{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "4c7aabad-748d-43c8-b7fb-025f60f08f2b",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import geopandas as gpd\n",
    "import numpy as np\n",
    "import gurobipy as gp\n",
    "from gurobipy import GRB\n",
    "import networkx as nx\n",
    "import itertools\n",
    "import sys\n",
    "sys.path.append('..')\n",
    "from security_game.target import Target\n",
    "from security_game.green_security_game import GreenSecurityGame\n",
    "from security_game.infra_security_game import InfraSecurityGame\n",
    "\n",
    "from solvers.mip import mip\n",
    "from solvers.nash import nash\n",
    "from solvers.double_oracle import double_oracle\n",
    "from solvers.double_oracle_sf import double_oracle_sf\n",
    "from solvers.no_regret import regret_matching\n",
    "import time\n",
    "from matplotlib import pyplot as plt\n",
    "from collections import defaultdict, Counter"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "d8b51046-6862-45ac-8da8-8ade42a0c432",
   "metadata": {},
   "outputs": [],
   "source": [
    "gdf = gpd.read_file(\"chinatown_infra.geojson\")\n",
    "\n",
    "# Step 1: Handle relevant columns\n",
    "infra_columns = [\n",
    "    \"id\", \"name\", \"power\", \"man_made\", \"amenity\",\n",
    "    \"generator:method\", \"generator:source\", \"geometry\"\n",
    "]\n",
    "available_columns = [col for col in infra_columns if col in gdf.columns]\n",
    "gdf = gdf[available_columns].copy()\n",
    "\n",
    "# Step 2: Extract generator type if present\n",
    "gdf[\"generator_type\"] = gdf.get(\"generator:method\")\n",
    "if \"generator_type\" not in gdf.columns or gdf[\"generator_type\"].isnull().all():\n",
    "    gdf[\"generator_type\"] = gdf.get(\"generator:source\")\n",
    "\n",
    "# Step 3: Construct unified 'type' column\n",
    "gdf[\"type\"] = gdf.get(\"power\")\n",
    "if \"amenity\" in gdf.columns:\n",
    "    gdf[\"type\"] = gdf[\"type\"].combine_first(gdf[\"amenity\"])\n",
    "if \"man_made\" in gdf.columns:\n",
    "    gdf[\"type\"] = gdf[\"type\"].combine_first(gdf[\"man_made\"])\n",
    "\n",
    "# Step 4: Refine generator classification (solar vs. other)\n",
    "gdf.loc[(gdf[\"type\"] == \"generator\") & (gdf[\"generator_type\"] == \"photovoltaic\"), \"type\"] = \"solar_generator\"\n",
    "gdf.loc[(gdf[\"type\"] == \"generator\") & (gdf[\"generator_type\"] == \"solar\"), \"type\"] = \"solar_generator\"\n",
    "\n",
    "# Step 5: Drop raw columns now that 'type' is finalized\n",
    "df_simple = gdf[[\"id\", \"name\", \"type\", \"geometry\"]].copy()\n",
    "\n",
    "# Step 6: Separate nodes and ways\n",
    "df_nodes = df_simple[df_simple[\"id\"].str.contains(\"node\")].copy()\n",
    "df_nodes[\"x\"] = df_nodes.geometry.x\n",
    "df_nodes[\"y\"] = df_nodes.geometry.y\n",
    "df_nodes = df_nodes.drop(columns=[\"geometry\"])\n",
    "\n",
    "df_ways = df_simple[df_simple[\"id\"].str.contains(\"way\")].copy()\n",
    "df_ways = df_ways.set_geometry(\"geometry\").to_crs(\"EPSG:32618\")\n",
    "df_ways[\"centroid\"] = df_ways.geometry.centroid\n",
    "df_ways = df_ways.set_geometry(\"centroid\").to_crs(\"EPSG:4326\")\n",
    "df_ways[\"x\"] = df_ways.geometry.x\n",
    "df_ways[\"y\"] = df_ways.geometry.y\n",
    "df_ways = df_ways.drop(columns=[\"geometry\", \"centroid\"])\n",
    "\n",
    "# Step 7: Combine nodes and ways\n",
    "df_combined = pd.concat([df_nodes, df_ways], ignore_index=True)\n",
    "df_combined = pd.concat([df_nodes, df_ways], ignore_index=True)\n",
    "ny_blocks_gdf =  gpd.read_file(\"tl_2020_36_tabblock20.shp\")\n",
    "INFRA_WEIGHTS = {\n",
    "    # Power Infrastructure\n",
    "    \"plant\": 1.5,\n",
    "    \"generator\": 1.35,\n",
    "    \"solar_generator\": 0.95,\n",
    "    \"substation\": 1.45,\n",
    "    \"transformer\": 1.25,\n",
    "    \"tower\": 1.1,\n",
    "    \"pole\": 0.85,\n",
    "    \"line\": 1.0,\n",
    "    \"minor_line\": 0.9,\n",
    "    \"cable\": 0.95,\n",
    "    \"switchgear\": 1.2,\n",
    "    \"busbar\": 0.8,\n",
    "    \"bay\": 0.85,\n",
    "    \"converter\": 1.05,\n",
    "    \"insulator\": 0.75,\n",
    "    \"portal\": 0.75,\n",
    "    \"connection\": 0.7,\n",
    "    \"compensator\": 1.0,\n",
    "    \"rectifier\": 0.95,\n",
    "    \"inverter\": 0.95,\n",
    "    \"storage\": 0.9,\n",
    "\n",
    "    # Healthcare\n",
    "    \"hospital\": 1.5,\n",
    "    \"clinic\": 1.35,\n",
    "\n",
    "    # Education\n",
    "    \"school\": 1.25,\n",
    "    \"university\": 1.4,\n",
    "\n",
    "    # Water & Sanitation\n",
    "    \"water_works\": 1.45,\n",
    "    \"wastewater_plant\": 1.4,\n",
    "\n",
    "    # Government & Emergency Services\n",
    "    \"fire_station\": 1.3,\n",
    "    \"police\": 1.4,\n",
    "    \"courthouse\": 1.2,\n",
    "\n",
    "    # Critical Infrastructure\n",
    "    \"bunker_silo\": 1.0,\n",
    "\n",
    "    # Communications\n",
    "    \"communications_tower\": 1.25,\n",
    "}\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "534ec574-fd1a-4fab-a2ea-e51875c8b455",
   "metadata": {
    "jp-MarkdownHeadingCollapsed": true
   },
   "source": [
    "# GSG DO NFG (DONE)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "eb5ecb6b-c947-47d1-a3a7-0633056d3fb0",
   "metadata": {
    "jupyter": {
     "source_hidden": true
    },
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "df = pd.read_csv(\"lobeke.csv\")\n",
    "df.dropna(inplace=True)\n",
    "\n",
    "# Lobeke National Park Bounding Box\n",
    "# lat_min, lon_min = 2.05522, 15.8790\n",
    "# lat_max, lon_max = 2.2837, 16.2038\n",
    "\n",
    "lat_min, lon_min = 2.0530, 15.8790\n",
    "lat_max, lon_max = 2.2837, 16.2038\n",
    "\n",
    "coordinate_rectangle = [lat_min, lat_max, lon_min, lon_max]\n",
    "\n",
    "schedule_form_kwargs = {\n",
    "    \"schedule_form\": False,\n",
    "    \"simple\": True,\n",
    "    \"attacker_penalty_factor\": 3,\n",
    "    \"defender_penalty_factor\": 3,\n",
    "    \"extra_coverage_weight\":0.9\n",
    "}\n",
    "\n",
    "general_sum_kwargs = {\n",
    "    \"general_sum\": False,\n",
    "    \"attacker_feature_value\":  42, \n",
    "    \"defender_feature_value\": 69, \n",
    "    \"defender_step_cost\": 32.5, \n",
    "}\n",
    "\n",
    "boulou_camp = (2.2,15.9)\n",
    "# lobeke_camp = (2.25,15.75)\n",
    "kabo_djembe = (2.0532352380408088, 16.085709866529694)\n",
    "bomassa = (2.2037280296158355, 16.187056364164913)\n",
    "inner_post = (2.2,15.98)\n",
    "\n",
    "i=0\n",
    "supports=[]\n",
    "for num_timesteps in [7,8,9,10]:\n",
    "    for num_attackers in [2,3]:\n",
    "        for num_clusters in [7,8,9,10,11,12]:\n",
    "            for dims in [7,8,9,10]:\n",
    "                for dt in [1,2]:\n",
    "                    for force_return in [True,False]:\n",
    "                        gsg = GreenSecurityGame(df, coordinate_rectangle, \"centroid\", num_clusters=num_clusters, num_rows=dims, num_columns=dims)\n",
    "                        gsg.generate(num_attackers=num_attackers, num_defenders=1, home_base_assignments=[(kabo_djembe, bomassa, inner_post)], num_timesteps=num_timesteps, generate_utility_matrix=False, force_return=force_return, general_sum=False, **schedule_form_kwargs)\n",
    "                        D_a, D_d, u, c = double_oracle(gsg, dt, force_return, verbose=False)\n",
    "                        support = sum([1 for p in D_d if p!=0])\n",
    "                        supports.append(support)\n",
    "                        print(f\"{i}/767: timesteps:{num_timesteps}, num_attackers:{num_attackers}, num_clusters:{num_clusters}, dims:{dims}, dt:{dt}, force_return:{force_return}, support:{support}\")\n",
    "                        i+=1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1586e1e2-a6a3-42f3-8845-b4c52cc9062e",
   "metadata": {
    "jupyter": {
     "source_hidden": true
    },
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "sorted(supports, reverse=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f9ba8132-8a2a-4833-b5e4-b91f1a1e5add",
   "metadata": {
    "jupyter": {
     "source_hidden": true
    }
   },
   "outputs": [],
   "source": [
    "arr = np.array(supports)\n",
    "ind = np.argpartition(arr, -13)[-13:]\n",
    "ind[np.argsort(arr[ind])][::-1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4f240ba1-e47f-43b8-99d5-f82e678d07d3",
   "metadata": {
    "jupyter": {
     "source_hidden": true
    }
   },
   "outputs": [],
   "source": [
    "#RESULTS WITH NO ADJUSTMENTS:\n",
    "#400/767: timesteps:9, num_attackers:2, num_clusters:8, dims:7, dt:1, force_return:True, support:7\n",
    "#659/767: timesteps:10, num_attackers:2, num_clusters:12, dims:7, dt:2, force_return:False, support:7\n",
    "#755/767: timesteps:10, num_attackers:3, num_clusters:12, dims:7, dt:2, force_return:False, support:7\n",
    "#752/767: timesteps:10, num_attackers:3, num_clusters:12, dims:7, dt:1, force_return:True, support:7\n",
    "#549/767: timesteps:9, num_attackers:3, num_clusters:11, dims:8, dt:1, force_return:False, support:7\n",
    "\n",
    "#609/767: timesteps:10, num_attackers:2, num_clusters:9, dims:7, dt:1, force_return:False, support:7 **\n",
    "#417/767: timesteps:9, num_attackers:2, num_clusters:9, dims:7, dt:1, force_return:False, support:7 **\n",
    "\n",
    "#705/767: timesteps:10, num_attackers:3, num_clusters:9, dims:7, dt:1, force_return:False, support:7 **\n",
    "#513/767: timesteps:9, num_attackers:3, num_clusters:9, dims:7, dt:1, force_return:False, support:7 **\n",
    "\n",
    "#721/767: timesteps:10, num_attackers:3, num_clusters:10, dims:7, dt:1, force_return:False, support:7 **\n",
    "#529/767: timesteps:9, num_attackers:3, num_clusters:10, dims:7, dt:1, force_return:False, support:7 **\n",
    "\n",
    "#625/767: timesteps:10, num_attackers:2, num_clusters:10, dims:7, dt:1, force_return:False, support:8 ***\n",
    "#433/767: timesteps:9, num_attackers:2, num_clusters:10, dims:7, dt:1, force_return:False, support:7 ***\n",
    "#THE REST\n",
    "#241/767: timesteps:8, num_attackers:2, num_clusters:10, dims:7, dt:1, force_return:False, support:5\n",
    "#49/767: timesteps:7, num_attackers:2, num_clusters:10, dims:7, dt:1, force_return:False, support:5\n",
    "#11 is 9\n",
    "#12 is 9\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "74719f42-703a-4a9c-a416-40e85de7cfe3",
   "metadata": {
    "jupyter": {
     "source_hidden": true
    },
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "df = pd.read_csv(\"lobeke.csv\")\n",
    "df.dropna(inplace=True)\n",
    "\n",
    "# Lobeke National Park Bounding Box\n",
    "# lat_min, lon_min = 2.05522, 15.8790\n",
    "# lat_max, lon_max = 2.2837, 16.2038\n",
    "\n",
    "lat_min, lon_min = 2.0530, 15.8790\n",
    "lat_max, lon_max = 2.2837, 16.2038\n",
    "\n",
    "coordinate_rectangle = [lat_min, lat_max, lon_min, lon_max]\n",
    "\n",
    "schedule_form_kwargs = {\n",
    "    \"schedule_form\": False,\n",
    "    \"simple\": True,\n",
    "    \"attacker_penalty_factor\": 3,\n",
    "    \"defender_penalty_factor\": 3,\n",
    "    \"extra_coverage_weight\":0.9\n",
    "}\n",
    "\n",
    "general_sum_kwargs = {\n",
    "    \"general_sum\": False,\n",
    "    \"attacker_feature_value\":  42, \n",
    "    \"defender_feature_value\": 69, \n",
    "    \"defender_step_cost\": 32.5, \n",
    "}\n",
    "\n",
    "boulou_camp = (2.2,15.9)\n",
    "# lobeke_camp = (2.25,15.75)\n",
    "kabo_djembe = (2.0532352380408088, 16.085709866529694)\n",
    "bomassa = (2.2037280296158355, 16.187056364164913)\n",
    "inner_post = (2.2,15.98)\n",
    "\n",
    "num_timesteps_li = []\n",
    "supports=[]\n",
    "defender_actions_sizes = []\n",
    "attacker_actions_sizes = []\n",
    "iterations_to_converge = []\n",
    "iteration_times_li = []\n",
    "gaps_li = []\n",
    "\n",
    "for num_timesteps in [6,7,8,9,10,11,12,13,14,15]:\n",
    "    print(num_timesteps)\n",
    "    num_timesteps_li.append(num_timesteps)\n",
    "    gsg = GreenSecurityGame(df, coordinate_rectangle, \"centroid\", num_clusters=10, num_rows=7, num_columns=7)\n",
    "    gsg.generate(num_attackers=2, num_defenders=1, home_base_assignments=[(kabo_djembe, bomassa, inner_post)], num_timesteps=num_timesteps, generate_utility_matrix=False, defense_time_threshold=1, generate_actions=False, force_return=False, general_sum=False, **schedule_form_kwargs)\n",
    "    D_a, D_d, u, A_a, A_d, c, its, gs = double_oracle(gsg, eps=1e-12, verbose=False)\n",
    "    support = sum([1 for p in D_d if p!=0])\n",
    "    supports.append(support)\n",
    "    iterations_to_converge.append(c)\n",
    "    iteration_times_li.append(its)\n",
    "    gaps_li.append(gs)\n",
    "    defender_actions_sizes.append(len(A_d))\n",
    "    attacker_actions_sizes.append(len(A_a))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f00cc325-1b1b-4d12-b99b-c178746e7383",
   "metadata": {
    "jupyter": {
     "source_hidden": true
    },
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "df = pd.DataFrame({\n",
    "    \"num_timesteps\": num_timesteps_li,\n",
    "    \"def_support\": supports,\n",
    "    \"iterations_to_converge\": iterations_to_converge,\n",
    "    \"iteration_times\": iteration_times_li,\n",
    "    \"gaps\": gaps_li,\n",
    "    \"defender_actions_size\": defender_actions_sizes,\n",
    "    \"attacker_actions_size\": attacker_actions_sizes\n",
    "})\n",
    "\n",
    "# Step 2: Explode list columns\n",
    "exploded_df = df.explode([\"iteration_times\", \"gaps\"], ignore_index=True)\n",
    "\n",
    "# Optional: Add a column for iteration number within each trial\n",
    "exploded_df[\"iteration_number\"] = exploded_df.groupby(\"num_timesteps\").cumcount()\n",
    "\n",
    "# Reorder if desired\n",
    "cols = [\"num_timesteps\", \"iteration_number\", \"iteration_times\", \"gaps\", \n",
    "        \"iterations_to_converge\", \"def_support\", \"defender_actions_size\", \"attacker_actions_size\"]\n",
    "exploded_df = exploded_df[cols]\n",
    "\n",
    "exploded_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6befbaaf-6b52-4abc-baf1-182032a4b90b",
   "metadata": {
    "jupyter": {
     "source_hidden": true
    }
   },
   "outputs": [],
   "source": [
    "exploded_df.to_csv(\"GSG_NFG_DO.csv\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d19e55ef-ed9b-464f-aae2-d4bbf97d6142",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "df = pd.read_csv(\"lobeke.csv\")\n",
    "df.dropna(inplace=True)\n",
    "\n",
    "# Lobeke National Park Bounding Box\n",
    "# lat_min, lon_min = 2.05522, 15.8790\n",
    "# lat_max, lon_max = 2.2837, 16.2038\n",
    "\n",
    "lat_min, lon_min = 2.0530, 15.8790\n",
    "lat_max, lon_max = 2.2837, 16.2038\n",
    "\n",
    "coordinate_rectangle = [lat_min, lat_max, lon_min, lon_max]\n",
    "\n",
    "schedule_form_kwargs = {\n",
    "    \"schedule_form\": False,\n",
    "    \"simple\": False,\n",
    "    \"attacker_penalty_factor\": 5,\n",
    "    \"defender_penalty_factor\": 5,\n",
    "    \"extra_coverage_weight\":1\n",
    "}\n",
    "\n",
    "general_sum_kwargs = {\n",
    "    \"general_sum\": False,\n",
    "    \"attacker_feature_value\":  42, \n",
    "    \"defender_feature_value\": 69, \n",
    "    \"defender_step_cost\": 32.5, \n",
    "}\n",
    "\n",
    "boulou_camp = (2.2,15.9)\n",
    "# lobeke_camp = (2.25,15.75)\n",
    "kabo_djembe = (2.0532352380408088, 16.085709866529694)\n",
    "bomassa = (2.2037280296158355, 16.187056364164913)\n",
    "inner_post = (2.2,15.98)\n",
    "num_timesteps_li = []\n",
    "supports=[]\n",
    "num_attackers_li=[]\n",
    "num_defenders_li=[]\n",
    "num_clusters_li = []\n",
    "dims_li = []\n",
    "dts = []\n",
    "frs = []\n",
    "defender_actions_sizes = []\n",
    "attacker_actions_sizes = []\n",
    "iterations_to_converge = []\n",
    "iteration_times_li = []\n",
    "gaps_li = []\n",
    "i=0\n",
    "for num_timesteps in [7,8,9,10,11]:\n",
    "    for num_attackers in [1,2,3]:\n",
    "        for num_defenders in [1,2,3]:\n",
    "            for num_clusters in [7,8,9,10,11,12]:\n",
    "                for dims in [7,8,9,10]:\n",
    "                    for dt in [1,2]:\n",
    "                        for fr in [True, False]:\n",
    "                            gsg = GreenSecurityGame(df, coordinate_rectangle, \"centroid\", num_clusters=num_clusters, num_rows=dims, num_columns=dims)\n",
    "                            gsg.generate(num_attackers=num_attackers, num_defenders=num_defenders, home_base_assignments=[(kabo_djembe, bomassa, inner_post) for i in range(num_defenders)], num_timesteps=num_timesteps, generate_utility_matrix=False, defense_time_threshold=dt, generate_actions=False, force_return=fr, general_sum=False, **schedule_form_kwargs)\n",
    "                            D_a, D_d, u, A_a, A_d, c, iteration_times, gaps = double_oracle(gsg,eps=1e-12, verbose=False)\n",
    "                            support = sum([1 for p in D_d if p!=0])\n",
    "                            supports.append(support)\n",
    "                            num_timesteps_li.append(num_timesteps)\n",
    "                            num_attackers_li.append(num_attackers)\n",
    "                            num_defenders_li.append(num_defenders)\n",
    "                            num_clusters_li.append(num_clusters)\n",
    "                            dims_li.append(dims)\n",
    "                            dts.append(dt)\n",
    "                            frs.append(fr)\n",
    "                            iterations_to_converge.append(c)\n",
    "                            defender_actions_sizes.append(len(A_d))\n",
    "                            attacker_actions_sizes.append(len(A_a))\n",
    "                            iteration_times_li.append(iteration_times)\n",
    "                            gaps_li.append(gaps)\n",
    "                            print(f\"{i}/4319: timesteps:{num_timesteps}, num_attackers:{num_attackers}, num_defenders:{num_defenders}, num_clusters:{num_clusters}, dims:{dims}, dt:{dt}, fr:{fr}, support:{support}\")\n",
    "                            i+=1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "513bc21b-f8a3-4f01-9261-5c26f4905e15",
   "metadata": {},
   "outputs": [],
   "source": [
    "df = pd.DataFrame({\n",
    "    \"num_timesteps\": num_timesteps_li,\n",
    "    \"num_attackers\": num_attackers_li,\n",
    "    \"num_defenders\": num_defenders_li,\n",
    "    \"num_clusters\": num_clusters_li,\n",
    "    \"dims\": dims_li,\n",
    "    \"defense_time_threshold\": dts,\n",
    "    \"force_return\": frs,\n",
    "    \"def_support\": supports,\n",
    "    \"iterations_to_converge\": iterations_to_converge,\n",
    "    \"iteration_time\": iteration_times_li,\n",
    "    \"gap\": gaps_li,\n",
    "    \"defender_actions_size\": defender_actions_sizes,\n",
    "    \"attacker_actions_size\": attacker_actions_sizes\n",
    "})\n",
    "\n",
    "# Step 2: Explode list columns\n",
    "exploded_df = df.explode([\"iteration_time\", \"gap\"], ignore_index=True)\n",
    "\n",
    "# Optional: Add a column for iteration number within each grouped trial\n",
    "exploded_df[\"iteration_number\"] = exploded_df.groupby(\n",
    "    [\"num_timesteps\", \"num_attackers\", \"num_defenders\", \"num_clusters\", \"dims\", \"force_return\", \"defense_time_threshold\"]\n",
    ").cumcount()\n",
    "\n",
    "# Reorder if desired\n",
    "cols = [\n",
    "    \"num_timesteps\",\"num_attackers\", \"num_defenders\", \"num_clusters\", \"dims\", \"force_return\", \"defense_time_threshold\",\n",
    "    \"iteration_number\", \"iteration_time\", \"gap\", \n",
    "    \"iterations_to_converge\", \"def_support\", \"defender_actions_size\", \"attacker_actions_size\"\n",
    "]\n",
    "exploded_df = exploded_df[cols]\n",
    "\n",
    "# Make iteration number 1-indexed\n",
    "exploded_df[\"iteration_number\"] += 1\n",
    "exploded_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9eb7de35-0883-4c97-b3d7-f79433e53794",
   "metadata": {},
   "outputs": [],
   "source": [
    "exploded_df.to_csv(\"GSG_NFG_DO_MASS_FINAL.csv\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f39f0786-09f9-48bf-a2c1-b71db6d795e0",
   "metadata": {
    "jupyter": {
     "source_hidden": true
    },
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "df = pd.read_csv(\"lobeke.csv\")\n",
    "df.dropna(inplace=True)\n",
    "\n",
    "# Lobeke National Park Bounding Box\n",
    "# lat_min, lon_min = 2.05522, 15.8790\n",
    "# lat_max, lon_max = 2.2837, 16.2038\n",
    "\n",
    "lat_min, lon_min = 2.0530, 15.8790\n",
    "lat_max, lon_max = 2.2837, 16.2038\n",
    "\n",
    "coordinate_rectangle = [lat_min, lat_max, lon_min, lon_max]\n",
    "\n",
    "schedule_form_kwargs = {\n",
    "    \"schedule_form\": False,\n",
    "    \"simple\": False,\n",
    "    \"attacker_penalty_factor\": 5,\n",
    "    \"defender_penalty_factor\": 5,\n",
    "    \"extra_coverage_weight\":1\n",
    "}\n",
    "\n",
    "general_sum_kwargs = {\n",
    "    \"general_sum\": False,\n",
    "    \"attacker_feature_value\":  42, \n",
    "    \"defender_feature_value\": 69, \n",
    "    \"defender_step_cost\": 32.5, \n",
    "}\n",
    "\n",
    "boulou_camp = (2.2,15.9)\n",
    "# lobeke_camp = (2.25,15.75)\n",
    "kabo_djembe = (2.0532352380408088, 16.085709866529694)\n",
    "bomassa = (2.2037280296158355, 16.187056364164913)\n",
    "inner_post = (2.2,15.98)\n",
    "num_timesteps_li = []\n",
    "supports=[]\n",
    "num_clusters_li = []\n",
    "dims_li = []\n",
    "dts = []\n",
    "defender_actions_sizes = []\n",
    "attacker_actions_sizes = []\n",
    "iterations_to_converge = []\n",
    "iteration_times_li = []\n",
    "gaps_li = []\n",
    "i=0\n",
    "for num_timesteps in [7,8,9,10,11]:\n",
    "    for num_clusters in [7,8,9,10,11,12]:\n",
    "        for dims in [7,8,9,10]:\n",
    "            for dt in [1,2]:\n",
    "                gsg = GreenSecurityGame(df, coordinate_rectangle, \"centroid\", num_clusters=num_clusters, num_rows=dims, num_columns=dims)\n",
    "                gsg.generate(num_attackers=1, num_defenders=3, home_base_assignments=[(kabo_djembe,), (bomassa,), (inner_post,)], num_timesteps=num_timesteps, generate_utility_matrix=False, defense_time_threshold=dt, generate_actions=False, force_return=True, general_sum=False, **schedule_form_kwargs)\n",
    "                D_a, D_d, u, A_a, A_d, c, iteration_times, gaps = double_oracle(gsg,eps=1e-12, verbose=False)\n",
    "                support = sum([1 for p in D_d if p!=0])\n",
    "                supports.append(support)\n",
    "                num_timesteps_li.append(num_timesteps)\n",
    "                num_clusters_li.append(num_clusters)\n",
    "                dims_li.append(dims)\n",
    "                dts.append(dt)\n",
    "                iterations_to_converge.append(c)\n",
    "                defender_actions_sizes.append(len(A_d))\n",
    "                attacker_actions_sizes.append(len(A_a))\n",
    "                iteration_times_li.append(iteration_times)\n",
    "                gaps_li.append(gaps)\n",
    "                print(f\"{i}/479: timesteps:{num_timesteps}, num_clusters:{num_clusters}, dims:{dims}, dt:{dt}, support:{support}\")\n",
    "                i+=1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b2d7eeb2-e567-4822-bfb3-307d2971c4a0",
   "metadata": {
    "jupyter": {
     "source_hidden": true
    },
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "df = pd.DataFrame({\n",
    "    \"num_timesteps\": num_timesteps_li,\n",
    "    \"num_clusters\": num_clusters_li,\n",
    "    \"dims\": dims_li,\n",
    "    \"defense_time_threshold\": dts,\n",
    "    \"def_support\": supports,\n",
    "    \"iterations_to_converge\": iterations_to_converge,\n",
    "    \"iteration_time\": iteration_times_li,\n",
    "    \"gap\": gaps_li,\n",
    "    \"defender_actions_size\": defender_actions_sizes,\n",
    "    \"attacker_actions_size\": attacker_actions_sizes\n",
    "})\n",
    "\n",
    "# Step 2: Explode list columns\n",
    "exploded_df = df.explode([\"iteration_time\", \"gap\"], ignore_index=True)\n",
    "\n",
    "# Optional: Add a column for iteration number within each grouped trial\n",
    "exploded_df[\"iteration_number\"] = exploded_df.groupby(\n",
    "    [\"num_timesteps\", \"num_clusters\", \"dims\", \"defense_time_threshold\"]\n",
    ").cumcount()\n",
    "\n",
    "# Reorder if desired\n",
    "cols = [\n",
    "    \"num_timesteps\", \"num_clusters\", \"dims\", \"defense_time_threshold\",\n",
    "    \"iteration_number\", \"iteration_time\", \"gap\", \n",
    "    \"iterations_to_converge\", \"def_support\", \"defender_actions_size\", \"attacker_actions_size\"\n",
    "]\n",
    "exploded_df = exploded_df[cols]\n",
    "\n",
    "# Make iteration number 1-indexed\n",
    "exploded_df[\"iteration_number\"] += 1\n",
    "exploded_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3f43419b-d9b4-4d6c-8c55-35a2a425614a",
   "metadata": {
    "jupyter": {
     "source_hidden": true
    }
   },
   "outputs": [],
   "source": [
    "exploded_df.to_csv(\"GSG_NFG_DO_3D_3_SEPARATE_HB.csv\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bc1007a2-5652-4794-9a52-75ded0c3b16d",
   "metadata": {
    "jupyter": {
     "source_hidden": true
    },
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "df = pd.read_csv(\"lobeke.csv\")\n",
    "df.dropna(inplace=True)\n",
    "\n",
    "# Lobeke National Park Bounding Box\n",
    "# lat_min, lon_min = 2.05522, 15.8790\n",
    "# lat_max, lon_max = 2.2837, 16.2038\n",
    "\n",
    "lat_min, lon_min = 2.0530, 15.8790\n",
    "lat_max, lon_max = 2.2837, 16.2038\n",
    "\n",
    "coordinate_rectangle = [lat_min, lat_max, lon_min, lon_max]\n",
    "\n",
    "schedule_form_kwargs = {\n",
    "    \"schedule_form\": False,\n",
    "    \"simple\": False,\n",
    "    \"attacker_penalty_factor\": 5,\n",
    "    \"defender_penalty_factor\": 5,\n",
    "    \"extra_coverage_weight\":1\n",
    "}\n",
    "\n",
    "general_sum_kwargs = {\n",
    "    \"general_sum\": False,\n",
    "    \"attacker_feature_value\":  42, \n",
    "    \"defender_feature_value\": 69, \n",
    "    \"defender_step_cost\": 32.5, \n",
    "}\n",
    "\n",
    "boulou_camp = (2.2,15.9)\n",
    "# lobeke_camp = (2.25,15.75)\n",
    "kabo_djembe = (2.0532352380408088, 16.085709866529694)\n",
    "bomassa = (2.2037280296158355, 16.187056364164913)\n",
    "inner_post = (2.2,15.98)\n",
    "num_timesteps_li = []\n",
    "supports=[]\n",
    "num_clusters_li = []\n",
    "dims_li = []\n",
    "dts = []\n",
    "defender_actions_sizes = []\n",
    "attacker_actions_sizes = []\n",
    "iterations_to_converge = []\n",
    "iteration_times_li = []\n",
    "gaps_li = []\n",
    "i=0\n",
    "for num_timesteps in [7,8,9,10,11,12,13,14,15]:\n",
    "    for num_clusters in [7,8,9,10,11,12]:\n",
    "        for dims in [7,8,9,10]:\n",
    "            for dt in [1,2]:\n",
    "                gsg = GreenSecurityGame(df, coordinate_rectangle, \"centroid\", num_clusters=num_clusters, num_rows=dims, num_columns=dims)\n",
    "                gsg.generate(num_attackers=1, num_defenders=1, home_base_assignments=[(kabo_djembe, bomassa, inner_post)], num_timesteps=num_timesteps, generate_utility_matrix=False, defense_time_threshold=dt, generate_actions=False, force_return=True, general_sum=False, **schedule_form_kwargs)\n",
    "                D_a, D_d, u, A_a, A_d, c, iteration_times, gaps = double_oracle(gsg,eps=1e-12, verbose=False)\n",
    "                support = sum([1 for p in D_d if p!=0])\n",
    "                supports.append(support)\n",
    "                num_timesteps_li.append(num_timesteps)\n",
    "                num_clusters_li.append(num_clusters)\n",
    "                dims_li.append(dims)\n",
    "                dts.append(dt)\n",
    "                iterations_to_converge.append(c)\n",
    "                defender_actions_sizes.append(len(A_d))\n",
    "                attacker_actions_sizes.append(len(A_a))\n",
    "                iteration_times_li.append(iteration_times)\n",
    "                gaps_li.append(gaps)\n",
    "                print(f\"{i}/239: timesteps:{num_timesteps}, num_clusters:{num_clusters}, dims:{dims}, dt:{dt}, support:{support}\")\n",
    "                i+=1"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "6c1a336b-f83b-4ed7-a93d-ebf72fd022a1",
   "metadata": {
    "jp-MarkdownHeadingCollapsed": true
   },
   "source": [
    "# GSG NR NFG"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "92b4900f-28bb-4576-8274-e834b8d40700",
   "metadata": {},
   "source": [
    "## RM"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9ae94990-eff2-432e-b2d2-479bec2449b4",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "df = pd.read_csv(\"lobeke.csv\")\n",
    "df.dropna(inplace=True)\n",
    "\n",
    "# Lobeke National Park Bounding Box\n",
    "# lat_min, lon_min = 2.05522, 15.8790\n",
    "# lat_max, lon_max = 2.2837, 16.2038\n",
    "\n",
    "lat_min, lon_min = 2.0530, 15.8790\n",
    "lat_max, lon_max = 2.2837, 16.2038\n",
    "\n",
    "coordinate_rectangle = [lat_min, lat_max, lon_min, lon_max]\n",
    "\n",
    "schedule_form_kwargs = {\n",
    "    \"schedule_form\": False,\n",
    "    \"simple\": False,\n",
    "    \"attacker_penalty_factor\": 3,\n",
    "    \"defender_penalty_factor\": 3,\n",
    "    \"extra_coverage_weight\":0.9\n",
    "}\n",
    "\n",
    "general_sum_kwargs = {\n",
    "    \"general_sum\": False,\n",
    "    \"attacker_feature_value\":  42, \n",
    "    \"defender_feature_value\": 69, \n",
    "    \"defender_step_cost\": 32.5, \n",
    "}\n",
    "\n",
    "boulou_camp = (2.2,15.9)\n",
    "# lobeke_camp = (2.25,15.75)\n",
    "kabo_djembe = (2.0532352380408088, 16.085709866529694)\n",
    "bomassa = (2.2037280296158355, 16.187056364164913)\n",
    "inner_post = (2.2,15.98)\n",
    "\n",
    "rm_num_attackers_li = []\n",
    "\n",
    "rm_gaps_li = []\n",
    "rm_interval_times_li = []\n",
    "rm_num_timesteps_li = []\n",
    "rm_frs = []\n",
    "rm_dts = []\n",
    "\n",
    "for num_timesteps in [7,8,9,10]:\n",
    "    for num_attackers in [1,2,3]:\n",
    "        for dt in [1,2]:\n",
    "            for fr in [True,False]:\n",
    "                gsg = GreenSecurityGame(df, coordinate_rectangle, \"centroid\", num_clusters=10, num_rows=7, num_columns=7)\n",
    "                gsg.generate(num_attackers=num_attackers, num_defenders=1, home_base_assignments=[(kabo_djembe, bomassa, inner_post)], num_timesteps=num_timesteps, generate_utility_matrix=True, defense_time_threshold=dt, generate_actions=False, force_return=fr, general_sum=False, **schedule_form_kwargs)\n",
    "                D_d, U, gaps, interval_times = regret_matching(gsg.utility_matrix, runtime=120, interval=5, iterations=10000, averaging=0, alternations=False, plus=False, predictive=False, verbose=True)\n",
    "                rm_num_attackers_li.append(num_attackers)\n",
    "                rm_frs.append(fr)\n",
    "                rm_dts.append(dt)\n",
    "                rm_gaps_li.append(gaps)\n",
    "                rm_interval_times_li.append(interval_times)\n",
    "                rm_num_timesteps_li.append(num_timesteps)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e08f3a86-ec98-4385-8212-9d25b47640e4",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "df = pd.DataFrame({\n",
    "    \"num_timesteps\": rm_num_timesteps_li,\n",
    "    \"num_attackers\": rm_num_attackers_li,\n",
    "    \"num_defenders\": [1 for i in range(len(rm_num_timesteps_li))],\n",
    "    \"defense_time_threshold\": rm_dts,\n",
    "    \"force_return\": rm_frs,\n",
    "    \"iteration_times\": rm_interval_times_li,\n",
    "    \"gaps\": rm_gaps_li\n",
    "})\n",
    "\n",
    "# Step 2: Explode list columns\n",
    "exploded_df = df.explode([\"iteration_times\", \"gaps\"], ignore_index=True)\n",
    "\n",
    "# Optional: Add a column for iteration number within each trial\n",
    "exploded_df[\"interval_number\"] = exploded_df.groupby([\"num_timesteps\",\"num_attackers\",\"force_return\",\"defense_time_threshold\"]).cumcount()\n",
    "\n",
    "# Reorder if desired\n",
    "cols = [\"num_timesteps\", \"num_attackers\", \"num_defenders\", \"defense_time_threshold\", \"force_return\", \"interval_number\", \"iteration_times\", \"gaps\"]\n",
    "exploded_df = exploded_df[cols]\n",
    "\n",
    "exploded_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7ca19229-20f8-4f18-ab46-cb166d578af2",
   "metadata": {
    "jupyter": {
     "source_hidden": true
    }
   },
   "outputs": [],
   "source": [
    "exploded_df[\"interval_number\"] = exploded_df[\"interval_number\"]+1\n",
    "exploded_df[\"iteration_number\"] = exploded_df[\"interval_number\"]*5"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ce96383b-e042-43cf-9590-9d2f7777e414",
   "metadata": {
    "jupyter": {
     "source_hidden": true
    },
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "exploded_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6dd90546-a329-422e-9774-84b95e8394e7",
   "metadata": {},
   "outputs": [],
   "source": [
    "exploded_df.to_csv(\"GSG_NFG_RM_FINAL_WITH_FR_DT.csv\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "23d23d03-c229-4978-8d16-71927b6f71f2",
   "metadata": {
    "scrolled": true
   },
   "source": [
    "## RM+"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "id": "ada41a84-b1e8-4a78-89e8-7ab071065423",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration 5 gap:  0.17967308627307088\n",
      "Iteration 10 gap:  0.11643591086142535\n",
      "Iteration 15 gap:  0.07471283152675262\n",
      "Iteration 20 gap:  0.05558705506928008\n",
      "Iteration 25 gap:  0.04404823171183947\n",
      "Iteration 30 gap:  0.028023419575692987\n",
      "Iteration 35 gap:  0.025542120157586057\n",
      "Iteration 40 gap:  0.020311785398360427\n",
      "Iteration 45 gap:  0.014373079722045046\n",
      "Iteration 50 gap:  0.013660184124061558\n",
      "Iteration 55 gap:  0.01317095758886666\n",
      "Iteration 60 gap:  0.01338183659893355\n",
      "Iteration 65 gap:  0.009940442341369704\n",
      "Iteration 70 gap:  0.008242446895940558\n",
      "Iteration 75 gap:  0.007850889447150289\n",
      "Iteration 80 gap:  0.010096746122998046\n",
      "Iteration 85 gap:  0.005281376760725265\n",
      "Iteration 90 gap:  0.005665800446756575\n",
      "Iteration 95 gap:  0.00906884212549397\n",
      "Iteration 100 gap:  0.003813926599430917\n",
      "Iteration 105 gap:  0.006836410907654633\n",
      "Iteration 110 gap:  0.005285998703892125\n",
      "Iteration 115 gap:  0.004791426088887718\n",
      "Iteration 120 gap:  0.0062955378624749425\n",
      "Iteration 125 gap:  0.006080191224617337\n",
      "Iteration 130 gap:  0.004458105677585311\n",
      "Iteration 135 gap:  0.0053089020888738014\n",
      "Iteration 140 gap:  0.004939911752128823\n",
      "Iteration 145 gap:  0.004091878462693765\n",
      "Iteration 150 gap:  0.0036943010844511237\n",
      "Iteration 155 gap:  0.0030037952577725013\n",
      "Iteration 160 gap:  0.004920840022436979\n",
      "Iteration 165 gap:  0.001946518769622707\n",
      "Iteration 170 gap:  0.003800782075270459\n",
      "Iteration 175 gap:  0.002456676134650171\n",
      "Iteration 180 gap:  0.0039664965403427566\n",
      "Iteration 185 gap:  0.0023716619107518877\n",
      "Iteration 190 gap:  0.0033017568877066195\n",
      "Iteration 195 gap:  0.003225748500970127\n",
      "Iteration 200 gap:  0.002551799030574009\n",
      "Iteration 205 gap:  0.0030984472625946724\n",
      "Iteration 210 gap:  0.0030435349936961398\n",
      "Iteration 215 gap:  0.002605492864242276\n",
      "Iteration 220 gap:  0.0024598596864993105\n",
      "Iteration 225 gap:  0.002289029364036632\n",
      "Iteration 230 gap:  0.0030726747139533384\n",
      "Iteration 235 gap:  0.002391578260120486\n",
      "Iteration 240 gap:  0.0021077276269092504\n",
      "Iteration 245 gap:  0.0024657770617370067\n",
      "Iteration 250 gap:  0.002363646676596609\n",
      "Iteration 255 gap:  0.0016047946056232387\n",
      "Iteration 260 gap:  0.002410923929585196\n",
      "Iteration 265 gap:  0.003017297242049355\n",
      "Iteration 270 gap:  0.0018456932407830973\n",
      "Iteration 275 gap:  0.001645635903989029\n",
      "Iteration 280 gap:  0.0023607836005201666\n",
      "Iteration 285 gap:  0.0023524300245295615\n",
      "Iteration 290 gap:  0.0017417387705133125\n",
      "Iteration 295 gap:  0.0015509346922041312\n",
      "Iteration 300 gap:  0.0016197356365433846\n",
      "Iteration 305 gap:  0.0022921784084862784\n",
      "Iteration 310 gap:  0.0024597243486194076\n",
      "Iteration 315 gap:  0.0015948868830965024\n",
      "Iteration 320 gap:  0.0020778138998959195\n",
      "Iteration 325 gap:  0.0013958648754053282\n",
      "Iteration 330 gap:  0.001856267638028375\n",
      "Iteration 335 gap:  0.0010859181117629513\n",
      "Iteration 340 gap:  0.0017356283716410958\n",
      "Iteration 345 gap:  0.00217085611956791\n",
      "Iteration 350 gap:  0.0015682859520916859\n",
      "Iteration 355 gap:  0.0013048931333845548\n",
      "Iteration 360 gap:  0.0021742908015898177\n",
      "Iteration 365 gap:  0.0018740746612001535\n",
      "Iteration 370 gap:  0.0013342552152295628\n",
      "Iteration 375 gap:  0.0012301536859533613\n",
      "Iteration 380 gap:  0.001303342563429566\n",
      "Iteration 385 gap:  0.001810768813603203\n",
      "Iteration 390 gap:  0.001984780976004963\n",
      "Iteration 395 gap:  0.0012997146714651686\n",
      "Iteration 400 gap:  0.001546650408413619\n",
      "Iteration 405 gap:  0.0008432601617981428\n",
      "Iteration 410 gap:  0.0016149480381731918\n",
      "Iteration 415 gap:  0.0009018449674259577\n",
      "Iteration 420 gap:  0.0012589909758953244\n",
      "Iteration 425 gap:  0.0019039432218449504\n",
      "Iteration 430 gap:  0.0010692426196819982\n",
      "Iteration 435 gap:  0.001235034546883007\n",
      "Iteration 440 gap:  0.0012125242773323164\n",
      "Iteration 445 gap:  0.0013407441241362061\n",
      "Iteration 450 gap:  0.0013755642718257244\n",
      "Iteration 455 gap:  0.0009706953526202877\n",
      "Iteration 460 gap:  0.0009473842853412462\n",
      "Iteration 465 gap:  0.0011494563766355492\n",
      "Iteration 470 gap:  0.0016293503643600715\n",
      "Iteration 475 gap:  0.0013306844731427736\n",
      "Iteration 480 gap:  0.0010267021572013535\n",
      "Iteration 485 gap:  0.001001492307922236\n",
      "Iteration 490 gap:  0.0006400431526423223\n",
      "Iteration 495 gap:  0.001505840832398464\n",
      "Iteration 500 gap:  0.0010190882156551062\n",
      "Iteration 505 gap:  0.001137746039836518\n",
      "Iteration 510 gap:  0.001539659631442536\n",
      "Iteration 515 gap:  0.0009000902048643677\n",
      "Iteration 520 gap:  0.0011031763442052034\n",
      "Iteration 525 gap:  0.000854681812671898\n",
      "Iteration 530 gap:  0.0014595365466715249\n",
      "Iteration 535 gap:  0.0014412636750331664\n",
      "Iteration 540 gap:  0.0008719124158071967\n",
      "Iteration 545 gap:  0.0006967433465738804\n",
      "Iteration 550 gap:  0.0009133111478069056\n",
      "Iteration 555 gap:  0.0011444997357905606\n",
      "Iteration 560 gap:  0.0013931008545521317\n",
      "Iteration 565 gap:  0.0009726063087939218\n",
      "Iteration 570 gap:  0.0008968421850343855\n",
      "Iteration 575 gap:  0.0005424995384923914\n",
      "Iteration 580 gap:  0.0010766980351505362\n",
      "Iteration 585 gap:  0.0011818638838136941\n",
      "Iteration 590 gap:  0.0005747524464209119\n",
      "Iteration 595 gap:  0.0012362548462802048\n",
      "Iteration 600 gap:  0.0011365472492540496\n",
      "Iteration 605 gap:  0.0009695091886687823\n",
      "Iteration 610 gap:  0.0007574572245475641\n",
      "Iteration 615 gap:  0.0008893257917672592\n",
      "Iteration 620 gap:  0.001093416333694086\n",
      "Iteration 625 gap:  0.0012733658632175793\n",
      "Iteration 630 gap:  0.0007474820642222602\n",
      "Iteration 635 gap:  0.0005157253923868677\n",
      "Iteration 640 gap:  0.000908651469671895\n",
      "Iteration 645 gap:  0.0009939710645865407\n",
      "Iteration 650 gap:  0.0011390553798575898\n",
      "Iteration 655 gap:  0.0008693236376349223\n",
      "Iteration 660 gap:  0.0007849902640031381\n",
      "Iteration 665 gap:  0.0005793550940677017\n",
      "Iteration 670 gap:  0.0009173072988672981\n",
      "Iteration 675 gap:  0.0011415956468620037\n",
      "Iteration 680 gap:  0.0005999616805010266\n",
      "Iteration 685 gap:  0.0010149948258051378\n",
      "Iteration 690 gap:  0.0010138447767981118\n",
      "Iteration 695 gap:  0.0007602165876805511\n",
      "Iteration 700 gap:  0.0007696649873830674\n",
      "Iteration 705 gap:  0.0005882668915484501\n",
      "Iteration 710 gap:  0.0009661684256171421\n",
      "Iteration 715 gap:  0.0011647195229251839\n",
      "Iteration 720 gap:  0.0007397938632398571\n",
      "Iteration 725 gap:  0.0005726117915378914\n",
      "Iteration 730 gap:  0.0005107977776384054\n",
      "Iteration 735 gap:  0.0009126442935338819\n",
      "Iteration 740 gap:  0.0009743291987618363\n",
      "Iteration 745 gap:  0.0008540931443112854\n",
      "Iteration 750 gap:  0.0005995646799724641\n",
      "Iteration 755 gap:  0.0005161853453859999\n",
      "Iteration 760 gap:  0.000656169105786919\n",
      "Iteration 765 gap:  0.0010798871970775226\n",
      "Iteration 770 gap:  0.0009266324040967389\n",
      "Iteration 775 gap:  0.0006952550334873298\n",
      "Iteration 780 gap:  0.0009007603857521529\n",
      "Iteration 785 gap:  0.00062617351215144\n",
      "Iteration 790 gap:  0.0006772333466807945\n",
      "Iteration 795 gap:  0.0006680220703065842\n",
      "Iteration 800 gap:  0.000578248001508852\n",
      "Iteration 805 gap:  0.0008077370742505252\n",
      "Iteration 810 gap:  0.0009806204197967405\n",
      "Iteration 815 gap:  0.0005555594544370823\n",
      "Iteration 820 gap:  0.0005924765512207442\n",
      "Iteration 825 gap:  0.0005442021500086103\n",
      "Iteration 830 gap:  0.0009556330427756832\n",
      "Iteration 835 gap:  0.0008501316028798334\n",
      "Iteration 840 gap:  0.0006883942412094779\n",
      "Iteration 845 gap:  0.0005089606638383204\n",
      "Iteration 850 gap:  0.000489790059032158\n",
      "Iteration 855 gap:  0.0005735864513322086\n",
      "Iteration 860 gap:  0.0008968665113588958\n",
      "Iteration 865 gap:  0.000846861622091355\n",
      "Iteration 870 gap:  0.0005320278435012593\n",
      "Iteration 875 gap:  0.0007419732993185768\n",
      "Iteration 880 gap:  0.0006270714536928956\n",
      "Iteration 885 gap:  0.0006825235606979785\n",
      "Iteration 890 gap:  0.0007578550465279221\n",
      "Iteration 895 gap:  0.0004031635025257829\n",
      "Iteration 900 gap:  0.0006023352877648769\n",
      "Iteration 905 gap:  0.0009296123680994084\n",
      "Iteration 910 gap:  0.0006300062574142729\n",
      "Iteration 915 gap:  0.0005859751477538255\n",
      "Iteration 920 gap:  0.00033915781378279775\n",
      "Iteration 925 gap:  0.0007012275702992232\n",
      "Iteration 930 gap:  0.000711115980420951\n",
      "Iteration 935 gap:  0.0008040577932597603\n",
      "Iteration 940 gap:  0.0005223533375274814\n",
      "Iteration 945 gap:  0.0004310059910757058\n",
      "Iteration 950 gap:  0.00045441213627350763\n",
      "Iteration 955 gap:  0.0006057419014835475\n",
      "Iteration 960 gap:  0.000873587407090759\n",
      "Iteration 965 gap:  0.0005556726191290329\n",
      "Iteration 970 gap:  0.0005761784211457677\n",
      "Iteration 975 gap:  0.0005540332838174233\n",
      "Iteration 980 gap:  0.000373236072661598\n",
      "Iteration 985 gap:  0.0007369327913659962\n",
      "Iteration 990 gap:  0.0006967757875013803\n",
      "Iteration 995 gap:  0.00035819633871414513\n",
      "Iteration 1000 gap:  0.0006870501375247917\n",
      "Iteration 1005 gap:  0.0007874398974005992\n",
      "Iteration 1010 gap:  0.0004149593953787223\n",
      "Iteration 1015 gap:  0.0005553368168648154\n",
      "Iteration 1020 gap:  0.00033979819146234824\n",
      "Iteration 1025 gap:  0.0006470668497812193\n",
      "Iteration 1030 gap:  0.0006120834434523159\n",
      "Iteration 1035 gap:  0.0007479279314540621\n",
      "Iteration 1040 gap:  0.00043528062586317695\n",
      "Iteration 1045 gap:  0.0003255736939843379\n",
      "Iteration 1050 gap:  0.00047155767845918906\n",
      "Iteration 1055 gap:  0.000559135245273068\n",
      "Iteration 1060 gap:  0.0007716685525226419\n",
      "Iteration 1065 gap:  0.0005354731296695059\n",
      "Iteration 1070 gap:  0.0005086582208291279\n",
      "Iteration 1075 gap:  0.00042508148743969354\n",
      "Iteration 1080 gap:  0.0003277099087437563\n",
      "Iteration 1085 gap:  0.0006886828292346214\n",
      "Iteration 1090 gap:  0.0006912286613540708\n",
      "Iteration 1095 gap:  0.00031769633093237104\n",
      "Iteration 1100 gap:  0.000606822575558108\n",
      "Iteration 1105 gap:  0.0006985302286195427\n",
      "Iteration 1110 gap:  0.0004117284971337787\n",
      "Iteration 1115 gap:  0.0005333883429325947\n",
      "Iteration 1120 gap:  0.00038594302564198824\n",
      "Iteration 1125 gap:  0.0005357400634035114\n",
      "Iteration 1130 gap:  0.0005652798125013181\n",
      "Iteration 1135 gap:  0.0007286081126709476\n",
      "Iteration 1140 gap:  0.00044315196092858944\n",
      "Iteration 1145 gap:  0.00029379688901542966\n",
      "Iteration 1150 gap:  0.0003233124075049387\n",
      "Iteration 1155 gap:  0.0005631361003158863\n",
      "Iteration 1160 gap:  0.0006509145293407403\n",
      "Iteration 1165 gap:  0.0005899861452812738\n",
      "Iteration 1170 gap:  0.00045561759703394156\n",
      "Iteration 1175 gap:  0.000378968689023762\n",
      "Iteration 1180 gap:  0.0003001789638986674\n",
      "Iteration 1185 gap:  0.0005051320674079873\n",
      "Iteration 1190 gap:  0.0006949744587649853\n",
      "Iteration 1195 gap:  0.0004757481810435671\n",
      "Iteration 1200 gap:  0.00043886895372702295\n",
      "Iteration 1205 gap:  0.0006301751346441398\n",
      "Iteration 1210 gap:  0.000519827569542719\n",
      "Iteration 1215 gap:  0.0004647216269664245\n",
      "Iteration 1220 gap:  0.0004603512820381406\n",
      "Iteration 1225 gap:  0.00032924494232522417\n",
      "Iteration 1230 gap:  0.0005413153927572578\n",
      "Iteration 1235 gap:  0.0006652801759625682\n",
      "Iteration 1240 gap:  0.0005766701238353322\n",
      "Iteration 1245 gap:  0.00028471624738724\n",
      "Iteration 1250 gap:  0.00029945182411517113\n",
      "Iteration 1255 gap:  0.0004091661119679513\n",
      "Iteration 1260 gap:  0.0006123339807547756\n",
      "Iteration 1265 gap:  0.0006051392548209744\n",
      "Iteration 1270 gap:  0.00046101484192506703\n",
      "Iteration 1275 gap:  0.00041896860478629616\n",
      "Iteration 1280 gap:  0.00037370941574255134\n",
      "Iteration 1285 gap:  0.00032343589920869054\n",
      "Iteration 1290 gap:  0.0004985502826518884\n",
      "Iteration 1295 gap:  0.0006537448945577173\n",
      "Iteration 1300 gap:  0.0004466416889553626\n",
      "Iteration 1305 gap:  0.0004905926746645584\n",
      "Iteration 1310 gap:  0.0005494301251696143\n",
      "Iteration 1315 gap:  0.0003627971982469447\n",
      "Iteration 1320 gap:  0.0004167756373308906\n",
      "Iteration 1325 gap:  0.00045847747521554627\n",
      "Iteration 1330 gap:  0.00035722310609154206\n",
      "Iteration 1335 gap:  0.0004065908374957239\n",
      "Iteration 1340 gap:  0.0006058061632738809\n",
      "Iteration 1345 gap:  0.0005398039304070901\n",
      "Iteration 1350 gap:  0.00032356649500908663\n",
      "Iteration 1355 gap:  0.0003090997360063463\n",
      "Iteration 1360 gap:  0.00037546987440573165\n",
      "Iteration 1365 gap:  0.0005007189305762383\n",
      "Iteration 1370 gap:  0.0004917162225503979\n",
      "Iteration 1375 gap:  0.000526842253507076\n",
      "Iteration 1380 gap:  0.0003553398158173682\n",
      "Iteration 1385 gap:  0.00028874629350139625\n",
      "Iteration 1390 gap:  0.00032006863026357024\n",
      "Iteration 1395 gap:  0.0004383861678092238\n",
      "Iteration 1400 gap:  0.0006090128131474026\n",
      "Iteration 1405 gap:  0.0004435914103894101\n",
      "Iteration 1410 gap:  0.00039621036931303255\n",
      "Iteration 1415 gap:  0.00046219586578466476\n",
      "Iteration 1420 gap:  0.0003807696224664703\n",
      "Iteration 1425 gap:  0.00041395914084474406\n",
      "Iteration 1430 gap:  0.0004971268395080886\n",
      "Iteration 1435 gap:  0.0003480122038500566\n",
      "Iteration 1440 gap:  0.00033894285253088796\n",
      "Iteration 1445 gap:  0.0005572620035566578\n",
      "Iteration 1450 gap:  0.0005375381359908893\n",
      "Iteration 1455 gap:  0.000315416769392618\n",
      "Iteration 1460 gap:  0.00035010867301177306\n",
      "Iteration 1465 gap:  0.00023477667296967208\n",
      "Iteration 1470 gap:  0.0004967759640672753\n",
      "Iteration 1475 gap:  0.0004015271344440796\n",
      "Iteration 1480 gap:  0.000481592735259051\n",
      "Iteration 1485 gap:  0.00041720150261392863\n",
      "Iteration 1490 gap:  0.00031889925719841283\n",
      "Iteration 1495 gap:  0.0002880440433207232\n",
      "Iteration 1500 gap:  0.0004195670468692958\n",
      "Iteration 1505 gap:  0.000519233298821975\n",
      "Iteration 1510 gap:  0.0005320092829982359\n",
      "Iteration 1515 gap:  0.00038925990150695533\n",
      "Iteration 1520 gap:  0.00039640410534957926\n",
      "Iteration 1525 gap:  0.0003373346891306639\n",
      "Iteration 1530 gap:  0.00023011753671264845\n",
      "Iteration 1535 gap:  0.00047562208498774794\n",
      "Iteration 1540 gap:  0.0004850427951614833\n",
      "Iteration 1545 gap:  0.00027003451344231877\n",
      "Iteration 1550 gap:  0.00039231411917273196\n",
      "Iteration 1555 gap:  0.000536089804164086\n",
      "Iteration 1560 gap:  0.0004164265802695244\n",
      "Iteration 1565 gap:  0.0003299193825309077\n",
      "Iteration 1570 gap:  0.000294433518084114\n",
      "Iteration 1575 gap:  0.0002925371148311262\n",
      "Iteration 1580 gap:  0.00046936197406965974\n",
      "Iteration 1585 gap:  0.0004718826544150012\n",
      "Iteration 1590 gap:  0.0004639585874131047\n",
      "Iteration 1595 gap:  0.00031782054091789025\n",
      "Iteration 1600 gap:  0.00024966910382551166\n",
      "Iteration 1605 gap:  0.00028334606380897576\n",
      "Iteration 1610 gap:  0.00043804362447763534\n",
      "Iteration 1615 gap:  0.0004930408371031092\n",
      "Iteration 1620 gap:  0.00045907531435929183\n",
      "Iteration 1625 gap:  0.0003881251079340675\n",
      "Iteration 1630 gap:  0.00034314438959015536\n",
      "Iteration 1635 gap:  0.00024298906858966074\n",
      "Iteration 1640 gap:  0.00023344886221043915\n",
      "Iteration 1645 gap:  0.00047478828593550126\n",
      "Iteration 1650 gap:  0.00047251057943742403\n",
      "Iteration 1655 gap:  0.00025009903243788933\n",
      "Iteration 1660 gap:  0.000392226246598959\n",
      "Iteration 1665 gap:  0.00047795214551793475\n",
      "Iteration 1670 gap:  0.00035658405889216205\n",
      "Iteration 1675 gap:  0.000331785298794518\n",
      "Iteration 1680 gap:  0.0003128577907852703\n",
      "Iteration 1685 gap:  0.00026096142486509155\n",
      "Iteration 1690 gap:  0.0004108186829174798\n",
      "Iteration 1695 gap:  0.00046696567139059564\n",
      "Iteration 1700 gap:  0.0004521562128220191\n",
      "Iteration 1705 gap:  0.0002869848870297176\n",
      "Iteration 1710 gap:  0.00021648104452465233\n",
      "Iteration 1715 gap:  0.0002469854076649902\n",
      "Iteration 1720 gap:  0.0004206494185763354\n",
      "Iteration 1725 gap:  0.00042382075106539574\n",
      "Iteration 1730 gap:  0.0004268491655861073\n",
      "Iteration 1735 gap:  0.00037853945300347913\n",
      "Iteration 1740 gap:  0.00029751486980422737\n",
      "Iteration 1745 gap:  0.00021639682490437462\n",
      "Iteration 1750 gap:  0.00025624351965347625\n",
      "Iteration 1755 gap:  0.000426843159229251\n",
      "Iteration 1760 gap:  0.00047603403023310786\n",
      "Iteration 1765 gap:  0.00029567184618373155\n",
      "Iteration 1770 gap:  0.00034049560736748585\n",
      "Iteration 1775 gap:  0.0004268469000846542\n",
      "Iteration 1780 gap:  0.000353217218999724\n",
      "Iteration 1785 gap:  0.00031609191841708295\n",
      "Iteration 1790 gap:  0.0003432342012086309\n",
      "Iteration 1795 gap:  0.0002545666662115975\n",
      "Iteration 1800 gap:  0.0003301995931166424\n",
      "Iteration 1805 gap:  0.0004121056931799538\n",
      "Iteration 1810 gap:  0.00045682506247879395\n",
      "Iteration 1815 gap:  0.00032675686336913756\n",
      "Iteration 1820 gap:  0.0002403468624649907\n",
      "Iteration 1825 gap:  0.00017912094798766542\n",
      "Iteration 1830 gap:  0.0003434114213605177\n",
      "Iteration 1835 gap:  0.0003565014671245148\n",
      "Iteration 1840 gap:  0.0003944571276320863\n",
      "Iteration 1845 gap:  0.0003886299465155618\n",
      "Iteration 1850 gap:  0.0002869168261750987\n",
      "Iteration 1855 gap:  0.00022168869629868304\n",
      "Iteration 1860 gap:  0.00021264008739807494\n",
      "Iteration 1865 gap:  0.00030289475699307733\n",
      "Iteration 1870 gap:  0.0004499261613922778\n",
      "Iteration 1875 gap:  0.0003899504131904541\n",
      "Iteration 1880 gap:  0.0002690762865292795\n",
      "Iteration 1885 gap:  0.0003740763312699569\n",
      "Iteration 1890 gap:  0.00035879097887425715\n",
      "Iteration 1895 gap:  0.00021811742528254907\n",
      "Iteration 1900 gap:  0.0003305305165359762\n",
      "Iteration 1905 gap:  0.0003333785989787508\n",
      "Iteration 1910 gap:  0.00026429521847848303\n",
      "Iteration 1915 gap:  0.0002978090910409348\n",
      "Iteration 1920 gap:  0.0004286000555692171\n",
      "Iteration 1925 gap:  0.00040233425821567526\n",
      "Iteration 1930 gap:  0.00020791034062050961\n",
      "Iteration 1935 gap:  0.0002444279320088505\n",
      "Iteration 1940 gap:  0.00017091228068466524\n",
      "Iteration 1945 gap:  0.00034165841359068416\n",
      "Iteration 1950 gap:  0.00035117010769258883\n",
      "Iteration 1955 gap:  0.0003917923610438079\n",
      "Iteration 1960 gap:  0.0003254230320610674\n",
      "Iteration 1965 gap:  0.00022514122523487057\n",
      "Iteration 1970 gap:  0.00019352470691047508\n",
      "Iteration 1975 gap:  0.00024316918124467346\n",
      "Iteration 1980 gap:  0.0003214811452851851\n",
      "Iteration 1985 gap:  0.0004366699636938476\n",
      "Iteration 1990 gap:  0.0003468364332133156\n",
      "Iteration 1995 gap:  0.00031877741482877475\n",
      "Iteration 2000 gap:  0.0003285018534547879\n",
      "Iteration 2005 gap:  0.000258067693106212\n",
      "Iteration 2010 gap:  0.00020232985261459113\n",
      "Iteration 2015 gap:  0.0003675552538828786\n",
      "Iteration 2020 gap:  0.00035331364345758676\n",
      "Iteration 2025 gap:  0.00020437094857184146\n",
      "Iteration 2030 gap:  0.00030645416890562327\n",
      "Iteration 2035 gap:  0.0004207426688142002\n",
      "Iteration 2040 gap:  0.00034689700597700934\n",
      "Iteration 2045 gap:  0.0002354468096837925\n",
      "Iteration 2050 gap:  0.00023670602250713824\n",
      "Iteration 2055 gap:  0.00018628646374851954\n",
      "Iteration 2060 gap:  0.00034701926300617636\n",
      "Iteration 2065 gap:  0.00030010214434317284\n",
      "Iteration 2070 gap:  0.0003663436174338175\n",
      "Iteration 2075 gap:  0.0003330984876286358\n",
      "Iteration 2080 gap:  0.00022094695494578875\n",
      "Iteration 2085 gap:  0.00015139620163551193\n",
      "Iteration 2090 gap:  0.00025658686436780265\n",
      "Iteration 2095 gap:  0.0002990749265612269\n",
      "Iteration 2100 gap:  0.00039842816251278723\n",
      "Iteration 2105 gap:  0.00032606252331479624\n",
      "Iteration 2110 gap:  0.00027732070365538153\n",
      "Iteration 2115 gap:  0.00028292159682929974\n",
      "Iteration 2120 gap:  0.00023929959913338017\n",
      "Iteration 2125 gap:  0.00020776351321827313\n",
      "Iteration 2130 gap:  0.00034283545417412853\n",
      "Iteration 2135 gap:  0.0003517683941481886\n",
      "Iteration 2140 gap:  0.0002556248731803157\n",
      "Iteration 2145 gap:  0.0003037500836889917\n",
      "Iteration 2150 gap:  0.00037975689720759487\n",
      "Iteration 2155 gap:  0.0003238068421482776\n",
      "Iteration 2160 gap:  0.00020268255218092168\n",
      "Iteration 2165 gap:  0.0002471250643649725\n",
      "Iteration 2170 gap:  0.00021711137975921613\n",
      "Iteration 2175 gap:  0.0002761278403088374\n",
      "Iteration 2180 gap:  0.0003124110423604609\n",
      "Iteration 2185 gap:  0.00038917837253138465\n",
      "Iteration 2190 gap:  0.00032028388056082324\n",
      "Iteration 2195 gap:  0.000184635335352068\n",
      "Iteration 2200 gap:  0.00013887327305439623\n",
      "Iteration 2205 gap:  0.0002050203782973936\n",
      "Iteration 2210 gap:  0.0003282163101520075\n",
      "Iteration 2215 gap:  0.0003553986617235161\n",
      "Iteration 2220 gap:  0.0003370419231844002\n",
      "Iteration 2225 gap:  0.0002993564003422877\n",
      "Iteration 2230 gap:  0.00025338568504895687\n",
      "Iteration 2235 gap:  0.00018530375556824463\n",
      "Iteration 2240 gap:  0.00017958401144968494\n",
      "Iteration 2245 gap:  0.00031052164395994897\n",
      "Iteration 2250 gap:  0.00037362408120811264\n",
      "Iteration 2255 gap:  0.00027899894942551295\n",
      "Iteration 2260 gap:  0.00023208722090473088\n",
      "Iteration 2265 gap:  0.0003423564812169433\n",
      "Iteration 2270 gap:  0.00033255030724010926\n",
      "Iteration 2275 gap:  0.00020000233038386384\n",
      "Iteration 2280 gap:  0.00024631597814828154\n",
      "Iteration 2285 gap:  0.00023659462165825929\n",
      "Iteration 2290 gap:  0.00021111840473186927\n",
      "Iteration 2295 gap:  0.0002634675506669737\n",
      "Iteration 2300 gap:  0.0003392789954039799\n",
      "Iteration 2305 gap:  0.00036522687635642814\n",
      "Iteration 2310 gap:  0.0002314213200025339\n",
      "Iteration 2315 gap:  0.00016513729293088364\n",
      "Iteration 2320 gap:  0.00011301145432918158\n",
      "Iteration 2325 gap:  0.00026137937450121385\n",
      "Iteration 2330 gap:  0.0003166483641419138\n",
      "Iteration 2335 gap:  0.00033495359031143757\n",
      "Iteration 2340 gap:  0.00027290875198160425\n",
      "Iteration 2345 gap:  0.00026494511532970666\n",
      "Iteration 2350 gap:  0.00020307351632864457\n",
      "Iteration 2355 gap:  0.00014410859064017956\n",
      "Iteration 2360 gap:  0.0002149012087327984\n",
      "Iteration 2365 gap:  0.0003427965929495569\n",
      "Iteration 2370 gap:  0.000353417938092071\n",
      "Iteration 2375 gap:  0.00021773924448575954\n",
      "Iteration 2380 gap:  0.0002682087244296749\n",
      "Iteration 2385 gap:  0.00031118572270893985\n",
      "Iteration 2390 gap:  0.000262329274087314\n",
      "Iteration 2395 gap:  0.00022927846708598043\n",
      "Iteration 2400 gap:  0.00027349381111752\n",
      "Iteration 2405 gap:  0.00023493047645650744\n",
      "Iteration 2410 gap:  0.00020729325550317146\n",
      "\n"
     ]
    }
   ],
   "source": [
    "df = pd.read_csv(\"lobeke.csv\")\n",
    "df.dropna(inplace=True)\n",
    "\n",
    "# Lobeke National Park Bounding Box\n",
    "# lat_min, lon_min = 2.05522, 15.8790\n",
    "# lat_max, lon_max = 2.2837, 16.2038\n",
    "\n",
    "lat_min, lon_min = 2.0530, 15.8790\n",
    "lat_max, lon_max = 2.2837, 16.2038\n",
    "\n",
    "coordinate_rectangle = [lat_min, lat_max, lon_min, lon_max]\n",
    "\n",
    "schedule_form_kwargs = {\n",
    "    \"schedule_form\": False,\n",
    "    \"simple\": False,\n",
    "    \"attacker_penalty_factor\": 5,\n",
    "    \"defender_penalty_factor\": 5,\n",
    "}\n",
    "\n",
    "general_sum_kwargs = {\n",
    "    \"general_sum\": False,\n",
    "    \"attacker_feature_value\":  42, \n",
    "    \"defender_feature_value\": 69, \n",
    "    \"defender_step_cost\": 32.5, \n",
    "}\n",
    "\n",
    "boulou_camp = (2.2,15.9)\n",
    "# lobeke_camp = (2.25,15.75)\n",
    "kabo_djembe = (2.0532352380408088, 16.085709866529694)\n",
    "bomassa = (2.2037280296158355, 16.187056364164913)\n",
    "inner_post = (2.2,15.98)\n",
    "\n",
    "rmp_num_attackers_li = []\n",
    "\n",
    "rmp_gaps_li = []\n",
    "rmp_interval_times_li = []\n",
    "rmp_num_timesteps_li = []\n",
    "rmp_frs = []\n",
    "rmp_dts = []\n",
    "# for num_timesteps in [7,8,9,10]:\n",
    "#     for num_attackers in [1,2,3]:\n",
    "#         for dt in [1,2]:\n",
    "#             for fr in [True,False]:\n",
    "#                 gsg = GreenSecurityGame(df, coordinate_rectangle, \"centroid\", num_clusters=10, num_rows=7, num_columns=7)\n",
    "#                 gsg.generate(num_attackers=num_attackers, num_defenders=1, home_base_assignments=[(kabo_djembe, bomassa, inner_post)], num_timesteps=num_timesteps, generate_utility_matrix=True, defense_time_threshold=dt, generate_actions=False, force_return=fr, general_sum=False, **schedule_form_kwargs)\n",
    "#                 D_d, U, gaps, interval_times = regret_matching(gsg.utility_matrix, runtime=120, interval=5, iterations=10000, averaging=0, alternations=False, plus=True, predictive=False, verbose=True)\n",
    "#                 rmp_num_attackers_li.append(num_attackers)\n",
    "#                 rmp_frs.append(fr)\n",
    "#                 rmp_dts.append(dt)\n",
    "#                 rmp_gaps_li.append(gaps)\n",
    "#                 rmp_interval_times_li.append(interval_times)\n",
    "#                 rmp_num_timesteps_li.append(num_timesteps)\n",
    "\n",
    "gsg = GreenSecurityGame(df, coordinate_rectangle, \"centroid\", num_clusters=10, num_rows=7, num_columns=7)\n",
    "gsg.generate(num_attackers=1, \n",
    "             num_defenders=1, \n",
    "             home_base_assignments=[(kabo_djembe, bomassa, inner_post)], \n",
    "             num_timesteps=8, \n",
    "             generate_utility_matrix=True, \n",
    "             random_target_values=True,\n",
    "             defense_time_threshold=1, \n",
    "             generate_actions=False, \n",
    "             force_return=False, \n",
    "             general_sum=False, \n",
    "             **schedule_form_kwargs)\n",
    "\n",
    "D_d, U, gaps, interval_times = regret_matching(gsg.utility_matrix, runtime=120, interval=5, iterations=10000, averaging=1, alternations=True, plus=True, predictive=False, verbose=True)\n",
    "rmp_num_attackers_li.append(1)\n",
    "rmp_frs.append(True)\n",
    "rmp_dts.append(1)\n",
    "rmp_gaps_li.append(gaps)\n",
    "rmp_interval_times_li.append(interval_times)\n",
    "rmp_num_timesteps_li.append(num_timesteps)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "id": "b16408af-cbce-45d8-bc9b-bc85b37f2f88",
   "metadata": {},
   "outputs": [],
   "source": [
    "rmp_num_timesteps_li = [8]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "id": "a1576fb5-41d4-46e7-a326-c36e15ffa610",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>num_timesteps</th>\n",
       "      <th>num_attackers</th>\n",
       "      <th>num_defenders</th>\n",
       "      <th>defense_time_threshold</th>\n",
       "      <th>force_return</th>\n",
       "      <th>interval_number</th>\n",
       "      <th>iteration_times</th>\n",
       "      <th>gaps</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>True</td>\n",
       "      <td>0</td>\n",
       "      <td>0.187397</td>\n",
       "      <td>0.179673</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>True</td>\n",
       "      <td>1</td>\n",
       "      <td>0.225407</td>\n",
       "      <td>0.116436</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>True</td>\n",
       "      <td>2</td>\n",
       "      <td>0.206293</td>\n",
       "      <td>0.074713</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>True</td>\n",
       "      <td>3</td>\n",
       "      <td>0.2045</td>\n",
       "      <td>0.055587</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>True</td>\n",
       "      <td>4</td>\n",
       "      <td>0.21508</td>\n",
       "      <td>0.044048</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>477</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>True</td>\n",
       "      <td>477</td>\n",
       "      <td>0.176974</td>\n",
       "      <td>0.000262</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>478</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>True</td>\n",
       "      <td>478</td>\n",
       "      <td>0.22726</td>\n",
       "      <td>0.000229</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>479</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>True</td>\n",
       "      <td>479</td>\n",
       "      <td>0.243986</td>\n",
       "      <td>0.000273</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>480</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>True</td>\n",
       "      <td>480</td>\n",
       "      <td>0.247086</td>\n",
       "      <td>0.000235</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>481</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>True</td>\n",
       "      <td>481</td>\n",
       "      <td>0.215559</td>\n",
       "      <td>0.000207</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>482 rows × 8 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "     num_timesteps  num_attackers  num_defenders  defense_time_threshold  \\\n",
       "0                8              1              1                       1   \n",
       "1                8              1              1                       1   \n",
       "2                8              1              1                       1   \n",
       "3                8              1              1                       1   \n",
       "4                8              1              1                       1   \n",
       "..             ...            ...            ...                     ...   \n",
       "477              8              1              1                       1   \n",
       "478              8              1              1                       1   \n",
       "479              8              1              1                       1   \n",
       "480              8              1              1                       1   \n",
       "481              8              1              1                       1   \n",
       "\n",
       "     force_return  interval_number iteration_times      gaps  \n",
       "0            True                0        0.187397  0.179673  \n",
       "1            True                1        0.225407  0.116436  \n",
       "2            True                2        0.206293  0.074713  \n",
       "3            True                3          0.2045  0.055587  \n",
       "4            True                4         0.21508  0.044048  \n",
       "..            ...              ...             ...       ...  \n",
       "477          True              477        0.176974  0.000262  \n",
       "478          True              478         0.22726  0.000229  \n",
       "479          True              479        0.243986  0.000273  \n",
       "480          True              480        0.247086  0.000235  \n",
       "481          True              481        0.215559  0.000207  \n",
       "\n",
       "[482 rows x 8 columns]"
      ]
     },
     "execution_count": 48,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df = pd.DataFrame({\n",
    "    \"num_timesteps\": rmp_num_timesteps_li,\n",
    "    \"num_attackers\": rmp_num_attackers_li,\n",
    "    \"num_defenders\": [1 for i in range(len(rmp_num_timesteps_li))],\n",
    "    \"defense_time_threshold\": rmp_dts,\n",
    "    \"force_return\": rmp_frs,\n",
    "    \"iteration_times\": rmp_interval_times_li,\n",
    "    \"gaps\": rmp_gaps_li\n",
    "})\n",
    "\n",
    "# Step 2: Explode list columns\n",
    "exploded_df = df.explode([\"iteration_times\", \"gaps\"], ignore_index=True)\n",
    "\n",
    "# Optional: Add a column for iteration number within each trial\n",
    "exploded_df[\"interval_number\"] = exploded_df.groupby([\"num_timesteps\",\"num_attackers\", \"force_return\",\"defense_time_threshold\"]).cumcount()\n",
    "\n",
    "# Reorder if desired\n",
    "cols = [\"num_timesteps\", \"num_attackers\", \"num_defenders\", \"defense_time_threshold\", \"force_return\", \"interval_number\", \"iteration_times\", \"gaps\"]\n",
    "exploded_df = exploded_df[cols]\n",
    "\n",
    "exploded_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "id": "f0c3c846-be2d-481d-8805-2075fc9fcc38",
   "metadata": {},
   "outputs": [],
   "source": [
    "exploded_df[\"interval_number\"] = exploded_df[\"interval_number\"]+1\n",
    "exploded_df[\"iteration_number\"] = exploded_df[\"interval_number\"]*5"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "id": "b7adec11-8b3f-495f-9190-ab1e1f0357c4",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>num_timesteps</th>\n",
       "      <th>num_attackers</th>\n",
       "      <th>num_defenders</th>\n",
       "      <th>defense_time_threshold</th>\n",
       "      <th>force_return</th>\n",
       "      <th>interval_number</th>\n",
       "      <th>iteration_times</th>\n",
       "      <th>gaps</th>\n",
       "      <th>iteration_number</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>True</td>\n",
       "      <td>1</td>\n",
       "      <td>0.187397</td>\n",
       "      <td>0.179673</td>\n",
       "      <td>5</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>True</td>\n",
       "      <td>2</td>\n",
       "      <td>0.225407</td>\n",
       "      <td>0.116436</td>\n",
       "      <td>10</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>True</td>\n",
       "      <td>3</td>\n",
       "      <td>0.206293</td>\n",
       "      <td>0.074713</td>\n",
       "      <td>15</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>True</td>\n",
       "      <td>4</td>\n",
       "      <td>0.2045</td>\n",
       "      <td>0.055587</td>\n",
       "      <td>20</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>True</td>\n",
       "      <td>5</td>\n",
       "      <td>0.21508</td>\n",
       "      <td>0.044048</td>\n",
       "      <td>25</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>477</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>True</td>\n",
       "      <td>478</td>\n",
       "      <td>0.176974</td>\n",
       "      <td>0.000262</td>\n",
       "      <td>2390</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>478</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>True</td>\n",
       "      <td>479</td>\n",
       "      <td>0.22726</td>\n",
       "      <td>0.000229</td>\n",
       "      <td>2395</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>479</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>True</td>\n",
       "      <td>480</td>\n",
       "      <td>0.243986</td>\n",
       "      <td>0.000273</td>\n",
       "      <td>2400</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>480</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>True</td>\n",
       "      <td>481</td>\n",
       "      <td>0.247086</td>\n",
       "      <td>0.000235</td>\n",
       "      <td>2405</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>481</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>True</td>\n",
       "      <td>482</td>\n",
       "      <td>0.215559</td>\n",
       "      <td>0.000207</td>\n",
       "      <td>2410</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>482 rows × 9 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "     num_timesteps  num_attackers  num_defenders  defense_time_threshold  \\\n",
       "0                8              1              1                       1   \n",
       "1                8              1              1                       1   \n",
       "2                8              1              1                       1   \n",
       "3                8              1              1                       1   \n",
       "4                8              1              1                       1   \n",
       "..             ...            ...            ...                     ...   \n",
       "477              8              1              1                       1   \n",
       "478              8              1              1                       1   \n",
       "479              8              1              1                       1   \n",
       "480              8              1              1                       1   \n",
       "481              8              1              1                       1   \n",
       "\n",
       "     force_return  interval_number iteration_times      gaps  iteration_number  \n",
       "0            True                1        0.187397  0.179673                 5  \n",
       "1            True                2        0.225407  0.116436                10  \n",
       "2            True                3        0.206293  0.074713                15  \n",
       "3            True                4          0.2045  0.055587                20  \n",
       "4            True                5         0.21508  0.044048                25  \n",
       "..            ...              ...             ...       ...               ...  \n",
       "477          True              478        0.176974  0.000262              2390  \n",
       "478          True              479         0.22726  0.000229              2395  \n",
       "479          True              480        0.243986  0.000273              2400  \n",
       "480          True              481        0.247086  0.000235              2405  \n",
       "481          True              482        0.215559  0.000207              2410  \n",
       "\n",
       "[482 rows x 9 columns]"
      ]
     },
     "execution_count": 50,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "exploded_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 51,
   "id": "217f45bf-519d-451a-851e-2ad04f5e3a14",
   "metadata": {},
   "outputs": [],
   "source": [
    "exploded_df.to_csv(\"GSG_NFG_NEW_RMP_FINAL_WITH_FR_DT.csv\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "9e067f8a-72d1-475a-a81e-a86cb2000e9d",
   "metadata": {},
   "source": [
    "## PRM+ (DONE)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3491a146-58b0-426b-aaa2-9d4f81088847",
   "metadata": {
    "jupyter": {
     "source_hidden": true
    },
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "df = pd.read_csv(\"lobeke.csv\")\n",
    "df.dropna(inplace=True)\n",
    "\n",
    "# Lobeke National Park Bounding Box\n",
    "# lat_min, lon_min = 2.05522, 15.8790\n",
    "# lat_max, lon_max = 2.2837, 16.2038\n",
    "\n",
    "lat_min, lon_min = 2.0530, 15.8790\n",
    "lat_max, lon_max = 2.2837, 16.2038\n",
    "\n",
    "coordinate_rectangle = [lat_min, lat_max, lon_min, lon_max]\n",
    "\n",
    "schedule_form_kwargs = {\n",
    "    \"schedule_form\": False,\n",
    "    \"simple\": True,\n",
    "    \"attacker_penalty_factor\": 3,\n",
    "    \"defender_penalty_factor\": 3,\n",
    "    \"extra_coverage_weight\":0.9\n",
    "}\n",
    "\n",
    "general_sum_kwargs = {\n",
    "    \"general_sum\": False,\n",
    "    \"attacker_feature_value\":  42, \n",
    "    \"defender_feature_value\": 69, \n",
    "    \"defender_step_cost\": 32.5, \n",
    "}\n",
    "\n",
    "boulou_camp = (2.2,15.9)\n",
    "# lobeke_camp = (2.25,15.75)\n",
    "kabo_djembe = (2.0532352380408088, 16.085709866529694)\n",
    "bomassa = (2.2037280296158355, 16.187056364164913)\n",
    "inner_post = (2.2,15.98)\n",
    "\n",
    "prmp_num_attackers_li = []\n",
    "\n",
    "prmp_gaps_li = []\n",
    "prmp_interval_times_li = []\n",
    "prmp_num_timesteps_li = []\n",
    "prmp_frs = []\n",
    "prmp_dts = []\n",
    "\n",
    "for num_timesteps in [7,8,9,10]:\n",
    "    for num_attackers in [1,2,3]:\n",
    "        for dt in [1,2]:\n",
    "            for fr in [True,False]:\n",
    "                gsg = GreenSecurityGame(df, coordinate_rectangle, \"centroid\", num_clusters=10, num_rows=7, num_columns=7)\n",
    "                gsg.generate(num_attackers=num_attackers, num_defenders=1, home_base_assignments=[(kabo_djembe, bomassa, inner_post)], num_timesteps=num_timesteps, generate_utility_matrix=True, defense_time_threshold=dt, generate_actions=False, force_return=fr, general_sum=False, **schedule_form_kwargs)\n",
    "                D_d, U, gaps, interval_times = regret_matching(gsg.utility_matrix, runtime=120, interval=5, iterations=10000, averaging=2, alternations=True, plus=True, predictive=True, verbose=True)\n",
    "                prmp_num_attackers_li.append(num_attackers)\n",
    "                prmp_frs.append(fr)\n",
    "                prmp_dts.append(dt)\n",
    "                prmp_gaps_li.append(gaps)\n",
    "                prmp_interval_times_li.append(interval_times)\n",
    "                prmp_num_timesteps_li.append(num_timesteps)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2b7f4f48-b4f6-4d6e-a0f0-d62f40664db0",
   "metadata": {
    "jupyter": {
     "source_hidden": true
    }
   },
   "outputs": [],
   "source": [
    "df = pd.DataFrame({\n",
    "    \"num_timesteps\": prmp_num_timesteps_li,\n",
    "    \"num_attackers\": prmp_num_attackers_li,\n",
    "    \"num_defenders\": [1 for i in range(len(prmp_num_timesteps_li))],\n",
    "    \"defense_time_threshold\": prmp_dts,\n",
    "    \"force_return\": prmp_frs,\n",
    "    \"iteration_times\": prmp_interval_times_li,\n",
    "    \"gaps\": prmp_gaps_li\n",
    "})\n",
    "\n",
    "# Step 2: Explode list columns\n",
    "exploded_df = df.explode([\"iteration_times\", \"gaps\"], ignore_index=True)\n",
    "\n",
    "# Optional: Add a column for iteration number within each trial\n",
    "exploded_df[\"interval_number\"] = exploded_df.groupby([\"num_timesteps\",\"num_attackers\", \"force_return\",\"defense_time_threshold\"]).cumcount()\n",
    "\n",
    "# Reorder if desired\n",
    "cols = [\"num_timesteps\", \"num_attackers\", \"num_defenders\", \"defense_time_threshold\", \"force_return\", \"interval_number\", \"iteration_times\", \"gaps\"]\n",
    "exploded_df = exploded_df[cols]\n",
    "\n",
    "exploded_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "33ebdd1c-4fe6-462c-a1b0-adcadae536dd",
   "metadata": {
    "jupyter": {
     "source_hidden": true
    }
   },
   "outputs": [],
   "source": [
    "exploded_df[\"interval_number\"] = exploded_df[\"interval_number\"]+1\n",
    "exploded_df[\"iteration_number\"] = exploded_df[\"interval_number\"]*5"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "df300af9-d60b-4b8c-a49e-0955b40a39f8",
   "metadata": {
    "jupyter": {
     "source_hidden": true
    },
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "exploded_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2b7bc0e3-c678-43c0-a9f2-743a32a37df5",
   "metadata": {},
   "outputs": [],
   "source": [
    "exploded_df.to_csv(\"GSG_NFG_PRMP_FINAL_WITH_FR_DT.csv\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "96aa0eee-f49e-4290-aed7-3d97cefdf25c",
   "metadata": {},
   "source": [
    "# GSG DO SF (DONE)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cbf43da5-2837-44ff-9cff-f871407cfbdb",
   "metadata": {},
   "outputs": [],
   "source": [
    "df = pd.read_csv(\"lobeke.csv\")\n",
    "df.dropna(inplace=True)\n",
    "\n",
    "# Lobeke National Park Bounding Box\n",
    "# lat_min, lon_min = 2.05522, 15.8790\n",
    "# lat_max, lon_max = 2.2837, 16.2038\n",
    "\n",
    "lat_min, lon_min = 2.0530, 15.8790\n",
    "lat_max, lon_max = 2.2837, 16.2038\n",
    "\n",
    "coordinate_rectangle = [lat_min, lat_max, lon_min, lon_max]\n",
    "\n",
    "schedule_form_kwargs = {\n",
    "    \"schedule_form\": True,\n",
    "    \"simple\": False,\n",
    "    \"attacker_penalty_factor\": 5, #from real source\n",
    "    \"defender_penalty_factor\": 5,\n",
    "    \"extra_coverage_weight\":0.1\n",
    "}\n",
    "\n",
    "general_sum_kwargs = {\n",
    "    \"general_sum\": False,\n",
    "    \"attacker_feature_value\":  42, \n",
    "    \"defender_feature_value\": 69, \n",
    "    \"defender_step_cost\": 32.5, \n",
    "}\n",
    "\n",
    "boulou_camp = (2.2,15.9)\n",
    "# lobeke_camp = (2.25,15.75)\n",
    "kabo_djembe = (2.0532352380408088, 16.085709866529694)\n",
    "bomassa = (2.2037280296158355, 16.187056364164913)\n",
    "inner_post = (2.2,15.98)\n",
    "\n",
    "gsg = GreenSecurityGame(df, coordinate_rectangle, \"centroid\", num_clusters=10, num_rows=7, num_columns=7)\n",
    "gsg.generate(num_attackers=2, num_defenders=1, home_base_assignments=[(kabo_djembe, bomassa, inner_post)], num_timesteps=7, generate_utility_matrix=True, defense_time_threshold=1, generate_actions=False, force_return=False, general_sum=False, **schedule_form_kwargs)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "15d6f3df-1a5b-4381-abee-8d74f7f2b304",
   "metadata": {},
   "outputs": [],
   "source": [
    "df = pd.read_csv(\"lobeke.csv\")\n",
    "df.dropna(inplace=True)\n",
    "\n",
    "# Lobeke National Park Bounding Box\n",
    "# lat_min, lon_min = 2.05522, 15.8790\n",
    "# lat_max, lon_max = 2.2837, 16.2038\n",
    "\n",
    "lat_min, lon_min = 2.0530, 15.8790\n",
    "lat_max, lon_max = 2.2837, 16.2038\n",
    "\n",
    "coordinate_rectangle = [lat_min, lat_max, lon_min, lon_max]\n",
    "\n",
    "schedule_form_kwargs = {\n",
    "    \"schedule_form\": True,\n",
    "    \"simple\": False,\n",
    "    \"attacker_penalty_factor\": 100,\n",
    "    \"defender_penalty_factor\": 100,\n",
    "    \"extra_coverage_weight\":1\n",
    "}\n",
    "\n",
    "general_sum_kwargs = {\n",
    "    \"general_sum\": False,\n",
    "    \"attacker_feature_value\":  42, \n",
    "    \"defender_feature_value\": 69, \n",
    "    \"defender_step_cost\": 32.5, \n",
    "}\n",
    "\n",
    "boulou_camp = (2.2,15.9)\n",
    "# lobeke_camp = (2.25,15.75)\n",
    "kabo_djembe = (2.0532352380408088, 16.085709866529694)\n",
    "bomassa = (2.2037280296158355, 16.187056364164913)\n",
    "inner_post = (2.2,15.98)\n",
    "\n",
    "num_timesteps_li = []\n",
    "supports=[]\n",
    "defender_actions_sizes = []\n",
    "attacker_actions_sizes = []\n",
    "iterations_to_converge = []\n",
    "iteration_times_li = []\n",
    "gaps_li = []\n",
    "\n",
    "for num_timesteps in [6,7,8,9,10]:\n",
    "    print(num_timesteps)\n",
    "    num_timesteps_li.append(num_timesteps)\n",
    "    gsg = GreenSecurityGame(df, coordinate_rectangle, \"centroid\", num_clusters=10, num_rows=7, num_columns=7)\n",
    "    gsg.generate(num_attackers=2, num_defenders=1, home_base_assignments=[(kabo_djembe, bomassa, inner_post)], num_timesteps=num_timesteps, generate_utility_matrix=False, defense_time_threshold=1, generate_actions=False, force_return=False, general_sum=False, **schedule_form_kwargs)\n",
    "    D_a, D_d, u, A_a, A_d, c, its, gs = double_oracle_sf(gsg.schedule_form_dict, eps=1e-12, verbose=False)\n",
    "    support = sum([1 for p in D_d if p!=0])\n",
    "    supports.append(support)\n",
    "    iterations_to_converge.append(c)\n",
    "    iteration_times_li.append(its)\n",
    "    gaps_li.append(gs)\n",
    "    defender_actions_sizes.append(len(A_d))\n",
    "    attacker_actions_sizes.append(len(A_a))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7f276ea3-2bed-4261-91ca-5c7ff3d305cd",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "supports"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c21ba7d4-0e59-4c8a-9178-d71327b27331",
   "metadata": {},
   "outputs": [],
   "source": [
    "gsg = GreenSecurityGame(df, coordinate_rectangle, \"centroid\", num_clusters=10, num_rows=7, num_columns=7)\n",
    "gsg.generate(num_attackers=2, num_defenders=1, home_base_assignments=[(kabo_djembe, bomassa, inner_post)], num_timesteps=10, generate_utility_matrix=False, defense_time_threshold=1, generate_actions=False, force_return=True, general_sum=False, **schedule_form_kwargs)\n",
    "D_a, D_d, u, A_a, A_d, c, its, gs = double_oracle_sf(gsg.schedule_form_dict, eps=1e-12, verbose=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "07b4b514-887f-4913-ad1e-59b19c24a21f",
   "metadata": {
    "jupyter": {
     "source_hidden": true
    },
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "gsg.draw_graph()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "749a8672-80ff-43c9-935c-fd3d4beace22",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Set parameter WLSAccessID\n",
      "Set parameter WLSSecret\n",
      "Set parameter LicenseID to value 2455389\n",
      "Academic license 2455389 - for non-commercial use only - registered to jc___@columbia.edu\n",
      "0/575: timesteps:7, num_defenders:1, num_clusters:7, dims:7, dt:1, support:2\n",
      "1/575: timesteps:7, num_defenders:1, num_clusters:7, dims:7, dt:2, support:2\n",
      "2/575: timesteps:7, num_defenders:1, num_clusters:7, dims:8, dt:1, support:2\n",
      "3/575: timesteps:7, num_defenders:1, num_clusters:7, dims:8, dt:2, support:1\n",
      "4/575: timesteps:7, num_defenders:1, num_clusters:7, dims:9, dt:1, support:2\n",
      "5/575: timesteps:7, num_defenders:1, num_clusters:7, dims:9, dt:2, support:1\n",
      "6/575: timesteps:7, num_defenders:1, num_clusters:7, dims:10, dt:1, support:2\n",
      "7/575: timesteps:7, num_defenders:1, num_clusters:7, dims:10, dt:2, support:1\n",
      "8/575: timesteps:7, num_defenders:1, num_clusters:8, dims:7, dt:1, support:2\n",
      "9/575: timesteps:7, num_defenders:1, num_clusters:8, dims:7, dt:2, support:2\n",
      "10/575: timesteps:7, num_defenders:1, num_clusters:8, dims:8, dt:1, support:2\n",
      "11/575: timesteps:7, num_defenders:1, num_clusters:8, dims:8, dt:2, support:1\n",
      "12/575: timesteps:7, num_defenders:1, num_clusters:8, dims:9, dt:1, support:2\n",
      "13/575: timesteps:7, num_defenders:1, num_clusters:8, dims:9, dt:2, support:1\n",
      "14/575: timesteps:7, num_defenders:1, num_clusters:8, dims:10, dt:1, support:2\n",
      "15/575: timesteps:7, num_defenders:1, num_clusters:8, dims:10, dt:2, support:1\n",
      "16/575: timesteps:7, num_defenders:1, num_clusters:9, dims:7, dt:1, support:2\n",
      "17/575: timesteps:7, num_defenders:1, num_clusters:9, dims:7, dt:2, support:2\n",
      "18/575: timesteps:7, num_defenders:1, num_clusters:9, dims:8, dt:1, support:2\n",
      "19/575: timesteps:7, num_defenders:1, num_clusters:9, dims:8, dt:2, support:1\n",
      "20/575: timesteps:7, num_defenders:1, num_clusters:9, dims:9, dt:1, support:2\n",
      "21/575: timesteps:7, num_defenders:1, num_clusters:9, dims:9, dt:2, support:1\n",
      "22/575: timesteps:7, num_defenders:1, num_clusters:9, dims:10, dt:1, support:2\n",
      "23/575: timesteps:7, num_defenders:1, num_clusters:9, dims:10, dt:2, support:1\n",
      "24/575: timesteps:7, num_defenders:1, num_clusters:10, dims:7, dt:1, support:2\n",
      "25/575: timesteps:7, num_defenders:1, num_clusters:10, dims:7, dt:2, support:1\n",
      "26/575: timesteps:7, num_defenders:1, num_clusters:10, dims:8, dt:1, support:2\n",
      "27/575: timesteps:7, num_defenders:1, num_clusters:10, dims:8, dt:2, support:1\n",
      "28/575: timesteps:7, num_defenders:1, num_clusters:10, dims:9, dt:1, support:2\n",
      "29/575: timesteps:7, num_defenders:1, num_clusters:10, dims:9, dt:2, support:1\n",
      "30/575: timesteps:7, num_defenders:1, num_clusters:10, dims:10, dt:1, support:2\n",
      "31/575: timesteps:7, num_defenders:1, num_clusters:10, dims:10, dt:2, support:1\n",
      "32/575: timesteps:7, num_defenders:1, num_clusters:11, dims:7, dt:1, support:2\n",
      "33/575: timesteps:7, num_defenders:1, num_clusters:11, dims:7, dt:2, support:2\n",
      "34/575: timesteps:7, num_defenders:1, num_clusters:11, dims:8, dt:1, support:2\n",
      "35/575: timesteps:7, num_defenders:1, num_clusters:11, dims:8, dt:2, support:1\n",
      "36/575: timesteps:7, num_defenders:1, num_clusters:11, dims:9, dt:1, support:2\n",
      "37/575: timesteps:7, num_defenders:1, num_clusters:11, dims:9, dt:2, support:1\n",
      "38/575: timesteps:7, num_defenders:1, num_clusters:11, dims:10, dt:1, support:3\n",
      "39/575: timesteps:7, num_defenders:1, num_clusters:11, dims:10, dt:2, support:1\n",
      "40/575: timesteps:7, num_defenders:1, num_clusters:12, dims:7, dt:1, support:2\n",
      "41/575: timesteps:7, num_defenders:1, num_clusters:12, dims:7, dt:2, support:2\n",
      "42/575: timesteps:7, num_defenders:1, num_clusters:12, dims:8, dt:1, support:2\n",
      "43/575: timesteps:7, num_defenders:1, num_clusters:12, dims:8, dt:2, support:1\n",
      "44/575: timesteps:7, num_defenders:1, num_clusters:12, dims:9, dt:1, support:2\n",
      "45/575: timesteps:7, num_defenders:1, num_clusters:12, dims:9, dt:2, support:1\n",
      "46/575: timesteps:7, num_defenders:1, num_clusters:12, dims:10, dt:1, support:3\n",
      "47/575: timesteps:7, num_defenders:1, num_clusters:12, dims:10, dt:2, support:1\n",
      "48/575: timesteps:7, num_defenders:2, num_clusters:7, dims:7, dt:1, support:5\n",
      "49/575: timesteps:7, num_defenders:2, num_clusters:7, dims:7, dt:2, support:4\n",
      "50/575: timesteps:7, num_defenders:2, num_clusters:7, dims:8, dt:1, support:4\n",
      "51/575: timesteps:7, num_defenders:2, num_clusters:7, dims:8, dt:2, support:1\n",
      "52/575: timesteps:7, num_defenders:2, num_clusters:7, dims:9, dt:1, support:4\n",
      "53/575: timesteps:7, num_defenders:2, num_clusters:7, dims:9, dt:2, support:1\n",
      "54/575: timesteps:7, num_defenders:2, num_clusters:7, dims:10, dt:1, support:5\n",
      "55/575: timesteps:7, num_defenders:2, num_clusters:7, dims:10, dt:2, support:1\n",
      "56/575: timesteps:7, num_defenders:2, num_clusters:8, dims:7, dt:1, support:6\n",
      "57/575: timesteps:7, num_defenders:2, num_clusters:8, dims:7, dt:2, support:5\n",
      "58/575: timesteps:7, num_defenders:2, num_clusters:8, dims:8, dt:1, support:5\n",
      "59/575: timesteps:7, num_defenders:2, num_clusters:8, dims:8, dt:2, support:1\n",
      "60/575: timesteps:7, num_defenders:2, num_clusters:8, dims:9, dt:1, support:1\n",
      "61/575: timesteps:7, num_defenders:2, num_clusters:8, dims:9, dt:2, support:1\n",
      "62/575: timesteps:7, num_defenders:2, num_clusters:8, dims:10, dt:1, support:5\n",
      "63/575: timesteps:7, num_defenders:2, num_clusters:8, dims:10, dt:2, support:1\n",
      "64/575: timesteps:7, num_defenders:2, num_clusters:9, dims:7, dt:1, support:6\n",
      "65/575: timesteps:7, num_defenders:2, num_clusters:9, dims:7, dt:2, support:4\n",
      "66/575: timesteps:7, num_defenders:2, num_clusters:9, dims:8, dt:1, support:5\n",
      "67/575: timesteps:7, num_defenders:2, num_clusters:9, dims:8, dt:2, support:1\n",
      "68/575: timesteps:7, num_defenders:2, num_clusters:9, dims:9, dt:1, support:1\n",
      "69/575: timesteps:7, num_defenders:2, num_clusters:9, dims:9, dt:2, support:1\n",
      "70/575: timesteps:7, num_defenders:2, num_clusters:9, dims:10, dt:1, support:5\n",
      "71/575: timesteps:7, num_defenders:2, num_clusters:9, dims:10, dt:2, support:1\n",
      "72/575: timesteps:7, num_defenders:2, num_clusters:10, dims:7, dt:1, support:6\n",
      "73/575: timesteps:7, num_defenders:2, num_clusters:10, dims:7, dt:2, support:1\n",
      "74/575: timesteps:7, num_defenders:2, num_clusters:10, dims:8, dt:1, support:5\n",
      "75/575: timesteps:7, num_defenders:2, num_clusters:10, dims:8, dt:2, support:1\n",
      "76/575: timesteps:7, num_defenders:2, num_clusters:10, dims:9, dt:1, support:1\n",
      "77/575: timesteps:7, num_defenders:2, num_clusters:10, dims:9, dt:2, support:1\n",
      "78/575: timesteps:7, num_defenders:2, num_clusters:10, dims:10, dt:1, support:5\n",
      "79/575: timesteps:7, num_defenders:2, num_clusters:10, dims:10, dt:2, support:1\n",
      "80/575: timesteps:7, num_defenders:2, num_clusters:11, dims:7, dt:1, support:6\n",
      "81/575: timesteps:7, num_defenders:2, num_clusters:11, dims:7, dt:2, support:6\n",
      "82/575: timesteps:7, num_defenders:2, num_clusters:11, dims:8, dt:1, support:5\n",
      "83/575: timesteps:7, num_defenders:2, num_clusters:11, dims:8, dt:2, support:1\n",
      "84/575: timesteps:7, num_defenders:2, num_clusters:11, dims:9, dt:1, support:5\n",
      "85/575: timesteps:7, num_defenders:2, num_clusters:11, dims:9, dt:2, support:1\n",
      "86/575: timesteps:7, num_defenders:2, num_clusters:11, dims:10, dt:1, support:5\n",
      "87/575: timesteps:7, num_defenders:2, num_clusters:11, dims:10, dt:2, support:1\n",
      "88/575: timesteps:7, num_defenders:2, num_clusters:12, dims:7, dt:1, support:7\n",
      "89/575: timesteps:7, num_defenders:2, num_clusters:12, dims:7, dt:2, support:4\n",
      "90/575: timesteps:7, num_defenders:2, num_clusters:12, dims:8, dt:1, support:7\n",
      "91/575: timesteps:7, num_defenders:2, num_clusters:12, dims:8, dt:2, support:1\n",
      "92/575: timesteps:7, num_defenders:2, num_clusters:12, dims:9, dt:1, support:4\n",
      "93/575: timesteps:7, num_defenders:2, num_clusters:12, dims:9, dt:2, support:1\n",
      "94/575: timesteps:7, num_defenders:2, num_clusters:12, dims:10, dt:1, support:4\n",
      "95/575: timesteps:7, num_defenders:2, num_clusters:12, dims:10, dt:2, support:1\n",
      "96/575: timesteps:7, num_defenders:3, num_clusters:7, dims:7, dt:1, support:6\n",
      "97/575: timesteps:7, num_defenders:3, num_clusters:7, dims:7, dt:2, support:4\n",
      "98/575: timesteps:7, num_defenders:3, num_clusters:7, dims:8, dt:1, support:5\n",
      "99/575: timesteps:7, num_defenders:3, num_clusters:7, dims:8, dt:2, support:1\n",
      "100/575: timesteps:7, num_defenders:3, num_clusters:7, dims:9, dt:1, support:5\n",
      "101/575: timesteps:7, num_defenders:3, num_clusters:7, dims:9, dt:2, support:1\n",
      "102/575: timesteps:7, num_defenders:3, num_clusters:7, dims:10, dt:1, support:5\n",
      "103/575: timesteps:7, num_defenders:3, num_clusters:7, dims:10, dt:2, support:1\n",
      "104/575: timesteps:7, num_defenders:3, num_clusters:8, dims:7, dt:1, support:5\n",
      "105/575: timesteps:7, num_defenders:3, num_clusters:8, dims:7, dt:2, support:5\n",
      "106/575: timesteps:7, num_defenders:3, num_clusters:8, dims:8, dt:1, support:6\n",
      "107/575: timesteps:7, num_defenders:3, num_clusters:8, dims:8, dt:2, support:1\n",
      "108/575: timesteps:7, num_defenders:3, num_clusters:8, dims:9, dt:1, support:1\n",
      "109/575: timesteps:7, num_defenders:3, num_clusters:8, dims:9, dt:2, support:1\n",
      "110/575: timesteps:7, num_defenders:3, num_clusters:8, dims:10, dt:1, support:6\n",
      "111/575: timesteps:7, num_defenders:3, num_clusters:8, dims:10, dt:2, support:1\n",
      "112/575: timesteps:7, num_defenders:3, num_clusters:9, dims:7, dt:1, support:5\n",
      "113/575: timesteps:7, num_defenders:3, num_clusters:9, dims:7, dt:2, support:5\n",
      "114/575: timesteps:7, num_defenders:3, num_clusters:9, dims:8, dt:1, support:5\n",
      "115/575: timesteps:7, num_defenders:3, num_clusters:9, dims:8, dt:2, support:1\n",
      "116/575: timesteps:7, num_defenders:3, num_clusters:9, dims:9, dt:1, support:1\n",
      "117/575: timesteps:7, num_defenders:3, num_clusters:9, dims:9, dt:2, support:1\n",
      "118/575: timesteps:7, num_defenders:3, num_clusters:9, dims:10, dt:1, support:7\n",
      "119/575: timesteps:7, num_defenders:3, num_clusters:9, dims:10, dt:2, support:1\n",
      "120/575: timesteps:7, num_defenders:3, num_clusters:10, dims:7, dt:1, support:7\n",
      "121/575: timesteps:7, num_defenders:3, num_clusters:10, dims:7, dt:2, support:1\n",
      "122/575: timesteps:7, num_defenders:3, num_clusters:10, dims:8, dt:1, support:6\n",
      "123/575: timesteps:7, num_defenders:3, num_clusters:10, dims:8, dt:2, support:1\n",
      "124/575: timesteps:7, num_defenders:3, num_clusters:10, dims:9, dt:1, support:1\n",
      "125/575: timesteps:7, num_defenders:3, num_clusters:10, dims:9, dt:2, support:1\n",
      "126/575: timesteps:7, num_defenders:3, num_clusters:10, dims:10, dt:1, support:6\n",
      "127/575: timesteps:7, num_defenders:3, num_clusters:10, dims:10, dt:2, support:1\n",
      "128/575: timesteps:7, num_defenders:3, num_clusters:11, dims:7, dt:1, support:6\n",
      "129/575: timesteps:7, num_defenders:3, num_clusters:11, dims:7, dt:2, support:5\n",
      "130/575: timesteps:7, num_defenders:3, num_clusters:11, dims:8, dt:1, support:5\n",
      "131/575: timesteps:7, num_defenders:3, num_clusters:11, dims:8, dt:2, support:1\n",
      "132/575: timesteps:7, num_defenders:3, num_clusters:11, dims:9, dt:1, support:6\n",
      "133/575: timesteps:7, num_defenders:3, num_clusters:11, dims:9, dt:2, support:1\n",
      "134/575: timesteps:7, num_defenders:3, num_clusters:11, dims:10, dt:1, support:5\n",
      "135/575: timesteps:7, num_defenders:3, num_clusters:11, dims:10, dt:2, support:1\n",
      "136/575: timesteps:7, num_defenders:3, num_clusters:12, dims:7, dt:1, support:6\n",
      "137/575: timesteps:7, num_defenders:3, num_clusters:12, dims:7, dt:2, support:4\n",
      "138/575: timesteps:7, num_defenders:3, num_clusters:12, dims:8, dt:1, support:8\n",
      "139/575: timesteps:7, num_defenders:3, num_clusters:12, dims:8, dt:2, support:1\n",
      "140/575: timesteps:7, num_defenders:3, num_clusters:12, dims:9, dt:1, support:5\n",
      "141/575: timesteps:7, num_defenders:3, num_clusters:12, dims:9, dt:2, support:1\n",
      "142/575: timesteps:7, num_defenders:3, num_clusters:12, dims:10, dt:1, support:4\n",
      "143/575: timesteps:7, num_defenders:3, num_clusters:12, dims:10, dt:2, support:1\n",
      "144/575: timesteps:8, num_defenders:1, num_clusters:7, dims:7, dt:1, support:2\n",
      "145/575: timesteps:8, num_defenders:1, num_clusters:7, dims:7, dt:2, support:2\n",
      "146/575: timesteps:8, num_defenders:1, num_clusters:7, dims:8, dt:1, support:2\n",
      "147/575: timesteps:8, num_defenders:1, num_clusters:7, dims:8, dt:2, support:2\n",
      "148/575: timesteps:8, num_defenders:1, num_clusters:7, dims:9, dt:1, support:2\n",
      "149/575: timesteps:8, num_defenders:1, num_clusters:7, dims:9, dt:2, support:2\n",
      "150/575: timesteps:8, num_defenders:1, num_clusters:7, dims:10, dt:1, support:2\n",
      "151/575: timesteps:8, num_defenders:1, num_clusters:7, dims:10, dt:2, support:2\n",
      "152/575: timesteps:8, num_defenders:1, num_clusters:8, dims:7, dt:1, support:2\n",
      "153/575: timesteps:8, num_defenders:1, num_clusters:8, dims:7, dt:2, support:2\n",
      "154/575: timesteps:8, num_defenders:1, num_clusters:8, dims:8, dt:1, support:2\n",
      "155/575: timesteps:8, num_defenders:1, num_clusters:8, dims:8, dt:2, support:2\n",
      "156/575: timesteps:8, num_defenders:1, num_clusters:8, dims:9, dt:1, support:2\n",
      "157/575: timesteps:8, num_defenders:1, num_clusters:8, dims:9, dt:2, support:2\n",
      "158/575: timesteps:8, num_defenders:1, num_clusters:8, dims:10, dt:1, support:2\n",
      "159/575: timesteps:8, num_defenders:1, num_clusters:8, dims:10, dt:2, support:2\n",
      "160/575: timesteps:8, num_defenders:1, num_clusters:9, dims:7, dt:1, support:2\n",
      "161/575: timesteps:8, num_defenders:1, num_clusters:9, dims:7, dt:2, support:2\n",
      "162/575: timesteps:8, num_defenders:1, num_clusters:9, dims:8, dt:1, support:2\n",
      "163/575: timesteps:8, num_defenders:1, num_clusters:9, dims:8, dt:2, support:2\n",
      "164/575: timesteps:8, num_defenders:1, num_clusters:9, dims:9, dt:1, support:2\n",
      "165/575: timesteps:8, num_defenders:1, num_clusters:9, dims:9, dt:2, support:2\n",
      "166/575: timesteps:8, num_defenders:1, num_clusters:9, dims:10, dt:1, support:2\n",
      "167/575: timesteps:8, num_defenders:1, num_clusters:9, dims:10, dt:2, support:2\n",
      "168/575: timesteps:8, num_defenders:1, num_clusters:10, dims:7, dt:1, support:2\n",
      "169/575: timesteps:8, num_defenders:1, num_clusters:10, dims:7, dt:2, support:4\n",
      "170/575: timesteps:8, num_defenders:1, num_clusters:10, dims:8, dt:1, support:2\n",
      "171/575: timesteps:8, num_defenders:1, num_clusters:10, dims:8, dt:2, support:4\n",
      "172/575: timesteps:8, num_defenders:1, num_clusters:10, dims:9, dt:1, support:2\n",
      "173/575: timesteps:8, num_defenders:1, num_clusters:10, dims:9, dt:2, support:2\n",
      "174/575: timesteps:8, num_defenders:1, num_clusters:10, dims:10, dt:1, support:2\n",
      "175/575: timesteps:8, num_defenders:1, num_clusters:10, dims:10, dt:2, support:4\n",
      "176/575: timesteps:8, num_defenders:1, num_clusters:11, dims:7, dt:1, support:2\n",
      "177/575: timesteps:8, num_defenders:1, num_clusters:11, dims:7, dt:2, support:2\n",
      "178/575: timesteps:8, num_defenders:1, num_clusters:11, dims:8, dt:1, support:2\n",
      "179/575: timesteps:8, num_defenders:1, num_clusters:11, dims:8, dt:2, support:3\n",
      "180/575: timesteps:8, num_defenders:1, num_clusters:11, dims:9, dt:1, support:2\n",
      "181/575: timesteps:8, num_defenders:1, num_clusters:11, dims:9, dt:2, support:3\n",
      "182/575: timesteps:8, num_defenders:1, num_clusters:11, dims:10, dt:1, support:2\n",
      "183/575: timesteps:8, num_defenders:1, num_clusters:11, dims:10, dt:2, support:3\n",
      "184/575: timesteps:8, num_defenders:1, num_clusters:12, dims:7, dt:1, support:2\n",
      "185/575: timesteps:8, num_defenders:1, num_clusters:12, dims:7, dt:2, support:2\n",
      "186/575: timesteps:8, num_defenders:1, num_clusters:12, dims:8, dt:1, support:2\n",
      "187/575: timesteps:8, num_defenders:1, num_clusters:12, dims:8, dt:2, support:3\n",
      "188/575: timesteps:8, num_defenders:1, num_clusters:12, dims:9, dt:1, support:2\n",
      "189/575: timesteps:8, num_defenders:1, num_clusters:12, dims:9, dt:2, support:3\n",
      "190/575: timesteps:8, num_defenders:1, num_clusters:12, dims:10, dt:1, support:2\n",
      "191/575: timesteps:8, num_defenders:1, num_clusters:12, dims:10, dt:2, support:3\n",
      "192/575: timesteps:8, num_defenders:2, num_clusters:7, dims:7, dt:1, support:3\n",
      "193/575: timesteps:8, num_defenders:2, num_clusters:7, dims:7, dt:2, support:5\n",
      "194/575: timesteps:8, num_defenders:2, num_clusters:7, dims:8, dt:1, support:4\n",
      "195/575: timesteps:8, num_defenders:2, num_clusters:7, dims:8, dt:2, support:4\n",
      "196/575: timesteps:8, num_defenders:2, num_clusters:7, dims:9, dt:1, support:4\n",
      "197/575: timesteps:8, num_defenders:2, num_clusters:7, dims:9, dt:2, support:4\n",
      "198/575: timesteps:8, num_defenders:2, num_clusters:7, dims:10, dt:1, support:4\n",
      "199/575: timesteps:8, num_defenders:2, num_clusters:7, dims:10, dt:2, support:5\n",
      "200/575: timesteps:8, num_defenders:2, num_clusters:8, dims:7, dt:1, support:4\n",
      "201/575: timesteps:8, num_defenders:2, num_clusters:8, dims:7, dt:2, support:6\n",
      "202/575: timesteps:8, num_defenders:2, num_clusters:8, dims:8, dt:1, support:6\n",
      "203/575: timesteps:8, num_defenders:2, num_clusters:8, dims:8, dt:2, support:5\n",
      "204/575: timesteps:8, num_defenders:2, num_clusters:8, dims:9, dt:1, support:1\n",
      "205/575: timesteps:8, num_defenders:2, num_clusters:8, dims:9, dt:2, support:1\n",
      "206/575: timesteps:8, num_defenders:2, num_clusters:8, dims:10, dt:1, support:6\n",
      "207/575: timesteps:8, num_defenders:2, num_clusters:8, dims:10, dt:2, support:5\n",
      "208/575: timesteps:8, num_defenders:2, num_clusters:9, dims:7, dt:1, support:5\n",
      "209/575: timesteps:8, num_defenders:2, num_clusters:9, dims:7, dt:2, support:7\n",
      "210/575: timesteps:8, num_defenders:2, num_clusters:9, dims:8, dt:1, support:7\n",
      "211/575: timesteps:8, num_defenders:2, num_clusters:9, dims:8, dt:2, support:5\n",
      "212/575: timesteps:8, num_defenders:2, num_clusters:9, dims:9, dt:1, support:1\n",
      "213/575: timesteps:8, num_defenders:2, num_clusters:9, dims:9, dt:2, support:1\n",
      "214/575: timesteps:8, num_defenders:2, num_clusters:9, dims:10, dt:1, support:6\n",
      "215/575: timesteps:8, num_defenders:2, num_clusters:9, dims:10, dt:2, support:5\n",
      "216/575: timesteps:8, num_defenders:2, num_clusters:10, dims:7, dt:1, support:7\n",
      "217/575: timesteps:8, num_defenders:2, num_clusters:10, dims:7, dt:2, support:7\n",
      "218/575: timesteps:8, num_defenders:2, num_clusters:10, dims:8, dt:1, support:5\n",
      "219/575: timesteps:8, num_defenders:2, num_clusters:10, dims:8, dt:2, support:5\n",
      "220/575: timesteps:8, num_defenders:2, num_clusters:10, dims:9, dt:1, support:1\n",
      "221/575: timesteps:8, num_defenders:2, num_clusters:10, dims:9, dt:2, support:1\n",
      "222/575: timesteps:8, num_defenders:2, num_clusters:10, dims:10, dt:1, support:7\n",
      "223/575: timesteps:8, num_defenders:2, num_clusters:10, dims:10, dt:2, support:6\n",
      "224/575: timesteps:8, num_defenders:2, num_clusters:11, dims:7, dt:1, support:7\n",
      "225/575: timesteps:8, num_defenders:2, num_clusters:11, dims:7, dt:2, support:7\n",
      "226/575: timesteps:8, num_defenders:2, num_clusters:11, dims:8, dt:1, support:5\n",
      "227/575: timesteps:8, num_defenders:2, num_clusters:11, dims:8, dt:2, support:5\n",
      "228/575: timesteps:8, num_defenders:2, num_clusters:11, dims:9, dt:1, support:7\n",
      "229/575: timesteps:8, num_defenders:2, num_clusters:11, dims:9, dt:2, support:5\n",
      "230/575: timesteps:8, num_defenders:2, num_clusters:11, dims:10, dt:1, support:5\n",
      "231/575: timesteps:8, num_defenders:2, num_clusters:11, dims:10, dt:2, support:5\n",
      "232/575: timesteps:8, num_defenders:2, num_clusters:12, dims:7, dt:1, support:7\n",
      "233/575: timesteps:8, num_defenders:2, num_clusters:12, dims:7, dt:2, support:7\n",
      "234/575: timesteps:8, num_defenders:2, num_clusters:12, dims:8, dt:1, support:7\n",
      "235/575: timesteps:8, num_defenders:2, num_clusters:12, dims:8, dt:2, support:7\n",
      "236/575: timesteps:8, num_defenders:2, num_clusters:12, dims:9, dt:1, support:5\n",
      "237/575: timesteps:8, num_defenders:2, num_clusters:12, dims:9, dt:2, support:4\n",
      "238/575: timesteps:8, num_defenders:2, num_clusters:12, dims:10, dt:1, support:4\n",
      "239/575: timesteps:8, num_defenders:2, num_clusters:12, dims:10, dt:2, support:4\n",
      "240/575: timesteps:8, num_defenders:3, num_clusters:7, dims:7, dt:1, support:4\n",
      "241/575: timesteps:8, num_defenders:3, num_clusters:7, dims:7, dt:2, support:6\n",
      "242/575: timesteps:8, num_defenders:3, num_clusters:7, dims:8, dt:1, support:4\n",
      "243/575: timesteps:8, num_defenders:3, num_clusters:7, dims:8, dt:2, support:5\n",
      "244/575: timesteps:8, num_defenders:3, num_clusters:7, dims:9, dt:1, support:4\n",
      "245/575: timesteps:8, num_defenders:3, num_clusters:7, dims:9, dt:2, support:5\n",
      "246/575: timesteps:8, num_defenders:3, num_clusters:7, dims:10, dt:1, support:5\n",
      "247/575: timesteps:8, num_defenders:3, num_clusters:7, dims:10, dt:2, support:5\n",
      "248/575: timesteps:8, num_defenders:3, num_clusters:8, dims:7, dt:1, support:6\n",
      "249/575: timesteps:8, num_defenders:3, num_clusters:8, dims:7, dt:2, support:5\n",
      "250/575: timesteps:8, num_defenders:3, num_clusters:8, dims:8, dt:1, support:6\n",
      "251/575: timesteps:8, num_defenders:3, num_clusters:8, dims:8, dt:2, support:6\n",
      "252/575: timesteps:8, num_defenders:3, num_clusters:8, dims:9, dt:1, support:1\n",
      "253/575: timesteps:8, num_defenders:3, num_clusters:8, dims:9, dt:2, support:1\n",
      "254/575: timesteps:8, num_defenders:3, num_clusters:8, dims:10, dt:1, support:7\n",
      "255/575: timesteps:8, num_defenders:3, num_clusters:8, dims:10, dt:2, support:6\n",
      "256/575: timesteps:8, num_defenders:3, num_clusters:9, dims:7, dt:1, support:3\n",
      "257/575: timesteps:8, num_defenders:3, num_clusters:9, dims:7, dt:2, support:4\n",
      "258/575: timesteps:8, num_defenders:3, num_clusters:9, dims:8, dt:1, support:4\n",
      "259/575: timesteps:8, num_defenders:3, num_clusters:9, dims:8, dt:2, support:5\n",
      "260/575: timesteps:8, num_defenders:3, num_clusters:9, dims:9, dt:1, support:1\n",
      "261/575: timesteps:8, num_defenders:3, num_clusters:9, dims:9, dt:2, support:1\n",
      "262/575: timesteps:8, num_defenders:3, num_clusters:9, dims:10, dt:1, support:5\n",
      "263/575: timesteps:8, num_defenders:3, num_clusters:9, dims:10, dt:2, support:7\n",
      "264/575: timesteps:8, num_defenders:3, num_clusters:10, dims:7, dt:1, support:8\n",
      "265/575: timesteps:8, num_defenders:3, num_clusters:10, dims:7, dt:2, support:9\n",
      "266/575: timesteps:8, num_defenders:3, num_clusters:10, dims:8, dt:1, support:6\n",
      "267/575: timesteps:8, num_defenders:3, num_clusters:10, dims:8, dt:2, support:7\n",
      "268/575: timesteps:8, num_defenders:3, num_clusters:10, dims:9, dt:1, support:1\n",
      "269/575: timesteps:8, num_defenders:3, num_clusters:10, dims:9, dt:2, support:1\n",
      "270/575: timesteps:8, num_defenders:3, num_clusters:10, dims:10, dt:1, support:8\n",
      "271/575: timesteps:8, num_defenders:3, num_clusters:10, dims:10, dt:2, support:9\n",
      "272/575: timesteps:8, num_defenders:3, num_clusters:11, dims:7, dt:1, support:5\n",
      "273/575: timesteps:8, num_defenders:3, num_clusters:11, dims:7, dt:2, support:7\n",
      "274/575: timesteps:8, num_defenders:3, num_clusters:11, dims:8, dt:1, support:5\n",
      "275/575: timesteps:8, num_defenders:3, num_clusters:11, dims:8, dt:2, support:5\n",
      "276/575: timesteps:8, num_defenders:3, num_clusters:11, dims:9, dt:1, support:6\n",
      "277/575: timesteps:8, num_defenders:3, num_clusters:11, dims:9, dt:2, support:7\n",
      "278/575: timesteps:8, num_defenders:3, num_clusters:11, dims:10, dt:1, support:5\n",
      "279/575: timesteps:8, num_defenders:3, num_clusters:11, dims:10, dt:2, support:5\n",
      "280/575: timesteps:8, num_defenders:3, num_clusters:12, dims:7, dt:1, support:7\n",
      "281/575: timesteps:8, num_defenders:3, num_clusters:12, dims:7, dt:2, support:8\n",
      "282/575: timesteps:8, num_defenders:3, num_clusters:12, dims:8, dt:1, support:6\n",
      "283/575: timesteps:8, num_defenders:3, num_clusters:12, dims:8, dt:2, support:8\n",
      "284/575: timesteps:8, num_defenders:3, num_clusters:12, dims:9, dt:1, support:5\n",
      "285/575: timesteps:8, num_defenders:3, num_clusters:12, dims:9, dt:2, support:5\n",
      "286/575: timesteps:8, num_defenders:3, num_clusters:12, dims:10, dt:1, support:4\n",
      "287/575: timesteps:8, num_defenders:3, num_clusters:12, dims:10, dt:2, support:4\n",
      "288/575: timesteps:9, num_defenders:1, num_clusters:7, dims:7, dt:1, support:2\n",
      "289/575: timesteps:9, num_defenders:1, num_clusters:7, dims:7, dt:2, support:2\n",
      "290/575: timesteps:9, num_defenders:1, num_clusters:7, dims:8, dt:1, support:2\n",
      "291/575: timesteps:9, num_defenders:1, num_clusters:7, dims:8, dt:2, support:2\n",
      "292/575: timesteps:9, num_defenders:1, num_clusters:7, dims:9, dt:1, support:2\n",
      "293/575: timesteps:9, num_defenders:1, num_clusters:7, dims:9, dt:2, support:2\n",
      "294/575: timesteps:9, num_defenders:1, num_clusters:7, dims:10, dt:1, support:2\n",
      "295/575: timesteps:9, num_defenders:1, num_clusters:7, dims:10, dt:2, support:2\n",
      "296/575: timesteps:9, num_defenders:1, num_clusters:8, dims:7, dt:1, support:5\n",
      "297/575: timesteps:9, num_defenders:1, num_clusters:8, dims:7, dt:2, support:2\n",
      "298/575: timesteps:9, num_defenders:1, num_clusters:8, dims:8, dt:1, support:2\n",
      "299/575: timesteps:9, num_defenders:1, num_clusters:8, dims:8, dt:2, support:2\n",
      "300/575: timesteps:9, num_defenders:1, num_clusters:8, dims:9, dt:1, support:2\n",
      "301/575: timesteps:9, num_defenders:1, num_clusters:8, dims:9, dt:2, support:2\n",
      "302/575: timesteps:9, num_defenders:1, num_clusters:8, dims:10, dt:1, support:2\n",
      "303/575: timesteps:9, num_defenders:1, num_clusters:8, dims:10, dt:2, support:2\n",
      "304/575: timesteps:9, num_defenders:1, num_clusters:9, dims:7, dt:1, support:4\n",
      "305/575: timesteps:9, num_defenders:1, num_clusters:9, dims:7, dt:2, support:2\n",
      "306/575: timesteps:9, num_defenders:1, num_clusters:9, dims:8, dt:1, support:2\n",
      "307/575: timesteps:9, num_defenders:1, num_clusters:9, dims:8, dt:2, support:2\n",
      "308/575: timesteps:9, num_defenders:1, num_clusters:9, dims:9, dt:1, support:2\n",
      "309/575: timesteps:9, num_defenders:1, num_clusters:9, dims:9, dt:2, support:2\n",
      "310/575: timesteps:9, num_defenders:1, num_clusters:9, dims:10, dt:1, support:2\n",
      "311/575: timesteps:9, num_defenders:1, num_clusters:9, dims:10, dt:2, support:2\n",
      "312/575: timesteps:9, num_defenders:1, num_clusters:10, dims:7, dt:1, support:5\n",
      "313/575: timesteps:9, num_defenders:1, num_clusters:10, dims:7, dt:2, support:2\n",
      "314/575: timesteps:9, num_defenders:1, num_clusters:10, dims:8, dt:1, support:2\n",
      "315/575: timesteps:9, num_defenders:1, num_clusters:10, dims:8, dt:2, support:2\n",
      "316/575: timesteps:9, num_defenders:1, num_clusters:10, dims:9, dt:1, support:2\n",
      "317/575: timesteps:9, num_defenders:1, num_clusters:10, dims:9, dt:2, support:2\n",
      "318/575: timesteps:9, num_defenders:1, num_clusters:10, dims:10, dt:1, support:2\n",
      "319/575: timesteps:9, num_defenders:1, num_clusters:10, dims:10, dt:2, support:2\n",
      "320/575: timesteps:9, num_defenders:1, num_clusters:11, dims:7, dt:1, support:2\n",
      "321/575: timesteps:9, num_defenders:1, num_clusters:11, dims:7, dt:2, support:2\n",
      "322/575: timesteps:9, num_defenders:1, num_clusters:11, dims:8, dt:1, support:2\n",
      "323/575: timesteps:9, num_defenders:1, num_clusters:11, dims:8, dt:2, support:2\n",
      "324/575: timesteps:9, num_defenders:1, num_clusters:11, dims:9, dt:1, support:2\n",
      "325/575: timesteps:9, num_defenders:1, num_clusters:11, dims:9, dt:2, support:2\n",
      "326/575: timesteps:9, num_defenders:1, num_clusters:11, dims:10, dt:1, support:2\n",
      "327/575: timesteps:9, num_defenders:1, num_clusters:11, dims:10, dt:2, support:3\n",
      "328/575: timesteps:9, num_defenders:1, num_clusters:12, dims:7, dt:1, support:2\n",
      "329/575: timesteps:9, num_defenders:1, num_clusters:12, dims:7, dt:2, support:2\n",
      "330/575: timesteps:9, num_defenders:1, num_clusters:12, dims:8, dt:1, support:2\n",
      "331/575: timesteps:9, num_defenders:1, num_clusters:12, dims:8, dt:2, support:2\n",
      "332/575: timesteps:9, num_defenders:1, num_clusters:12, dims:9, dt:1, support:2\n",
      "333/575: timesteps:9, num_defenders:1, num_clusters:12, dims:9, dt:2, support:2\n",
      "334/575: timesteps:9, num_defenders:1, num_clusters:12, dims:10, dt:1, support:2\n",
      "335/575: timesteps:9, num_defenders:1, num_clusters:12, dims:10, dt:2, support:3\n",
      "336/575: timesteps:9, num_defenders:2, num_clusters:7, dims:7, dt:1, support:3\n",
      "337/575: timesteps:9, num_defenders:2, num_clusters:7, dims:7, dt:2, support:5\n",
      "338/575: timesteps:9, num_defenders:2, num_clusters:7, dims:8, dt:1, support:4\n",
      "339/575: timesteps:9, num_defenders:2, num_clusters:7, dims:8, dt:2, support:4\n",
      "340/575: timesteps:9, num_defenders:2, num_clusters:7, dims:9, dt:1, support:6\n",
      "341/575: timesteps:9, num_defenders:2, num_clusters:7, dims:9, dt:2, support:4\n",
      "342/575: timesteps:9, num_defenders:2, num_clusters:7, dims:10, dt:1, support:4\n",
      "343/575: timesteps:9, num_defenders:2, num_clusters:7, dims:10, dt:2, support:5\n",
      "344/575: timesteps:9, num_defenders:2, num_clusters:8, dims:7, dt:1, support:4\n",
      "345/575: timesteps:9, num_defenders:2, num_clusters:8, dims:7, dt:2, support:6\n",
      "346/575: timesteps:9, num_defenders:2, num_clusters:8, dims:8, dt:1, support:6\n",
      "347/575: timesteps:9, num_defenders:2, num_clusters:8, dims:8, dt:2, support:5\n",
      "348/575: timesteps:9, num_defenders:2, num_clusters:8, dims:9, dt:1, support:5\n",
      "349/575: timesteps:9, num_defenders:2, num_clusters:8, dims:9, dt:2, support:1\n",
      "350/575: timesteps:9, num_defenders:2, num_clusters:8, dims:10, dt:1, support:6\n",
      "351/575: timesteps:9, num_defenders:2, num_clusters:8, dims:10, dt:2, support:5\n",
      "352/575: timesteps:9, num_defenders:2, num_clusters:9, dims:7, dt:1, support:4\n",
      "353/575: timesteps:9, num_defenders:2, num_clusters:9, dims:7, dt:2, support:6\n",
      "354/575: timesteps:9, num_defenders:2, num_clusters:9, dims:8, dt:1, support:7\n",
      "355/575: timesteps:9, num_defenders:2, num_clusters:9, dims:8, dt:2, support:5\n",
      "356/575: timesteps:9, num_defenders:2, num_clusters:9, dims:9, dt:1, support:5\n",
      "357/575: timesteps:9, num_defenders:2, num_clusters:9, dims:9, dt:2, support:1\n",
      "358/575: timesteps:9, num_defenders:2, num_clusters:9, dims:10, dt:1, support:6\n",
      "359/575: timesteps:9, num_defenders:2, num_clusters:9, dims:10, dt:2, support:5\n",
      "360/575: timesteps:9, num_defenders:2, num_clusters:10, dims:7, dt:1, support:7\n",
      "361/575: timesteps:9, num_defenders:2, num_clusters:10, dims:7, dt:2, support:6\n",
      "362/575: timesteps:9, num_defenders:2, num_clusters:10, dims:8, dt:1, support:5\n",
      "363/575: timesteps:9, num_defenders:2, num_clusters:10, dims:8, dt:2, support:5\n",
      "364/575: timesteps:9, num_defenders:2, num_clusters:10, dims:9, dt:1, support:5\n",
      "365/575: timesteps:9, num_defenders:2, num_clusters:10, dims:9, dt:2, support:1\n",
      "366/575: timesteps:9, num_defenders:2, num_clusters:10, dims:10, dt:1, support:8\n",
      "367/575: timesteps:9, num_defenders:2, num_clusters:10, dims:10, dt:2, support:5\n",
      "368/575: timesteps:9, num_defenders:2, num_clusters:11, dims:7, dt:1, support:6\n",
      "369/575: timesteps:9, num_defenders:2, num_clusters:11, dims:7, dt:2, support:6\n",
      "370/575: timesteps:9, num_defenders:2, num_clusters:11, dims:8, dt:1, support:8\n",
      "371/575: timesteps:9, num_defenders:2, num_clusters:11, dims:8, dt:2, support:5\n",
      "372/575: timesteps:9, num_defenders:2, num_clusters:11, dims:9, dt:1, support:8\n",
      "373/575: timesteps:9, num_defenders:2, num_clusters:11, dims:9, dt:2, support:5\n",
      "374/575: timesteps:9, num_defenders:2, num_clusters:11, dims:10, dt:1, support:6\n",
      "375/575: timesteps:9, num_defenders:2, num_clusters:11, dims:10, dt:2, support:5\n",
      "376/575: timesteps:9, num_defenders:2, num_clusters:12, dims:7, dt:1, support:8\n",
      "377/575: timesteps:9, num_defenders:2, num_clusters:12, dims:7, dt:2, support:7\n",
      "378/575: timesteps:9, num_defenders:2, num_clusters:12, dims:8, dt:1, support:7\n",
      "379/575: timesteps:9, num_defenders:2, num_clusters:12, dims:8, dt:2, support:7\n",
      "380/575: timesteps:9, num_defenders:2, num_clusters:12, dims:9, dt:1, support:8\n",
      "381/575: timesteps:9, num_defenders:2, num_clusters:12, dims:9, dt:2, support:4\n",
      "382/575: timesteps:9, num_defenders:2, num_clusters:12, dims:10, dt:1, support:7\n",
      "383/575: timesteps:9, num_defenders:2, num_clusters:12, dims:10, dt:2, support:4\n",
      "384/575: timesteps:9, num_defenders:3, num_clusters:7, dims:7, dt:1, support:4\n",
      "385/575: timesteps:9, num_defenders:3, num_clusters:7, dims:7, dt:2, support:6\n",
      "386/575: timesteps:9, num_defenders:3, num_clusters:7, dims:8, dt:1, support:4\n",
      "387/575: timesteps:9, num_defenders:3, num_clusters:7, dims:8, dt:2, support:5\n",
      "388/575: timesteps:9, num_defenders:3, num_clusters:7, dims:9, dt:1, support:4\n",
      "389/575: timesteps:9, num_defenders:3, num_clusters:7, dims:9, dt:2, support:5\n",
      "390/575: timesteps:9, num_defenders:3, num_clusters:7, dims:10, dt:1, support:5\n",
      "391/575: timesteps:9, num_defenders:3, num_clusters:7, dims:10, dt:2, support:5\n",
      "392/575: timesteps:9, num_defenders:3, num_clusters:8, dims:7, dt:1, support:5\n",
      "393/575: timesteps:9, num_defenders:3, num_clusters:8, dims:7, dt:2, support:5\n",
      "394/575: timesteps:9, num_defenders:3, num_clusters:8, dims:8, dt:1, support:6\n",
      "395/575: timesteps:9, num_defenders:3, num_clusters:8, dims:8, dt:2, support:6\n",
      "396/575: timesteps:9, num_defenders:3, num_clusters:8, dims:9, dt:1, support:6\n",
      "397/575: timesteps:9, num_defenders:3, num_clusters:8, dims:9, dt:2, support:1\n",
      "398/575: timesteps:9, num_defenders:3, num_clusters:8, dims:10, dt:1, support:7\n",
      "399/575: timesteps:9, num_defenders:3, num_clusters:8, dims:10, dt:2, support:6\n",
      "400/575: timesteps:9, num_defenders:3, num_clusters:9, dims:7, dt:1, support:3\n",
      "401/575: timesteps:9, num_defenders:3, num_clusters:9, dims:7, dt:2, support:5\n",
      "402/575: timesteps:9, num_defenders:3, num_clusters:9, dims:8, dt:1, support:5\n",
      "403/575: timesteps:9, num_defenders:3, num_clusters:9, dims:8, dt:2, support:5\n",
      "404/575: timesteps:9, num_defenders:3, num_clusters:9, dims:9, dt:1, support:5\n",
      "405/575: timesteps:9, num_defenders:3, num_clusters:9, dims:9, dt:2, support:1\n",
      "406/575: timesteps:9, num_defenders:3, num_clusters:9, dims:10, dt:1, support:7\n",
      "407/575: timesteps:9, num_defenders:3, num_clusters:9, dims:10, dt:2, support:7\n",
      "408/575: timesteps:9, num_defenders:3, num_clusters:10, dims:7, dt:1, support:6\n",
      "409/575: timesteps:9, num_defenders:3, num_clusters:10, dims:7, dt:2, support:7\n",
      "410/575: timesteps:9, num_defenders:3, num_clusters:10, dims:8, dt:1, support:6\n",
      "411/575: timesteps:9, num_defenders:3, num_clusters:10, dims:8, dt:2, support:6\n",
      "412/575: timesteps:9, num_defenders:3, num_clusters:10, dims:9, dt:1, support:8\n",
      "413/575: timesteps:9, num_defenders:3, num_clusters:10, dims:9, dt:2, support:1\n",
      "414/575: timesteps:9, num_defenders:3, num_clusters:10, dims:10, dt:1, support:8\n",
      "415/575: timesteps:9, num_defenders:3, num_clusters:10, dims:10, dt:2, support:6\n",
      "416/575: timesteps:9, num_defenders:3, num_clusters:11, dims:7, dt:1, support:5\n",
      "417/575: timesteps:9, num_defenders:3, num_clusters:11, dims:7, dt:2, support:6\n",
      "418/575: timesteps:9, num_defenders:3, num_clusters:11, dims:8, dt:1, support:7\n",
      "419/575: timesteps:9, num_defenders:3, num_clusters:11, dims:8, dt:2, support:5\n",
      "420/575: timesteps:9, num_defenders:3, num_clusters:11, dims:9, dt:1, support:7\n",
      "421/575: timesteps:9, num_defenders:3, num_clusters:11, dims:9, dt:2, support:6\n",
      "422/575: timesteps:9, num_defenders:3, num_clusters:11, dims:10, dt:1, support:7\n",
      "423/575: timesteps:9, num_defenders:3, num_clusters:11, dims:10, dt:2, support:5\n",
      "424/575: timesteps:9, num_defenders:3, num_clusters:12, dims:7, dt:1, support:8\n",
      "425/575: timesteps:9, num_defenders:3, num_clusters:12, dims:7, dt:2, support:6\n",
      "426/575: timesteps:9, num_defenders:3, num_clusters:12, dims:8, dt:1, support:5\n",
      "427/575: timesteps:9, num_defenders:3, num_clusters:12, dims:8, dt:2, support:8\n",
      "428/575: timesteps:9, num_defenders:3, num_clusters:12, dims:9, dt:1, support:8\n",
      "429/575: timesteps:9, num_defenders:3, num_clusters:12, dims:9, dt:2, support:5\n",
      "430/575: timesteps:9, num_defenders:3, num_clusters:12, dims:10, dt:1, support:8\n",
      "431/575: timesteps:9, num_defenders:3, num_clusters:12, dims:10, dt:2, support:4\n",
      "432/575: timesteps:10, num_defenders:1, num_clusters:7, dims:7, dt:1, support:2\n",
      "433/575: timesteps:10, num_defenders:1, num_clusters:7, dims:7, dt:2, support:2\n",
      "434/575: timesteps:10, num_defenders:1, num_clusters:7, dims:8, dt:1, support:2\n",
      "435/575: timesteps:10, num_defenders:1, num_clusters:7, dims:8, dt:2, support:2\n",
      "436/575: timesteps:10, num_defenders:1, num_clusters:7, dims:9, dt:1, support:2\n",
      "437/575: timesteps:10, num_defenders:1, num_clusters:7, dims:9, dt:2, support:2\n",
      "438/575: timesteps:10, num_defenders:1, num_clusters:7, dims:10, dt:1, support:2\n",
      "439/575: timesteps:10, num_defenders:1, num_clusters:7, dims:10, dt:2, support:2\n",
      "440/575: timesteps:10, num_defenders:1, num_clusters:8, dims:7, dt:1, support:5\n",
      "441/575: timesteps:10, num_defenders:1, num_clusters:8, dims:7, dt:2, support:4\n",
      "442/575: timesteps:10, num_defenders:1, num_clusters:8, dims:8, dt:1, support:2\n",
      "443/575: timesteps:10, num_defenders:1, num_clusters:8, dims:8, dt:2, support:2\n",
      "444/575: timesteps:10, num_defenders:1, num_clusters:8, dims:9, dt:1, support:2\n",
      "445/575: timesteps:10, num_defenders:1, num_clusters:8, dims:9, dt:2, support:2\n",
      "446/575: timesteps:10, num_defenders:1, num_clusters:8, dims:10, dt:1, support:2\n",
      "447/575: timesteps:10, num_defenders:1, num_clusters:8, dims:10, dt:2, support:2\n",
      "448/575: timesteps:10, num_defenders:1, num_clusters:9, dims:7, dt:1, support:4\n",
      "449/575: timesteps:10, num_defenders:1, num_clusters:9, dims:7, dt:2, support:4\n",
      "450/575: timesteps:10, num_defenders:1, num_clusters:9, dims:8, dt:1, support:2\n",
      "451/575: timesteps:10, num_defenders:1, num_clusters:9, dims:8, dt:2, support:2\n",
      "452/575: timesteps:10, num_defenders:1, num_clusters:9, dims:9, dt:1, support:2\n",
      "453/575: timesteps:10, num_defenders:1, num_clusters:9, dims:9, dt:2, support:2\n",
      "454/575: timesteps:10, num_defenders:1, num_clusters:9, dims:10, dt:1, support:2\n",
      "455/575: timesteps:10, num_defenders:1, num_clusters:9, dims:10, dt:2, support:2\n",
      "456/575: timesteps:10, num_defenders:1, num_clusters:10, dims:7, dt:1, support:3\n",
      "457/575: timesteps:10, num_defenders:1, num_clusters:10, dims:7, dt:2, support:5\n",
      "458/575: timesteps:10, num_defenders:1, num_clusters:10, dims:8, dt:1, support:2\n",
      "459/575: timesteps:10, num_defenders:1, num_clusters:10, dims:8, dt:2, support:2\n",
      "460/575: timesteps:10, num_defenders:1, num_clusters:10, dims:9, dt:1, support:2\n",
      "461/575: timesteps:10, num_defenders:1, num_clusters:10, dims:9, dt:2, support:2\n",
      "462/575: timesteps:10, num_defenders:1, num_clusters:10, dims:10, dt:1, support:2\n",
      "463/575: timesteps:10, num_defenders:1, num_clusters:10, dims:10, dt:2, support:2\n",
      "464/575: timesteps:10, num_defenders:1, num_clusters:11, dims:7, dt:1, support:2\n",
      "465/575: timesteps:10, num_defenders:1, num_clusters:11, dims:7, dt:2, support:4\n",
      "466/575: timesteps:10, num_defenders:1, num_clusters:11, dims:8, dt:1, support:2\n",
      "467/575: timesteps:10, num_defenders:1, num_clusters:11, dims:8, dt:2, support:2\n",
      "468/575: timesteps:10, num_defenders:1, num_clusters:11, dims:9, dt:1, support:2\n",
      "469/575: timesteps:10, num_defenders:1, num_clusters:11, dims:9, dt:2, support:2\n",
      "470/575: timesteps:10, num_defenders:1, num_clusters:11, dims:10, dt:1, support:2\n",
      "471/575: timesteps:10, num_defenders:1, num_clusters:11, dims:10, dt:2, support:3\n",
      "472/575: timesteps:10, num_defenders:1, num_clusters:12, dims:7, dt:1, support:2\n",
      "473/575: timesteps:10, num_defenders:1, num_clusters:12, dims:7, dt:2, support:4\n",
      "474/575: timesteps:10, num_defenders:1, num_clusters:12, dims:8, dt:1, support:2\n",
      "475/575: timesteps:10, num_defenders:1, num_clusters:12, dims:8, dt:2, support:2\n",
      "476/575: timesteps:10, num_defenders:1, num_clusters:12, dims:9, dt:1, support:2\n",
      "477/575: timesteps:10, num_defenders:1, num_clusters:12, dims:9, dt:2, support:2\n",
      "478/575: timesteps:10, num_defenders:1, num_clusters:12, dims:10, dt:1, support:2\n",
      "479/575: timesteps:10, num_defenders:1, num_clusters:12, dims:10, dt:2, support:3\n",
      "480/575: timesteps:10, num_defenders:2, num_clusters:7, dims:7, dt:1, support:3\n",
      "481/575: timesteps:10, num_defenders:2, num_clusters:7, dims:7, dt:2, support:6\n",
      "482/575: timesteps:10, num_defenders:2, num_clusters:7, dims:8, dt:1, support:3\n",
      "483/575: timesteps:10, num_defenders:2, num_clusters:7, dims:8, dt:2, support:4\n",
      "484/575: timesteps:10, num_defenders:2, num_clusters:7, dims:9, dt:1, support:5\n",
      "485/575: timesteps:10, num_defenders:2, num_clusters:7, dims:9, dt:2, support:6\n",
      "486/575: timesteps:10, num_defenders:2, num_clusters:7, dims:10, dt:1, support:4\n",
      "487/575: timesteps:10, num_defenders:2, num_clusters:7, dims:10, dt:2, support:4\n",
      "488/575: timesteps:10, num_defenders:2, num_clusters:8, dims:7, dt:1, support:5\n",
      "489/575: timesteps:10, num_defenders:2, num_clusters:8, dims:7, dt:2, support:7\n",
      "490/575: timesteps:10, num_defenders:2, num_clusters:8, dims:8, dt:1, support:5\n",
      "491/575: timesteps:10, num_defenders:2, num_clusters:8, dims:8, dt:2, support:6\n",
      "492/575: timesteps:10, num_defenders:2, num_clusters:8, dims:9, dt:1, support:5\n",
      "493/575: timesteps:10, num_defenders:2, num_clusters:8, dims:9, dt:2, support:5\n",
      "494/575: timesteps:10, num_defenders:2, num_clusters:8, dims:10, dt:1, support:5\n",
      "495/575: timesteps:10, num_defenders:2, num_clusters:8, dims:10, dt:2, support:6\n",
      "496/575: timesteps:10, num_defenders:2, num_clusters:9, dims:7, dt:1, support:5\n",
      "497/575: timesteps:10, num_defenders:2, num_clusters:9, dims:7, dt:2, support:7\n",
      "498/575: timesteps:10, num_defenders:2, num_clusters:9, dims:8, dt:1, support:6\n",
      "499/575: timesteps:10, num_defenders:2, num_clusters:9, dims:8, dt:2, support:7\n",
      "500/575: timesteps:10, num_defenders:2, num_clusters:9, dims:9, dt:1, support:6\n",
      "501/575: timesteps:10, num_defenders:2, num_clusters:9, dims:9, dt:2, support:5\n",
      "502/575: timesteps:10, num_defenders:2, num_clusters:9, dims:10, dt:1, support:6\n",
      "503/575: timesteps:10, num_defenders:2, num_clusters:9, dims:10, dt:2, support:6\n",
      "504/575: timesteps:10, num_defenders:2, num_clusters:10, dims:7, dt:1, support:5\n",
      "505/575: timesteps:10, num_defenders:2, num_clusters:10, dims:7, dt:2, support:7\n",
      "506/575: timesteps:10, num_defenders:2, num_clusters:10, dims:8, dt:1, support:7\n",
      "507/575: timesteps:10, num_defenders:2, num_clusters:10, dims:8, dt:2, support:8\n",
      "508/575: timesteps:10, num_defenders:2, num_clusters:10, dims:9, dt:1, support:7\n",
      "509/575: timesteps:10, num_defenders:2, num_clusters:10, dims:9, dt:2, support:5\n",
      "510/575: timesteps:10, num_defenders:2, num_clusters:10, dims:10, dt:1, support:7\n",
      "511/575: timesteps:10, num_defenders:2, num_clusters:10, dims:10, dt:2, support:8\n",
      "512/575: timesteps:10, num_defenders:2, num_clusters:11, dims:7, dt:1, support:5\n",
      "513/575: timesteps:10, num_defenders:2, num_clusters:11, dims:7, dt:2, support:8\n",
      "514/575: timesteps:10, num_defenders:2, num_clusters:11, dims:8, dt:1, support:6\n",
      "515/575: timesteps:10, num_defenders:2, num_clusters:11, dims:8, dt:2, support:8\n",
      "516/575: timesteps:10, num_defenders:2, num_clusters:11, dims:9, dt:1, support:8\n",
      "517/575: timesteps:10, num_defenders:2, num_clusters:11, dims:9, dt:2, support:8\n",
      "518/575: timesteps:10, num_defenders:2, num_clusters:11, dims:10, dt:1, support:7\n",
      "519/575: timesteps:10, num_defenders:2, num_clusters:11, dims:10, dt:2, support:6\n",
      "520/575: timesteps:10, num_defenders:2, num_clusters:12, dims:7, dt:1, support:8\n",
      "521/575: timesteps:10, num_defenders:2, num_clusters:12, dims:7, dt:2, support:7\n",
      "522/575: timesteps:10, num_defenders:2, num_clusters:12, dims:8, dt:1, support:6\n",
      "523/575: timesteps:10, num_defenders:2, num_clusters:12, dims:8, dt:2, support:9\n",
      "524/575: timesteps:10, num_defenders:2, num_clusters:12, dims:9, dt:1, support:8\n",
      "525/575: timesteps:10, num_defenders:2, num_clusters:12, dims:9, dt:2, support:8\n",
      "526/575: timesteps:10, num_defenders:2, num_clusters:12, dims:10, dt:1, support:8\n",
      "527/575: timesteps:10, num_defenders:2, num_clusters:12, dims:10, dt:2, support:7\n",
      "528/575: timesteps:10, num_defenders:3, num_clusters:7, dims:7, dt:1, support:4\n",
      "529/575: timesteps:10, num_defenders:3, num_clusters:7, dims:7, dt:2, support:4\n",
      "530/575: timesteps:10, num_defenders:3, num_clusters:7, dims:8, dt:1, support:4\n",
      "531/575: timesteps:10, num_defenders:3, num_clusters:7, dims:8, dt:2, support:4\n",
      "532/575: timesteps:10, num_defenders:3, num_clusters:7, dims:9, dt:1, support:4\n",
      "533/575: timesteps:10, num_defenders:3, num_clusters:7, dims:9, dt:2, support:4\n",
      "534/575: timesteps:10, num_defenders:3, num_clusters:7, dims:10, dt:1, support:6\n",
      "535/575: timesteps:10, num_defenders:3, num_clusters:7, dims:10, dt:2, support:5\n",
      "536/575: timesteps:10, num_defenders:3, num_clusters:8, dims:7, dt:1, support:6\n",
      "537/575: timesteps:10, num_defenders:3, num_clusters:8, dims:7, dt:2, support:5\n",
      "538/575: timesteps:10, num_defenders:3, num_clusters:8, dims:8, dt:1, support:6\n",
      "539/575: timesteps:10, num_defenders:3, num_clusters:8, dims:8, dt:2, support:7\n",
      "540/575: timesteps:10, num_defenders:3, num_clusters:8, dims:9, dt:1, support:4\n",
      "541/575: timesteps:10, num_defenders:3, num_clusters:8, dims:9, dt:2, support:6\n",
      "542/575: timesteps:10, num_defenders:3, num_clusters:8, dims:10, dt:1, support:6\n",
      "543/575: timesteps:10, num_defenders:3, num_clusters:8, dims:10, dt:2, support:7\n",
      "544/575: timesteps:10, num_defenders:3, num_clusters:9, dims:7, dt:1, support:5\n",
      "545/575: timesteps:10, num_defenders:3, num_clusters:9, dims:7, dt:2, support:5\n",
      "546/575: timesteps:10, num_defenders:3, num_clusters:9, dims:8, dt:1, support:4\n",
      "547/575: timesteps:10, num_defenders:3, num_clusters:9, dims:8, dt:2, support:7\n",
      "548/575: timesteps:10, num_defenders:3, num_clusters:9, dims:9, dt:1, support:4\n",
      "549/575: timesteps:10, num_defenders:3, num_clusters:9, dims:9, dt:2, support:5\n",
      "550/575: timesteps:10, num_defenders:3, num_clusters:9, dims:10, dt:1, support:7\n",
      "551/575: timesteps:10, num_defenders:3, num_clusters:9, dims:10, dt:2, support:7\n",
      "552/575: timesteps:10, num_defenders:3, num_clusters:10, dims:7, dt:1, support:5\n",
      "553/575: timesteps:10, num_defenders:3, num_clusters:10, dims:7, dt:2, support:7\n",
      "554/575: timesteps:10, num_defenders:3, num_clusters:10, dims:8, dt:1, support:5\n",
      "555/575: timesteps:10, num_defenders:3, num_clusters:10, dims:8, dt:2, support:8\n",
      "556/575: timesteps:10, num_defenders:3, num_clusters:10, dims:9, dt:1, support:7\n",
      "557/575: timesteps:10, num_defenders:3, num_clusters:10, dims:9, dt:2, support:8\n",
      "558/575: timesteps:10, num_defenders:3, num_clusters:10, dims:10, dt:1, support:8\n",
      "559/575: timesteps:10, num_defenders:3, num_clusters:10, dims:10, dt:2, support:8\n",
      "560/575: timesteps:10, num_defenders:3, num_clusters:11, dims:7, dt:1, support:5\n",
      "561/575: timesteps:10, num_defenders:3, num_clusters:11, dims:7, dt:2, support:6\n",
      "562/575: timesteps:10, num_defenders:3, num_clusters:11, dims:8, dt:1, support:6\n",
      "563/575: timesteps:10, num_defenders:3, num_clusters:11, dims:8, dt:2, support:7\n",
      "564/575: timesteps:10, num_defenders:3, num_clusters:11, dims:9, dt:1, support:5\n",
      "565/575: timesteps:10, num_defenders:3, num_clusters:11, dims:9, dt:2, support:8\n",
      "566/575: timesteps:10, num_defenders:3, num_clusters:11, dims:10, dt:1, support:5\n",
      "567/575: timesteps:10, num_defenders:3, num_clusters:11, dims:10, dt:2, support:7\n",
      "568/575: timesteps:10, num_defenders:3, num_clusters:12, dims:7, dt:1, support:8\n",
      "569/575: timesteps:10, num_defenders:3, num_clusters:12, dims:7, dt:2, support:6\n",
      "570/575: timesteps:10, num_defenders:3, num_clusters:12, dims:8, dt:1, support:6\n",
      "571/575: timesteps:10, num_defenders:3, num_clusters:12, dims:8, dt:2, support:7\n",
      "572/575: timesteps:10, num_defenders:3, num_clusters:12, dims:9, dt:1, support:8\n",
      "573/575: timesteps:10, num_defenders:3, num_clusters:12, dims:9, dt:2, support:8\n",
      "574/575: timesteps:10, num_defenders:3, num_clusters:12, dims:10, dt:1, support:6\n",
      "575/575: timesteps:10, num_defenders:3, num_clusters:12, dims:10, dt:2, support:7\n"
     ]
    }
   ],
   "source": [
    "df = pd.read_csv(\"lobeke.csv\")\n",
    "df.dropna(inplace=True)\n",
    "\n",
    "# Lobeke National Park Bounding Box\n",
    "# lat_min, lon_min = 2.05522, 15.8790\n",
    "# lat_max, lon_max = 2.2837, 16.2038\n",
    "\n",
    "lat_min, lon_min = 2.0530, 15.8790\n",
    "lat_max, lon_max = 2.2837, 16.2038\n",
    "\n",
    "coordinate_rectangle = [lat_min, lat_max, lon_min, lon_max]\n",
    "\n",
    "schedule_form_kwargs = {\n",
    "    \"schedule_form\": True,\n",
    "    \"simple\": False,\n",
    "    \"attacker_penalty_factor\": 5,\n",
    "    \"defender_penalty_factor\": 5\n",
    "}\n",
    "\n",
    "general_sum_kwargs = {\n",
    "    \"general_sum\": False,\n",
    "    \"attacker_feature_value\":  42, \n",
    "    \"defender_feature_value\": 69, \n",
    "    \"defender_step_cost\": 32.5, \n",
    "}\n",
    "\n",
    "boulou_camp = (2.2,15.9)\n",
    "# lobeke_camp = (2.25,15.75)\n",
    "kabo_djembe = (2.0532352380408088, 16.085709866529694)\n",
    "bomassa = (2.2037280296158355, 16.187056364164913)\n",
    "inner_post = (2.2,15.98)\n",
    "num_timesteps_li = []\n",
    "num_defenders_li = []\n",
    "supports=[]\n",
    "num_clusters_li = []\n",
    "dims_li = []\n",
    "dts = []\n",
    "defender_actions_sizes = []\n",
    "attacker_actions_sizes = []\n",
    "iterations_to_converge = []\n",
    "iteration_times_li = []\n",
    "gaps_li = []\n",
    "i=0\n",
    "for num_timesteps in [7,8,9,10]:\n",
    "    for num_defenders in [1,2,3]:\n",
    "        for num_clusters in [7,8,9,10,11,12]:\n",
    "            for dims in [7,8,9,10]:\n",
    "                for dt in [1,2]:\n",
    "                    gsg = GreenSecurityGame(df, coordinate_rectangle, \"centroid\", num_clusters=num_clusters, num_rows=dims, num_columns=dims)\n",
    "                    gsg.generate(num_attackers=1, \n",
    "                                 num_defenders=num_defenders, \n",
    "                                 home_base_assignments=[(kabo_djembe, bomassa, inner_post) for i in range(num_defenders)], \n",
    "                                 num_timesteps=num_timesteps, \n",
    "                                 generate_utility_matrix=False, \n",
    "                                 defense_time_threshold=dt, \n",
    "                                 generate_actions=True, \n",
    "                                 force_return=True, \n",
    "                                 general_sum=False, \n",
    "                                 **schedule_form_kwargs)\n",
    "                    D_a, D_d, u, A_a, A_d, c, iteration_times, gaps = double_oracle_sf(gsg.schedule_form_dict,eps=1e-12, verbose=False)\n",
    "                    support = sum([1 for p in D_d if p!=0])\n",
    "                    supports.append(support)\n",
    "                    num_timesteps_li.append(num_timesteps)\n",
    "                    num_defenders_li.append(num_defenders)\n",
    "                    num_clusters_li.append(num_clusters)\n",
    "                    dims_li.append(dims)\n",
    "                    dts.append(dt)\n",
    "                    iterations_to_converge.append(c)\n",
    "                    defender_actions_sizes.append(len(A_d))\n",
    "                    attacker_actions_sizes.append(len(A_a))\n",
    "                    iteration_times_li.append(iteration_times)\n",
    "                    gaps_li.append(gaps)\n",
    "                    print(f\"{i}/575: timesteps:{num_timesteps}, num_defenders:{num_defenders}, num_clusters:{num_clusters}, dims:{dims}, dt:{dt}, support:{support}\")\n",
    "                    i+=1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "c996b3b0-317a-4c5b-aae7-f8f575617be2",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>num_timesteps</th>\n",
       "      <th>num_defenders</th>\n",
       "      <th>num_clusters</th>\n",
       "      <th>dims</th>\n",
       "      <th>defense_time_threshold</th>\n",
       "      <th>iteration_number</th>\n",
       "      <th>iteration_time</th>\n",
       "      <th>gap</th>\n",
       "      <th>iterations_to_converge</th>\n",
       "      <th>def_support</th>\n",
       "      <th>defender_actions_size</th>\n",
       "      <th>attacker_actions_size</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>7</td>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>0.012764</td>\n",
       "      <td>0.806915</td>\n",
       "      <td>5</td>\n",
       "      <td>2</td>\n",
       "      <td>3</td>\n",
       "      <td>3</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>7</td>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>2</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.8</td>\n",
       "      <td>5</td>\n",
       "      <td>2</td>\n",
       "      <td>3</td>\n",
       "      <td>3</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>7</td>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>3</td>\n",
       "      <td>0.001</td>\n",
       "      <td>0.587234</td>\n",
       "      <td>5</td>\n",
       "      <td>2</td>\n",
       "      <td>3</td>\n",
       "      <td>3</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>7</td>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>4</td>\n",
       "      <td>0.001</td>\n",
       "      <td>0.629787</td>\n",
       "      <td>5</td>\n",
       "      <td>2</td>\n",
       "      <td>3</td>\n",
       "      <td>3</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>7</td>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>5</td>\n",
       "      <td>0.001</td>\n",
       "      <td>0.0</td>\n",
       "      <td>5</td>\n",
       "      <td>2</td>\n",
       "      <td>3</td>\n",
       "      <td>3</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7809</th>\n",
       "      <td>10</td>\n",
       "      <td>3</td>\n",
       "      <td>12</td>\n",
       "      <td>10</td>\n",
       "      <td>2</td>\n",
       "      <td>29</td>\n",
       "      <td>0.013013</td>\n",
       "      <td>0.095917</td>\n",
       "      <td>33</td>\n",
       "      <td>7</td>\n",
       "      <td>31</td>\n",
       "      <td>9</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7810</th>\n",
       "      <td>10</td>\n",
       "      <td>3</td>\n",
       "      <td>12</td>\n",
       "      <td>10</td>\n",
       "      <td>2</td>\n",
       "      <td>30</td>\n",
       "      <td>0.025408</td>\n",
       "      <td>0.12954</td>\n",
       "      <td>33</td>\n",
       "      <td>7</td>\n",
       "      <td>31</td>\n",
       "      <td>9</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7811</th>\n",
       "      <td>10</td>\n",
       "      <td>3</td>\n",
       "      <td>12</td>\n",
       "      <td>10</td>\n",
       "      <td>2</td>\n",
       "      <td>31</td>\n",
       "      <td>0.016651</td>\n",
       "      <td>0.029117</td>\n",
       "      <td>33</td>\n",
       "      <td>7</td>\n",
       "      <td>31</td>\n",
       "      <td>9</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7812</th>\n",
       "      <td>10</td>\n",
       "      <td>3</td>\n",
       "      <td>12</td>\n",
       "      <td>10</td>\n",
       "      <td>2</td>\n",
       "      <td>32</td>\n",
       "      <td>0.015821</td>\n",
       "      <td>0.103894</td>\n",
       "      <td>33</td>\n",
       "      <td>7</td>\n",
       "      <td>31</td>\n",
       "      <td>9</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7813</th>\n",
       "      <td>10</td>\n",
       "      <td>3</td>\n",
       "      <td>12</td>\n",
       "      <td>10</td>\n",
       "      <td>2</td>\n",
       "      <td>33</td>\n",
       "      <td>0.019528</td>\n",
       "      <td>0.0</td>\n",
       "      <td>33</td>\n",
       "      <td>7</td>\n",
       "      <td>31</td>\n",
       "      <td>9</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>7814 rows × 12 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "      num_timesteps  num_defenders  num_clusters  dims  \\\n",
       "0                 7              1             7     7   \n",
       "1                 7              1             7     7   \n",
       "2                 7              1             7     7   \n",
       "3                 7              1             7     7   \n",
       "4                 7              1             7     7   \n",
       "...             ...            ...           ...   ...   \n",
       "7809             10              3            12    10   \n",
       "7810             10              3            12    10   \n",
       "7811             10              3            12    10   \n",
       "7812             10              3            12    10   \n",
       "7813             10              3            12    10   \n",
       "\n",
       "      defense_time_threshold  iteration_number iteration_time       gap  \\\n",
       "0                          1                 1       0.012764  0.806915   \n",
       "1                          1                 2            0.0       0.8   \n",
       "2                          1                 3          0.001  0.587234   \n",
       "3                          1                 4          0.001  0.629787   \n",
       "4                          1                 5          0.001       0.0   \n",
       "...                      ...               ...            ...       ...   \n",
       "7809                       2                29       0.013013  0.095917   \n",
       "7810                       2                30       0.025408   0.12954   \n",
       "7811                       2                31       0.016651  0.029117   \n",
       "7812                       2                32       0.015821  0.103894   \n",
       "7813                       2                33       0.019528       0.0   \n",
       "\n",
       "      iterations_to_converge  def_support  defender_actions_size  \\\n",
       "0                          5            2                      3   \n",
       "1                          5            2                      3   \n",
       "2                          5            2                      3   \n",
       "3                          5            2                      3   \n",
       "4                          5            2                      3   \n",
       "...                      ...          ...                    ...   \n",
       "7809                      33            7                     31   \n",
       "7810                      33            7                     31   \n",
       "7811                      33            7                     31   \n",
       "7812                      33            7                     31   \n",
       "7813                      33            7                     31   \n",
       "\n",
       "      attacker_actions_size  \n",
       "0                         3  \n",
       "1                         3  \n",
       "2                         3  \n",
       "3                         3  \n",
       "4                         3  \n",
       "...                     ...  \n",
       "7809                      9  \n",
       "7810                      9  \n",
       "7811                      9  \n",
       "7812                      9  \n",
       "7813                      9  \n",
       "\n",
       "[7814 rows x 12 columns]"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df = pd.DataFrame({\n",
    "    \"num_timesteps\": num_timesteps_li,\n",
    "    \"num_defenders\": num_defenders_li,\n",
    "    \"num_clusters\": num_clusters_li,\n",
    "    \"dims\": dims_li,\n",
    "    \"defense_time_threshold\": dts,\n",
    "    \"def_support\": supports,\n",
    "    \"iterations_to_converge\": iterations_to_converge,\n",
    "    \"iteration_time\": iteration_times_li,\n",
    "    \"gap\": gaps_li,\n",
    "    \"defender_actions_size\": defender_actions_sizes,\n",
    "    \"attacker_actions_size\": attacker_actions_sizes\n",
    "})\n",
    "\n",
    "# Step 2: Explode list columns\n",
    "exploded_df = df.explode([\"iteration_time\", \"gap\"], ignore_index=True)\n",
    "\n",
    "# Optional: Add a column for iteration number within each grouped trial\n",
    "exploded_df[\"iteration_number\"] = exploded_df.groupby(\n",
    "    [\"num_timesteps\", \"num_defenders\", \"num_clusters\", \"dims\", \"defense_time_threshold\"]\n",
    ").cumcount()\n",
    "\n",
    "# Reorder if desired\n",
    "cols = [\n",
    "    \"num_timesteps\", \"num_defenders\", \"num_clusters\", \"dims\", \"defense_time_threshold\",\n",
    "    \"iteration_number\", \"iteration_time\", \"gap\", \n",
    "    \"iterations_to_converge\", \"def_support\", \"defender_actions_size\", \"attacker_actions_size\"\n",
    "]\n",
    "exploded_df = exploded_df[cols]\n",
    "\n",
    "# Make iteration number 1-indexed\n",
    "exploded_df[\"iteration_number\"] += 1\n",
    "\n",
    "exploded_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "596cb259-0441-4796-b7f1-a3640f9f7dc4",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "exploded_df.to_csv(\"GSG_SF_DO_MASS_FINAL.csv\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c9cace84-c3eb-4f2a-ad78-ea3cc929abbd",
   "metadata": {
    "jupyter": {
     "source_hidden": true
    },
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "df = pd.read_csv(\"lobeke.csv\")\n",
    "df.dropna(inplace=True)\n",
    "\n",
    "# Lobeke National Park Bounding Box\n",
    "# lat_min, lon_min = 2.05522, 15.8790\n",
    "# lat_max, lon_max = 2.2837, 16.2038\n",
    "\n",
    "lat_min, lon_min = 2.0530, 15.8790\n",
    "lat_max, lon_max = 2.2837, 16.2038\n",
    "\n",
    "coordinate_rectangle = [lat_min, lat_max, lon_min, lon_max]\n",
    "\n",
    "schedule_form_kwargs = {\n",
    "    \"schedule_form\": True,\n",
    "    \"simple\": False,\n",
    "    \"attacker_penalty_factor\": 5,\n",
    "    \"defender_penalty_factor\": 5,\n",
    "    \"extra_coverage_weight\":1\n",
    "}\n",
    "\n",
    "general_sum_kwargs = {\n",
    "    \"general_sum\": False,\n",
    "    \"attacker_feature_value\":  42, \n",
    "    \"defender_feature_value\": 69, \n",
    "    \"defender_step_cost\": 32.5, \n",
    "}\n",
    "\n",
    "boulou_camp = (2.2,15.9)\n",
    "# lobeke_camp = (2.25,15.75)\n",
    "kabo_djembe = (2.0532352380408088, 16.085709866529694)\n",
    "bomassa = (2.2037280296158355, 16.187056364164913)\n",
    "inner_post = (2.2,15.98)\n",
    "num_timesteps_li = []\n",
    "supports=[]\n",
    "num_clusters_li = []\n",
    "dims_li = []\n",
    "dts = []\n",
    "defender_actions_sizes = []\n",
    "attacker_actions_sizes = []\n",
    "iterations_to_converge = []\n",
    "iteration_times_li = []\n",
    "gaps_li = []\n",
    "i=0\n",
    "for num_timesteps in [7,8,9,10]:\n",
    "    for num_clusters in [7,8,9,10,11,12]:\n",
    "        for dims in [7,8,9,10]:\n",
    "            for dt in [1,2]:\n",
    "                gsg = GreenSecurityGame(df, coordinate_rectangle, \"centroid\", num_clusters=num_clusters, num_rows=dims, num_columns=dims)\n",
    "                gsg.generate(num_attackers=1, num_defenders=3, home_base_assignments=[(kabo_djembe,), (bomassa,), (inner_post,)], num_timesteps=num_timesteps, generate_utility_matrix=False, defense_time_threshold=dt, generate_actions=False, force_return=True, general_sum=False, **schedule_form_kwargs)\n",
    "                D_a, D_d, u, A_a, A_d, c, iteration_times, gaps = double_oracle_sf(gsg.schedule_form_dict,eps=1e-12, verbose=False)\n",
    "                support = sum([1 for p in D_d if p!=0])\n",
    "                supports.append(support)\n",
    "                num_timesteps_li.append(num_timesteps)\n",
    "                num_clusters_li.append(num_clusters)\n",
    "                dims_li.append(dims)\n",
    "                dts.append(dt)\n",
    "                iterations_to_converge.append(c)\n",
    "                defender_actions_sizes.append(len(A_d))\n",
    "                attacker_actions_sizes.append(len(A_a))\n",
    "                iteration_times_li.append(iteration_times)\n",
    "                gaps_li.append(gaps)\n",
    "                print(f\"{i}/191: timesteps:{num_timesteps}, num_clusters:{num_clusters}, dims:{dims}, dt:{dt}, support:{support}\")\n",
    "                i+=1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7abd2416-6b83-452e-be32-961773a04713",
   "metadata": {},
   "outputs": [],
   "source": [
    "df = pd.DataFrame({\n",
    "    \"num_timesteps\": num_timesteps_li,\n",
    "    \"num_clusters\": num_clusters_li,\n",
    "    \"dims\": dims_li,\n",
    "    \"defense_time_threshold\": dts,\n",
    "    \"def_support\": supports,\n",
    "    \"iterations_to_converge\": iterations_to_converge,\n",
    "    \"iteration_time\": iteration_times_li,\n",
    "    \"gap\": gaps_li,\n",
    "    \"defender_actions_size\": defender_actions_sizes,\n",
    "    \"attacker_actions_size\": attacker_actions_sizes\n",
    "})\n",
    "\n",
    "# Step 2: Explode list columns\n",
    "exploded_df = df.explode([\"iteration_time\", \"gap\"], ignore_index=True)\n",
    "\n",
    "# Optional: Add a column for iteration number within each grouped trial\n",
    "exploded_df[\"iteration_number\"] = exploded_df.groupby(\n",
    "    [\"num_timesteps\", \"num_clusters\", \"dims\", \"defense_time_threshold\"]\n",
    ").cumcount()\n",
    "\n",
    "# Reorder if desired\n",
    "cols = [\n",
    "    \"num_timesteps\", \"num_clusters\", \"dims\", \"defense_time_threshold\",\n",
    "    \"iteration_number\", \"iteration_time\", \"gap\", \n",
    "    \"iterations_to_converge\", \"def_support\", \"defender_actions_size\", \"attacker_actions_size\"\n",
    "]\n",
    "exploded_df = exploded_df[cols]\n",
    "\n",
    "# Make iteration number 1-indexed\n",
    "exploded_df[\"iteration_number\"] += 1\n",
    "\n",
    "exploded_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "811859f6-ad09-44a3-b236-b6e684c009d2",
   "metadata": {
    "jupyter": {
     "source_hidden": true
    }
   },
   "outputs": [],
   "source": [
    "exploded_df.to_csv(\"GSG_SF_DO_3D_3_SEPARATE_HB.csv\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "0301663e-05a9-4190-85c0-9b6d1384bbf6",
   "metadata": {
    "jp-MarkdownHeadingCollapsed": true
   },
   "source": [
    "# GSG NR SF"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "4bccca6f-0490-4bd9-9c56-430e75284fe8",
   "metadata": {},
   "source": [
    "### Not iterating over dims and clusters in order to save time"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "cb603b8a-4d7e-45d8-99d7-08d08ad88a15",
   "metadata": {
    "jp-MarkdownHeadingCollapsed": true
   },
   "source": [
    "## RM (DONE)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "68a50b2a-f846-40f5-82e4-a882a7fd9d18",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "df = pd.read_csv(\"lobeke.csv\")\n",
    "df.dropna(inplace=True)\n",
    "\n",
    "# Lobeke National Park Bounding Box\n",
    "# lat_min, lon_min = 2.05522, 15.8790\n",
    "# lat_max, lon_max = 2.2837, 16.2038\n",
    "\n",
    "lat_min, lon_min = 2.0530, 15.8790\n",
    "lat_max, lon_max = 2.2837, 16.2038\n",
    "\n",
    "coordinate_rectangle = [lat_min, lat_max, lon_min, lon_max]\n",
    "\n",
    "schedule_form_kwargs = {\n",
    "    \"schedule_form\": True,\n",
    "    \"simple\": False,\n",
    "    \"attacker_penalty_factor\": 5,\n",
    "    \"defender_penalty_factor\": 5,\n",
    "    \"extra_coverage_weight\":1\n",
    "}\n",
    "\n",
    "general_sum_kwargs = {\n",
    "    \"general_sum\": False,\n",
    "    \"attacker_feature_value\":  42, \n",
    "    \"defender_feature_value\": 69, \n",
    "    \"defender_step_cost\": 32.5, \n",
    "}\n",
    "\n",
    "boulou_camp = (2.2,15.9)\n",
    "# lobeke_camp = (2.25,15.75)\n",
    "kabo_djembe = (2.0532352380408088, 16.085709866529694)\n",
    "bomassa = (2.2037280296158355, 16.187056364164913)\n",
    "inner_post = (2.2,15.98)\n",
    "\n",
    "srm_num_defenders_li = []\n",
    "srm_dts = []\n",
    "\n",
    "srm_gaps_li = []\n",
    "srm_interval_times_li = []\n",
    "srm_num_timesteps_li = []\n",
    "\n",
    "for num_timesteps in [7,8,9,10]:\n",
    "    for num_defenders in [1,2,3]:\n",
    "        for dt in [1,2]:\n",
    "            gsg = GreenSecurityGame(df, coordinate_rectangle, \"centroid\", num_clusters=10, num_rows=7, num_columns=7)\n",
    "            gsg.generate(num_attackers=1, num_defenders=num_defenders, home_base_assignments=[(kabo_djembe, bomassa, inner_post) for i in range(num_defenders)], num_timesteps=num_timesteps, generate_utility_matrix=True, defense_time_threshold=dt, generate_actions=False, force_return=True, general_sum=False, **schedule_form_kwargs)\n",
    "            D_d, U, gaps, interval_times = regret_matching(gsg.schedule_form_dict[\"defender_utility_matrix\"], runtime=120, interval=5, iterations=10000, averaging=0, alternations=False, plus=False, predictive=False, verbose=True)\n",
    "            srm_num_defenders_li.append(num_defenders)\n",
    "            srm_dts.append(dt)\n",
    "            srm_gaps_li.append(gaps)\n",
    "            srm_interval_times_li.append(interval_times)\n",
    "            srm_num_timesteps_li.append(num_timesteps)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c49a1f26-50c9-4d0a-9626-ad2d906fb7e8",
   "metadata": {},
   "outputs": [],
   "source": [
    "df = pd.DataFrame({\n",
    "    \"num_timesteps\": srm_num_timesteps_li,\n",
    "    \"num_attackers\": [1 for i in range(len(srm_num_timesteps_li))],\n",
    "    \"num_defenders\": srm_num_defenders_li,\n",
    "    \"defense_time_threshold\": srm_dts,\n",
    "    \"iteration_times\": srm_interval_times_li,\n",
    "    \"gaps\": srm_gaps_li\n",
    "})\n",
    "\n",
    "# Step 2: Explode list columns\n",
    "exploded_df = df.explode([\"iteration_times\", \"gaps\"], ignore_index=True)\n",
    "\n",
    "# Optional: Add a column for iteration number within each trial\n",
    "exploded_df[\"interval_number\"] = exploded_df.groupby([\"num_timesteps\",\"num_defenders\",\"defense_time_threshold\"]).cumcount()\n",
    "\n",
    "# Reorder if desired\n",
    "cols = [\"num_timesteps\", \"num_attackers\", \"num_defenders\", \"defense_time_threshold\", \"interval_number\", \"iteration_times\", \"gaps\"]\n",
    "exploded_df = exploded_df[cols]\n",
    "\n",
    "exploded_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6dce4c78-5f54-4c3b-aed1-102e4f244fd5",
   "metadata": {},
   "outputs": [],
   "source": [
    "exploded_df[\"interval_number\"] = exploded_df[\"interval_number\"]+1\n",
    "exploded_df[\"iteration_number\"] = exploded_df[\"interval_number\"]*5"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7ff4eb60-4455-46d4-8992-7290e625cb90",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "exploded_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c7d039f5-0310-424b-8df2-45ee306a39bb",
   "metadata": {},
   "outputs": [],
   "source": [
    "exploded_df.to_csv(\"GSG_SF_RM_FINAL_FIXED.csv\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "68560e0d-d908-48a6-8309-e95a6ed915f2",
   "metadata": {
    "jp-MarkdownHeadingCollapsed": true,
    "scrolled": true
   },
   "source": [
    "## RM+"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b8d7395d-ed5a-43dd-9b79-bde8bc26aecb",
   "metadata": {
    "jupyter": {
     "source_hidden": true
    },
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "df = pd.read_csv(\"lobeke.csv\")\n",
    "df.dropna(inplace=True)\n",
    "\n",
    "# Lobeke National Park Bounding Box\n",
    "# lat_min, lon_min = 2.05522, 15.8790\n",
    "# lat_max, lon_max = 2.2837, 16.2038\n",
    "\n",
    "lat_min, lon_min = 2.0530, 15.8790\n",
    "lat_max, lon_max = 2.2837, 16.2038\n",
    "\n",
    "coordinate_rectangle = [lat_min, lat_max, lon_min, lon_max]\n",
    "\n",
    "schedule_form_kwargs = {\n",
    "    \"schedule_form\": False,\n",
    "    \"simple\": True,\n",
    "    \"attacker_penalty_factor\": 3,\n",
    "    \"defender_penalty_factor\": 3,\n",
    "    \"extra_coverage_weight\":0.9\n",
    "}\n",
    "\n",
    "general_sum_kwargs = {\n",
    "    \"general_sum\": False,\n",
    "    \"attacker_feature_value\":  42, \n",
    "    \"defender_feature_value\": 69, \n",
    "    \"defender_step_cost\": 32.5, \n",
    "}\n",
    "\n",
    "boulou_camp = (2.2,15.9)\n",
    "# lobeke_camp = (2.25,15.75)\n",
    "kabo_djembe = (2.0532352380408088, 16.085709866529694)\n",
    "bomassa = (2.2037280296158355, 16.187056364164913)\n",
    "inner_post = (2.2,15.98)\n",
    "\n",
    "rmp_gaps_li = []\n",
    "rmp_interval_times_li = []\n",
    "rmp_num_timesteps_li = []\n",
    "\n",
    "for num_timesteps in [6,7,8,9,10]:\n",
    "    gsg = GreenSecurityGame(df, coordinate_rectangle, \"centroid\", num_clusters=10, num_rows=7, num_columns=7)\n",
    "    gsg.generate(num_attackers=2, num_defenders=1, home_base_assignments=[(kabo_djembe, bomassa, inner_post)], num_timesteps=num_timesteps, generate_utility_matrix=True, defense_time_threshold=1, generate_actions=False, force_return=False, general_sum=False, **schedule_form_kwargs)\n",
    "    D_d, U, gaps, interval_times = regret_matching(gsg.utility_matrix, runtime=120, interval=10, iterations=100000, averaging=0, alternations=False, plus=True, predictive=False, verbose=True)\n",
    "    rmp_gaps_li.append(gaps)\n",
    "    rmp_interval_times_li.append(interval_times)\n",
    "    rmp_num_timesteps_li.append(num_timesteps)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "b381432a-de24-4a24-9c21-2790896492dc",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration 5 gap:  0.31687595215627373\n",
      "Iteration 10 gap:  0.20777301323202896\n",
      "Iteration 15 gap:  0.17803934314075318\n",
      "Iteration 20 gap:  0.16566023143922892\n",
      "Iteration 25 gap:  0.14395172183433697\n",
      "Iteration 30 gap:  0.12468507298930051\n",
      "Iteration 35 gap:  0.10412862539030451\n",
      "Iteration 40 gap:  0.08232226835430681\n",
      "Iteration 45 gap:  0.07186266936773533\n",
      "Iteration 50 gap:  0.0616441384845855\n",
      "Iteration 55 gap:  0.05251603221879836\n",
      "Iteration 60 gap:  0.046871162647832754\n",
      "Iteration 65 gap:  0.043769319203725454\n",
      "Iteration 70 gap:  0.04162935464719225\n",
      "Iteration 75 gap:  0.03973220078951717\n",
      "Iteration 80 gap:  0.03855191839350319\n",
      "Iteration 85 gap:  0.03680266495346057\n",
      "Iteration 90 gap:  0.03456244200532199\n",
      "Iteration 95 gap:  0.031853437455921174\n",
      "Iteration 100 gap:  0.030327809371585468\n",
      "Iteration 105 gap:  0.028624201848512665\n",
      "Iteration 110 gap:  0.028801631998169763\n",
      "Iteration 115 gap:  0.029177199048942615\n",
      "Iteration 120 gap:  0.02935200100646529\n",
      "Iteration 125 gap:  0.029390292818669006\n",
      "Iteration 130 gap:  0.02941688050672442\n",
      "Iteration 135 gap:  0.028944560652580664\n",
      "Iteration 140 gap:  0.028008757860358613\n",
      "Iteration 145 gap:  0.02711629665346632\n",
      "Iteration 150 gap:  0.025640817435225616\n",
      "Iteration 155 gap:  0.02393858396768417\n",
      "Iteration 160 gap:  0.022153169163077413\n",
      "Iteration 165 gap:  0.021234235697971116\n",
      "Iteration 170 gap:  0.020178514185618224\n",
      "Iteration 175 gap:  0.019268448564003504\n",
      "Iteration 180 gap:  0.017831652227337125\n",
      "Iteration 185 gap:  0.01692683782387333\n",
      "Iteration 190 gap:  0.01609286562617207\n",
      "Iteration 195 gap:  0.015387376765071625\n",
      "Iteration 200 gap:  0.014377434627140528\n",
      "Iteration 205 gap:  0.013767003413156231\n",
      "Iteration 210 gap:  0.013167795887367995\n",
      "Iteration 215 gap:  0.012649731057172986\n",
      "Iteration 220 gap:  0.011899483278257572\n",
      "Iteration 225 gap:  0.011445516699557068\n",
      "Iteration 230 gap:  0.010982444882522258\n",
      "Iteration 235 gap:  0.010583826784794359\n",
      "Iteration 240 gap:  0.01001469721553272\n",
      "Iteration 245 gap:  0.009665117217034225\n",
      "Iteration 250 gap:  0.009295845285397453\n",
      "Iteration 255 gap:  0.008987614339821315\n",
      "Iteration 260 gap:  0.00854774597536273\n",
      "Iteration 265 gap:  0.008267259603993549\n",
      "Iteration 270 gap:  0.007969878366950067\n",
      "Iteration 275 gap:  0.0077327255864717\n",
      "Iteration 280 gap:  0.007380858423318648\n",
      "Iteration 285 gap:  0.007145442626651788\n",
      "Iteration 290 gap:  0.006911709960194079\n",
      "Iteration 295 gap:  0.006730821719471869\n",
      "Iteration 300 gap:  0.006434166093937432\n",
      "Iteration 305 gap:  0.0062295421128178985\n",
      "Iteration 310 gap:  0.006056007216837911\n",
      "Iteration 315 gap:  0.00591872134328475\n",
      "Iteration 320 gap:  0.005653450973320817\n",
      "Iteration 325 gap:  0.005473450079867215\n",
      "Iteration 330 gap:  0.005354985579368421\n",
      "Iteration 335 gap:  0.005249679745639002\n",
      "Iteration 340 gap:  0.005002352201505855\n",
      "Iteration 345 gap:  0.00484587804605463\n",
      "Iteration 350 gap:  0.00477251833884712\n",
      "Iteration 355 gap:  0.004688213061888324\n",
      "Iteration 360 gap:  0.004456840308842525\n",
      "Iteration 365 gap:  0.004324102446305267\n",
      "Iteration 370 gap:  0.004280100107218632\n",
      "Iteration 375 gap:  0.004207587668517088\n",
      "Iteration 380 gap:  0.003997771054308208\n",
      "Iteration 385 gap:  0.003887243341386515\n",
      "Iteration 390 gap:  0.0038571887193945\n",
      "Iteration 395 gap:  0.0037913553642730524\n",
      "Iteration 400 gap:  0.0036116469629293158\n",
      "Iteration 405 gap:  0.0035175101925583596\n",
      "Iteration 410 gap:  0.003489541818681441\n",
      "Iteration 415 gap:  0.0034323063450899527\n",
      "Iteration 420 gap:  0.0032812456736098783\n",
      "Iteration 425 gap:  0.0032010086627600742\n",
      "Iteration 430 gap:  0.0031681145991022674\n",
      "Iteration 435 gap:  0.003119259744503833\n",
      "Iteration 440 gap:  0.0029978102195002965\n",
      "Iteration 445 gap:  0.0029254599081226518\n",
      "Iteration 450 gap:  0.0028868654231525848\n",
      "Iteration 455 gap:  0.0028498437932047427\n",
      "Iteration 460 gap:  0.0027508007194886885\n",
      "Iteration 465 gap:  0.0026795733066095617\n",
      "Iteration 470 gap:  0.0026441950213551\n",
      "Iteration 475 gap:  0.0026194874530821033\n",
      "Iteration 480 gap:  0.0025303431927640174\n",
      "Iteration 485 gap:  0.0024593013918479123\n",
      "Iteration 490 gap:  0.0024320926574299406\n",
      "Iteration 495 gap:  0.002419629264287071\n",
      "Iteration 500 gap:  0.0023331234898782416\n",
      "Iteration 505 gap:  0.002260602029731218\n",
      "Iteration 510 gap:  0.002247979865407701\n",
      "Iteration 515 gap:  0.00224502718493641\n",
      "Iteration 520 gap:  0.002154886083915175\n",
      "Iteration 525 gap:  0.002085272689198503\n",
      "Iteration 530 gap:  0.0020863500978612892\n",
      "Iteration 535 gap:  0.0020885007968634572\n",
      "Iteration 540 gap:  0.001995371357866149\n",
      "Iteration 545 gap:  0.0019340530693735536\n",
      "Iteration 550 gap:  0.0019413417378899012\n",
      "Iteration 555 gap:  0.0019441224842488558\n",
      "Iteration 560 gap:  0.0018549394856205992\n",
      "Iteration 565 gap:  0.0018015570356849642\n",
      "Iteration 570 gap:  0.001807929543571174\n",
      "Iteration 575 gap:  0.0018093116363191442\n",
      "Iteration 580 gap:  0.0017328304803761463\n",
      "Iteration 585 gap:  0.001684095734549862\n",
      "Iteration 590 gap:  0.001683985626377893\n",
      "Iteration 595 gap:  0.0016862936953152552\n",
      "Iteration 600 gap:  0.0016249565021342893\n",
      "Iteration 605 gap:  0.0015784737856992526\n",
      "Iteration 610 gap:  0.0015699491504523877\n",
      "Iteration 615 gap:  0.001575840998074729\n",
      "Iteration 620 gap:  0.0015283826600970274\n",
      "Iteration 625 gap:  0.0014802561542907045\n",
      "Iteration 630 gap:  0.0014681012077898958\n",
      "Iteration 635 gap:  0.0014796403245305179\n",
      "Iteration 640 gap:  0.0014386583962162636\n",
      "Iteration 645 gap:  0.001388562526246584\n",
      "Iteration 650 gap:  0.0013771064830680468\n",
      "Iteration 655 gap:  0.0013951246385086602\n",
      "Iteration 660 gap:  0.0013545260530259395\n",
      "Iteration 665 gap:  0.0013023438047390923\n",
      "Iteration 670 gap:  0.001297084811311744\n",
      "Iteration 675 gap:  0.0013197319095591964\n",
      "Iteration 680 gap:  0.0012750895029187692\n",
      "Iteration 685 gap:  0.0012230832032884553\n",
      "Iteration 690 gap:  0.00122542608814169\n",
      "Iteration 695 gap:  0.0012492021471237624\n",
      "Iteration 700 gap:  0.0012021281677997986\n",
      "Iteration 705 gap:  0.0011518125353428\n",
      "Iteration 710 gap:  0.0011589251818821533\n",
      "Iteration 715 gap:  0.0011809312907847258\n",
      "Iteration 720 gap:  0.0011369996369976487\n",
      "Iteration 725 gap:  0.0010896246339314741\n",
      "Iteration 730 gap:  0.0010959153661014853\n",
      "Iteration 735 gap:  0.0011143778082156053\n",
      "Iteration 740 gap:  0.001079956238375257\n",
      "Iteration 745 gap:  0.0010364704297415872\n",
      "Iteration 750 gap:  0.0010392520684670559\n",
      "Iteration 755 gap:  0.0010520608382635355\n",
      "Iteration 760 gap:  0.001029115731815522\n",
      "Iteration 765 gap:  0.0009869568275735485\n",
      "Iteration 770 gap:  0.0009861489064402207\n",
      "Iteration 775 gap:  0.0009967333678836954\n",
      "Iteration 780 gap:  0.0009817000558016153\n",
      "Iteration 785 gap:  0.0009381188612637148\n",
      "Iteration 790 gap:  0.0009376963577424346\n",
      "Iteration 795 gap:  0.0009489510812135671\n",
      "Iteration 800 gap:  0.0009352074197294669\n",
      "Iteration 805 gap:  0.0008901807702719755\n",
      "Iteration 810 gap:  0.0008938670320240427\n",
      "Iteration 815 gap:  0.0009062811884925082\n",
      "Iteration 820 gap:  0.0008896603367505862\n",
      "Iteration 825 gap:  0.0008458544796572931\n",
      "Iteration 830 gap:  0.0008535612896835576\n",
      "Iteration 835 gap:  0.000865181186324171\n",
      "Iteration 840 gap:  0.0008470596032238986\n",
      "Iteration 845 gap:  0.0008059217769961213\n",
      "Iteration 850 gap:  0.0008157282595976922\n",
      "Iteration 855 gap:  0.0008246658021573983\n",
      "Iteration 860 gap:  0.0008082865091952884\n",
      "Iteration 865 gap:  0.0007717905835680772\n",
      "Iteration 870 gap:  0.0007788493516270312\n",
      "Iteration 875 gap:  0.0007839560196400974\n",
      "Iteration 880 gap:  0.000774293442740881\n",
      "Iteration 885 gap:  0.0007418302852795211\n",
      "Iteration 890 gap:  0.0007429541031023779\n",
      "Iteration 895 gap:  0.00074509057788541\n",
      "Iteration 900 gap:  0.0007436572999526825\n",
      "Iteration 905 gap:  0.0007135657708768894\n",
      "Iteration 910 gap:  0.0007085487288325809\n",
      "Iteration 915 gap:  0.0007103093794800786\n",
      "Iteration 920 gap:  0.0007145473393810886\n",
      "Iteration 925 gap:  0.0006849069248651141\n",
      "Iteration 930 gap:  0.0006766546677806629\n",
      "Iteration 935 gap:  0.0006802533857185322\n",
      "Iteration 940 gap:  0.0006852148556660276\n",
      "Iteration 945 gap:  0.0006558345831890744\n",
      "Iteration 950 gap:  0.0006475647580718724\n",
      "Iteration 955 gap:  0.0006533562361069056\n",
      "Iteration 960 gap:  0.0006556779462787432\n",
      "Iteration 965 gap:  0.000628477412665196\n",
      "Iteration 970 gap:  0.0006205442384339954\n",
      "Iteration 975 gap:  0.000626954879200281\n",
      "Iteration 980 gap:  0.0006276730908074679\n",
      "Iteration 985 gap:  0.0006049328978268709\n",
      "Iteration 990 gap:  0.000594192042032704\n",
      "Iteration 995 gap:  0.0005995051817479502\n",
      "Iteration 1000 gap:  0.0006028502360572174\n",
      "Iteration 1005 gap:  0.0005850882492777765\n",
      "Iteration 1010 gap:  0.0005680476857815031\n",
      "Iteration 1015 gap:  0.0005717426360944966\n",
      "Iteration 1020 gap:  0.0005809472677847372\n",
      "Iteration 1025 gap:  0.0005673074246569376\n",
      "Iteration 1030 gap:  0.0005435618951505905\n",
      "Iteration 1035 gap:  0.0005466991877554062\n",
      "Iteration 1040 gap:  0.000560259329877244\n",
      "Iteration 1045 gap:  0.0005489633169253882\n",
      "Iteration 1050 gap:  0.000522037275998144\n",
      "Iteration 1055 gap:  0.0005241916786839496\n",
      "Iteration 1060 gap:  0.0005401728831520569\n",
      "Iteration 1065 gap:  0.0005300333201218033\n",
      "Iteration 1070 gap:  0.0005033842133325694\n",
      "Iteration 1075 gap:  0.0005079373950030996\n",
      "Iteration 1080 gap:  0.0005194276860273628\n",
      "Iteration 1085 gap:  0.0005108961250323563\n",
      "Iteration 1090 gap:  0.0004870943344109646\n",
      "Iteration 1095 gap:  0.0004928290499575105\n",
      "Iteration 1100 gap:  0.0004985052718383121\n",
      "Iteration 1105 gap:  0.000492894178908132\n",
      "Iteration 1110 gap:  0.00047233748867159253\n",
      "Iteration 1115 gap:  0.0004774532628885053\n",
      "Iteration 1120 gap:  0.0004788823563646738\n",
      "Iteration 1125 gap:  0.00047760959197856723\n",
      "Iteration 1130 gap:  0.00045754139894560453\n",
      "Iteration 1135 gap:  0.00046118873310579955\n",
      "Iteration 1140 gap:  0.00046160665875333295\n",
      "Iteration 1145 gap:  0.0004646416541270737\n",
      "Iteration 1150 gap:  0.00044211814174333064\n",
      "Iteration 1155 gap:  0.00044477589144004126\n",
      "Iteration 1160 gap:  0.00044629191410844316\n",
      "Iteration 1165 gap:  0.00045213678675792845\n",
      "Iteration 1170 gap:  0.0004270232911193217\n",
      "Iteration 1175 gap:  0.00042954729294686356\n",
      "Iteration 1180 gap:  0.00043143161321357315\n",
      "Iteration 1185 gap:  0.000438333282836767\n",
      "Iteration 1190 gap:  0.00041386053424874447\n",
      "Iteration 1195 gap:  0.0004158688206051253\n",
      "Iteration 1200 gap:  0.00041587337245874156\n",
      "Iteration 1205 gap:  0.0004235537453794458\n",
      "Iteration 1210 gap:  0.0004026400923308193\n",
      "Iteration 1215 gap:  0.0004031780861012413\n",
      "Iteration 1220 gap:  0.0003997854526241462\n",
      "Iteration 1225 gap:  0.0004091280609085368\n",
      "Iteration 1230 gap:  0.0003927236788804911\n",
      "Iteration 1235 gap:  0.0003899358641149542\n",
      "Iteration 1240 gap:  0.0003850610741981675\n",
      "Iteration 1245 gap:  0.0003967699792503665\n",
      "Iteration 1250 gap:  0.00038253287390760393\n",
      "Iteration 1255 gap:  0.0003763340690656758\n",
      "Iteration 1260 gap:  0.0003717372184622314\n",
      "Iteration 1265 gap:  0.0003858800615413882\n",
      "Iteration 1270 gap:  0.00037191176728451625\n",
      "Iteration 1275 gap:  0.0003622826030849069\n",
      "Iteration 1280 gap:  0.0003629480078500835\n",
      "Iteration 1285 gap:  0.0003756898617625626\n",
      "Iteration 1290 gap:  0.00036099379654991326\n",
      "Iteration 1295 gap:  0.0003485686906505303\n",
      "Iteration 1300 gap:  0.0003545364485552649\n",
      "Iteration 1305 gap:  0.0003649494328440972\n",
      "Iteration 1310 gap:  0.000350681825664112\n",
      "Iteration 1315 gap:  0.00033606847797285067\n",
      "Iteration 1320 gap:  0.0003457803794220671\n",
      "Iteration 1325 gap:  0.00035292233977485266\n",
      "Iteration 1330 gap:  0.0003418354399246648\n",
      "Iteration 1335 gap:  0.0003246892225849951\n",
      "Iteration 1340 gap:  0.0003363517973049568\n",
      "Iteration 1345 gap:  0.0003405917180439588\n",
      "Iteration 1350 gap:  0.0003341663766091574\n",
      "Iteration 1355 gap:  0.0003145471452866144\n",
      "Iteration 1360 gap:  0.0003266783417394392\n",
      "Iteration 1365 gap:  0.0003295412140938425\n",
      "Iteration 1370 gap:  0.00032649223752867496\n",
      "Iteration 1375 gap:  0.00030621715263889904\n",
      "Iteration 1380 gap:  0.0003174338071091354\n",
      "Iteration 1385 gap:  0.0003202070559755743\n",
      "Iteration 1390 gap:  0.0003179114901956659\n",
      "Iteration 1395 gap:  0.0002977330862697358\n",
      "Iteration 1400 gap:  0.00030865038350508245\n",
      "Iteration 1405 gap:  0.0003112831844645503\n",
      "Iteration 1410 gap:  0.0003090047426737019\n",
      "Iteration 1415 gap:  0.0002897503229578047\n",
      "Iteration 1420 gap:  0.0003000080716346609\n",
      "Iteration 1425 gap:  0.000301935925308916\n",
      "Iteration 1430 gap:  0.00030047655755455205\n",
      "Iteration 1435 gap:  0.00028350477078925573\n",
      "Iteration 1440 gap:  0.00029082285357900917\n",
      "Iteration 1445 gap:  0.00029169266097273105\n",
      "Iteration 1450 gap:  0.0002931002060246324\n",
      "Iteration 1455 gap:  0.0002784394342902896\n",
      "Iteration 1460 gap:  0.000281296529281827\n",
      "Iteration 1465 gap:  0.0002813176288781194\n",
      "Iteration 1470 gap:  0.0002862928895990269\n",
      "Iteration 1475 gap:  0.00027352254706258794\n",
      "Iteration 1480 gap:  0.0002715502436627659\n",
      "Iteration 1485 gap:  0.0002719336666702765\n",
      "Iteration 1490 gap:  0.000279482835474687\n",
      "Iteration 1495 gap:  0.00026794720708228636\n",
      "Iteration 1500 gap:  0.00026207872351818873\n",
      "Iteration 1505 gap:  0.0002637814876648714\n",
      "Iteration 1510 gap:  0.0002720020449585303\n",
      "Iteration 1515 gap:  0.00026178701104334623\n",
      "Iteration 1520 gap:  0.0002531462842912946\n",
      "Iteration 1525 gap:  0.0002563298096708855\n",
      "Iteration 1530 gap:  0.00026402237066869283\n",
      "Iteration 1535 gap:  0.000256042420255842\n",
      "Iteration 1540 gap:  0.0002446699418396925\n",
      "Iteration 1545 gap:  0.00024993998485139945\n",
      "Iteration 1550 gap:  0.000256400524086986\n",
      "Iteration 1555 gap:  0.00025145354489480853\n",
      "Iteration 1560 gap:  0.00023920816693961955\n",
      "Iteration 1565 gap:  0.0002448012975541092\n",
      "Iteration 1570 gap:  0.00024968247010626055\n",
      "Iteration 1575 gap:  0.00024766415356103355\n",
      "Iteration 1580 gap:  0.00023347398665479746\n",
      "Iteration 1585 gap:  0.00023942028677209626\n",
      "Iteration 1590 gap:  0.00024349323857941751\n",
      "Iteration 1595 gap:  0.0002435753610664504\n",
      "Iteration 1600 gap:  0.00022808326593620754\n",
      "Iteration 1605 gap:  0.00023435101519320156\n",
      "Iteration 1610 gap:  0.0002370760213282752\n",
      "Iteration 1615 gap:  0.00023860253618052107\n",
      "Iteration 1620 gap:  0.00022374054263368803\n",
      "Iteration 1625 gap:  0.00022951301685047998\n",
      "Iteration 1630 gap:  0.00023017096253036273\n",
      "Iteration 1635 gap:  0.00023340487638656704\n",
      "Iteration 1640 gap:  0.0002199128584308152\n",
      "Iteration 1645 gap:  0.00022464693673368563\n",
      "Iteration 1650 gap:  0.00022306233617902516\n",
      "Iteration 1655 gap:  0.00022829389964801328\n",
      "Iteration 1660 gap:  0.00021642510236613566\n",
      "Iteration 1665 gap:  0.00021917230262741283\n",
      "Iteration 1670 gap:  0.00021644335096010492\n",
      "Iteration 1675 gap:  0.00022395830359595026\n",
      "Iteration 1680 gap:  0.00021263583377939543\n",
      "Iteration 1685 gap:  0.00021307431882527927\n",
      "Iteration 1690 gap:  0.00021048328889383683\n",
      "Iteration 1695 gap:  0.0002199807311729085\n",
      "Iteration 1700 gap:  0.00020850120307508435\n",
      "Iteration 1705 gap:  0.00020676076657533127\n",
      "Iteration 1710 gap:  0.00020546595469483897\n",
      "Iteration 1715 gap:  0.00021559428502249123\n",
      "Iteration 1720 gap:  0.00020454863520757982\n",
      "Iteration 1725 gap:  0.00020072404344523287\n",
      "Iteration 1730 gap:  0.00020281587670678558\n",
      "Iteration 1735 gap:  0.00021039511645698505\n",
      "Iteration 1740 gap:  0.000201216691838646\n",
      "Iteration 1745 gap:  0.0001949820403847613\n",
      "Iteration 1750 gap:  0.00019959854257550758\n",
      "Iteration 1755 gap:  0.00020486484723136744\n",
      "Iteration 1760 gap:  0.00019835772699577925\n",
      "Iteration 1765 gap:  0.00018906078373037705\n",
      "Iteration 1770 gap:  0.00019602041368477208\n",
      "Iteration 1775 gap:  0.0001998090160644228\n",
      "Iteration 1780 gap:  0.00019533840469326824\n",
      "Iteration 1785 gap:  0.0001826601715331222\n",
      "Iteration 1790 gap:  0.00019236380781950668\n",
      "Iteration 1795 gap:  0.00019533907225732783\n",
      "Iteration 1800 gap:  0.0001918317635934974\n",
      "Iteration 1805 gap:  0.00017749246671022734\n",
      "Iteration 1810 gap:  0.0001885939061986308\n",
      "Iteration 1815 gap:  0.00019077970892455998\n",
      "Iteration 1820 gap:  0.0001881898424787587\n",
      "Iteration 1825 gap:  0.00017426968176742497\n",
      "Iteration 1830 gap:  0.00018461046962126026\n",
      "Iteration 1835 gap:  0.00018586789969010642\n",
      "Iteration 1840 gap:  0.00018460308535311887\n",
      "Iteration 1845 gap:  0.0001718887981924655\n",
      "Iteration 1850 gap:  0.00018009868595036949\n",
      "Iteration 1855 gap:  0.00018043446094889726\n",
      "Iteration 1860 gap:  0.0001814384519780443\n",
      "Iteration 1865 gap:  0.0001700246052922516\n",
      "Iteration 1870 gap:  0.00017515470665241395\n",
      "Iteration 1875 gap:  0.0001750029161993738\n",
      "Iteration 1880 gap:  0.0001783482606498299\n",
      "Iteration 1885 gap:  0.0001680629251804011\n",
      "Iteration 1890 gap:  0.00016997025065673688\n",
      "Iteration 1895 gap:  0.00017010694918545566\n",
      "Iteration 1900 gap:  0.0001749566654480894\n",
      "Iteration 1905 gap:  0.000165748609355032\n",
      "Iteration 1910 gap:  0.0001647859853897704\n",
      "Iteration 1915 gap:  0.00016565380703525978\n",
      "Iteration 1920 gap:  0.00017111345622894403\n",
      "Iteration 1925 gap:  0.00016338959236028572\n",
      "Iteration 1930 gap:  0.00015960668912445852\n",
      "Iteration 1935 gap:  0.00016118048084351466\n",
      "Iteration 1940 gap:  0.00016714416930169174\n",
      "Iteration 1945 gap:  0.00016147624909268465\n",
      "Iteration 1950 gap:  0.0001542279821304393\n",
      "Iteration 1955 gap:  0.000157737938387692\n",
      "Iteration 1960 gap:  0.00016344874476709181\n",
      "Iteration 1965 gap:  0.00016002848169993644\n",
      "Iteration 1970 gap:  0.00015051069528565497\n",
      "Iteration 1975 gap:  0.00015569671774057214\n",
      "Iteration 1980 gap:  0.00016001204058080365\n",
      "Iteration 1985 gap:  0.00015855696206412695\n",
      "Iteration 1990 gap:  0.00014792298660915026\n",
      "Iteration 1995 gap:  0.0001535526850044433\n",
      "Iteration 2000 gap:  0.00015647335610458057\n",
      "Iteration 2005 gap:  0.0001566026273566723\n",
      "Iteration 2010 gap:  0.00014586743979294603\n",
      "Iteration 2015 gap:  0.0001513109289096315\n",
      "Iteration 2020 gap:  0.0001526438926424678\n",
      "Iteration 2025 gap:  0.00015445038675132583\n",
      "Iteration 2030 gap:  0.00014407465425558819\n",
      "Iteration 2035 gap:  0.00014894080965710543\n",
      "Iteration 2040 gap:  0.00014860784019782303\n",
      "Iteration 2045 gap:  0.00015207158149255218\n",
      "Iteration 2050 gap:  0.00014256554035879665\n",
      "Iteration 2055 gap:  0.00014616119621274626\n",
      "Iteration 2060 gap:  0.00014465658032913886\n",
      "Iteration 2065 gap:  0.00014988601265353285\n",
      "Iteration 2070 gap:  0.00014101767674262744\n",
      "Iteration 2075 gap:  0.00014289907531567225\n",
      "Iteration 2080 gap:  0.0001409417381031397\n",
      "Iteration 2085 gap:  0.00014784784031723897\n",
      "Iteration 2090 gap:  0.00013930845233561806\n",
      "Iteration 2095 gap:  0.00013924300473866502\n",
      "Iteration 2100 gap:  0.00013750264574285964\n",
      "Iteration 2105 gap:  0.00014563986090232461\n",
      "Iteration 2110 gap:  0.00013754958593292788\n",
      "Iteration 2115 gap:  0.0001354851293443593\n",
      "Iteration 2120 gap:  0.00013673349655835\n",
      "Iteration 2125 gap:  0.00014294076748372353\n",
      "Iteration 2130 gap:  0.00013602423616904114\n",
      "Iteration 2135 gap:  0.00013174839158358598\n",
      "Iteration 2140 gap:  0.0001355120168083923\n",
      "Iteration 2145 gap:  0.0001398747279700019\n",
      "Iteration 2150 gap:  0.0001347328830582084\n",
      "Iteration 2155 gap:  0.00012786961089428228\n",
      "Iteration 2160 gap:  0.00013387436351242066\n",
      "Iteration 2165 gap:  0.00013684871760050177\n",
      "Iteration 2170 gap:  0.0001333802882699242\n",
      "Iteration 2175 gap:  0.00012368061280360054\n",
      "Iteration 2180 gap:  0.00013195834979989884\n",
      "Iteration 2185 gap:  0.00013403363738589968\n",
      "Iteration 2190 gap:  0.00013173836375346415\n",
      "Iteration 2195 gap:  0.00012085075920836852\n",
      "Iteration 2200 gap:  0.00012976661340324824\n",
      "Iteration 2205 gap:  0.00013108280495638391\n",
      "Iteration 2210 gap:  0.00012996600946918457\n",
      "Iteration 2215 gap:  0.00011938337064032467\n",
      "Iteration 2220 gap:  0.00012729927514631978\n",
      "Iteration 2225 gap:  0.0001280087922125861\n",
      "Iteration 2230 gap:  0.00012804884204303812\n",
      "Iteration 2235 gap:  0.00011835593413311862\n",
      "Iteration 2240 gap:  0.00012437861717179421\n",
      "Iteration 2245 gap:  0.0001246658035385373\n",
      "Iteration 2250 gap:  0.0001262367478593318\n",
      "Iteration 2255 gap:  0.00011761217137479241\n",
      "Iteration 2260 gap:  0.0001211441055264384\n",
      "Iteration 2265 gap:  0.00012120363407192025\n",
      "Iteration 2270 gap:  0.0001243627420151605\n",
      "Iteration 2275 gap:  0.00011698345133870358\n",
      "Iteration 2280 gap:  0.00011759844267122954\n",
      "Iteration 2285 gap:  0.0001178776817755689\n",
      "Iteration 2290 gap:  0.00012235750077976837\n",
      "Iteration 2295 gap:  0.00011625828379768777\n",
      "Iteration 2300 gap:  0.00011384526881974555\n",
      "Iteration 2305 gap:  0.00011471285538838805\n",
      "Iteration 2310 gap:  0.00012015495070927251\n",
      "Iteration 2315 gap:  0.00011545602702761615\n",
      "Iteration 2320 gap:  0.00010999268758410397\n",
      "Iteration 2325 gap:  0.00011253156295493172\n",
      "Iteration 2330 gap:  0.00011775837966337965\n",
      "Iteration 2335 gap:  0.00011466117563468936\n",
      "Iteration 2340 gap:  0.00010729187865632372\n",
      "Iteration 2345 gap:  0.0001119058150848562\n",
      "Iteration 2350 gap:  0.00011526433835523653\n",
      "Iteration 2355 gap:  0.00011392899499790277\n",
      "Iteration 2360 gap:  0.00010612646173735474\n",
      "Iteration 2365 gap:  0.00011090844442229741\n",
      "Iteration 2370 gap:  0.00011280281905406975\n",
      "Iteration 2375 gap:  0.00011322344946085305\n",
      "Iteration 2380 gap:  0.00010503612387763317\n",
      "Iteration 2385 gap:  0.00010958942622329992\n",
      "Iteration 2390 gap:  0.00011033075790473079\n",
      "Iteration 2395 gap:  0.00011236364999789306\n",
      "Iteration 2400 gap:  0.00010407832672965078\n",
      "Iteration 2405 gap:  0.00010800726767801194\n",
      "Iteration 2410 gap:  0.00010779557822865327\n",
      "Iteration 2415 gap:  0.00011124950084462348\n",
      "Iteration 2420 gap:  0.00010330289304660845\n",
      "Iteration 2425 gap:  0.00010618680926788304\n",
      "Iteration 2430 gap:  0.0001051410799108865\n",
      "Iteration 2435 gap:  0.00010992941308518578\n",
      "Iteration 2440 gap:  0.00010267203439190409\n",
      "Iteration 2445 gap:  0.00010401058214370984\n",
      "Iteration 2450 gap:  0.00010257358297838248\n",
      "Iteration 2455 gap:  0.00010852054670001943\n",
      "Iteration 2460 gap:  0.00010205015962350128\n",
      "Iteration 2465 gap:  0.00010155856323207368\n",
      "Iteration 2470 gap:  0.00010116524214831557\n",
      "Iteration 2475 gap:  0.00010695516089681556\n",
      "Iteration 2480 gap:  0.00010141860576168282\n",
      "Iteration 2485 gap:  9.885619341271079e-05\n",
      "Iteration 2490 gap:  0.00010086313602242214\n",
      "Iteration 2495 gap:  0.00010527839894902691\n",
      "Iteration 2500 gap:  0.00010072380729331254\n",
      "Iteration 2505 gap:  9.593560625553721e-05\n",
      "Iteration 2510 gap:  0.00010024474516207027\n",
      "Iteration 2515 gap:  0.00010342374869753979\n",
      "Iteration 2520 gap:  9.998273747607866e-05\n",
      "Iteration 2525 gap:  9.282906555241333e-05\n",
      "Iteration 2530 gap:  9.930407417502174e-05\n",
      "Iteration 2535 gap:  0.00010142709741989275\n",
      "Iteration 2540 gap:  9.914045143105676e-05\n",
      "Iteration 2545 gap:  9.017883210749034e-05\n",
      "Iteration 2550 gap:  9.802617601067931e-05\n",
      "Iteration 2555 gap:  9.929812481479505e-05\n",
      "Iteration 2560 gap:  9.817575219128738e-05\n",
      "Iteration 2565 gap:  8.955966515422631e-05\n",
      "Iteration 2570 gap:  9.633810046044688e-05\n",
      "Iteration 2575 gap:  9.699554109127151e-05\n",
      "Iteration 2580 gap:  9.718766752353503e-05\n",
      "Iteration 2585 gap:  8.916119856400284e-05\n",
      "Iteration 2590 gap:  9.4306174776293e-05\n",
      "Iteration 2595 gap:  9.457939274892802e-05\n",
      "Iteration 2600 gap:  9.608590182602628e-05\n",
      "Iteration 2605 gap:  8.889849732574007e-05\n",
      "Iteration 2610 gap:  9.194520887861879e-05\n",
      "Iteration 2615 gap:  9.211270861592125e-05\n",
      "Iteration 2620 gap:  9.486426497790079e-05\n",
      "Iteration 2625 gap:  8.870243274033962e-05\n",
      "Iteration 2630 gap:  8.9315517703914e-05\n",
      "Iteration 2635 gap:  8.971209547614656e-05\n",
      "Iteration 2640 gap:  9.347498365191997e-05\n",
      "Iteration 2645 gap:  8.849786264802928e-05\n",
      "Iteration 2650 gap:  8.645087240788385e-05\n",
      "Iteration 2655 gap:  8.732587648602186e-05\n",
      "Iteration 2660 gap:  9.195509972809157e-05\n",
      "Iteration 2665 gap:  8.832200376102106e-05\n",
      "Iteration 2670 gap:  8.341965868979839e-05\n",
      "Iteration 2675 gap:  8.604040187687456e-05\n",
      "Iteration 2680 gap:  9.030424679212778e-05\n",
      "Iteration 2685 gap:  8.812436055227746e-05\n",
      "Iteration 2690 gap:  8.184959580348483e-05\n",
      "Iteration 2695 gap:  8.581067758495209e-05\n",
      "Iteration 2700 gap:  8.855867459461875e-05\n",
      "Iteration 2705 gap:  8.788616502741764e-05\n",
      "Iteration 2710 gap:  8.123807027154983e-05\n",
      "Iteration 2715 gap:  8.52692766065144e-05\n",
      "Iteration 2720 gap:  8.674870605024365e-05\n",
      "Iteration 2725 gap:  8.757594643293842e-05\n",
      "Iteration 2730 gap:  8.073921131229733e-05\n",
      "Iteration 2735 gap:  8.441594318236989e-05\n",
      "Iteration 2740 gap:  8.488102486703397e-05\n",
      "Iteration 2745 gap:  8.712358828805167e-05\n",
      "Iteration 2750 gap:  8.033811060614848e-05\n",
      "Iteration 2755 gap:  8.327302597610498e-05\n",
      "Iteration 2760 gap:  8.295017823500839e-05\n",
      "Iteration 2765 gap:  8.647363576369527e-05\n",
      "Iteration 2770 gap:  8.002732778394916e-05\n",
      "Iteration 2775 gap:  8.18552029320796e-05\n",
      "Iteration 2780 gap:  8.097087286940141e-05\n",
      "Iteration 2785 gap:  8.56077174083425e-05\n",
      "Iteration 2790 gap:  7.981048943950242e-05\n",
      "Iteration 2795 gap:  8.012690800884847e-05\n",
      "Iteration 2800 gap:  7.903602822162403e-05\n",
      "Iteration 2805 gap:  8.459318826803397e-05\n",
      "Iteration 2810 gap:  7.960918983018761e-05\n",
      "Iteration 2815 gap:  7.814525882782197e-05\n",
      "Iteration 2820 gap:  7.915755358772758e-05\n",
      "Iteration 2825 gap:  8.340883975044289e-05\n",
      "Iteration 2830 gap:  7.937973804644782e-05\n",
      "Iteration 2835 gap:  7.59264282372274e-05\n",
      "Iteration 2840 gap:  7.901184675856987e-05\n",
      "Iteration 2845 gap:  8.212416945913015e-05\n",
      "Iteration 2850 gap:  7.905800223428905e-05\n",
      "Iteration 2855 gap:  7.351974043895426e-05\n",
      "Iteration 2860 gap:  7.85321274224815e-05\n",
      "Iteration 2865 gap:  8.068610308281654e-05\n",
      "Iteration 2870 gap:  7.865581717775294e-05\n",
      "Iteration 2875 gap:  7.113021065074943e-05\n",
      "Iteration 2880 gap:  7.773872623306755e-05\n",
      "Iteration 2885 gap:  7.91162590083605e-05\n",
      "Iteration 2890 gap:  7.812265046969191e-05\n",
      "Iteration 2895 gap:  7.07118114884886e-05\n",
      "Iteration 2900 gap:  7.662447278333762e-05\n",
      "Iteration 2905 gap:  7.74384780682369e-05\n",
      "Iteration 2910 gap:  7.744267859149945e-05\n",
      "Iteration 2915 gap:  7.055934109478912e-05\n",
      "Iteration 2920 gap:  7.511342671379095e-05\n",
      "Iteration 2925 gap:  7.558697886278498e-05\n",
      "Iteration 2930 gap:  7.67305589070566e-05\n",
      "Iteration 2935 gap:  7.057735992033187e-05\n",
      "Iteration 2940 gap:  7.329669826500185e-05\n",
      "Iteration 2945 gap:  7.361756389684393e-05\n",
      "Iteration 2950 gap:  7.590213436498017e-05\n",
      "Iteration 2955 gap:  7.069966119671589e-05\n",
      "Iteration 2960 gap:  7.11872400819824e-05\n",
      "Iteration 2965 gap:  7.165481457427347e-05\n",
      "Iteration 2970 gap:  7.494625244436337e-05\n",
      "Iteration 2975 gap:  7.082073088643392e-05\n",
      "Iteration 2980 gap:  6.883967141241287e-05\n",
      "Iteration 2985 gap:  6.974926382835589e-05\n",
      "Iteration 2990 gap:  7.38437558028271e-05\n",
      "Iteration 2995 gap:  7.089502016910387e-05\n",
      "Iteration 3000 gap:  6.632006962181691e-05\n",
      "Iteration 3005 gap:  6.887027770485776e-05\n",
      "Iteration 3010 gap:  7.260402811348765e-05\n",
      "Iteration 3015 gap:  7.092178635392798e-05\n",
      "Iteration 3020 gap:  6.552558048195101e-05\n",
      "Iteration 3025 gap:  6.888048753550535e-05\n",
      "Iteration 3030 gap:  7.122679642002083e-05\n",
      "Iteration 3035 gap:  7.08924340349637e-05\n",
      "Iteration 3040 gap:  6.52313474359123e-05\n",
      "Iteration 3045 gap:  6.859256028396432e-05\n",
      "Iteration 3050 gap:  6.977360953447365e-05\n",
      "Iteration 3055 gap:  7.07851862622455e-05\n",
      "Iteration 3060 gap:  6.50282016106396e-05\n",
      "Iteration 3065 gap:  6.799127518358761e-05\n",
      "Iteration 3070 gap:  6.826916046370757e-05\n",
      "Iteration 3075 gap:  7.05589120617578e-05\n",
      "Iteration 3080 gap:  6.489492099509553e-05\n",
      "Iteration 3085 gap:  6.708150813278246e-05\n",
      "Iteration 3090 gap:  6.673288777853115e-05\n",
      "Iteration 3095 gap:  7.016618518262963e-05\n",
      "Iteration 3100 gap:  6.482761363951761e-05\n",
      "Iteration 3105 gap:  6.588018500641724e-05\n",
      "Iteration 3110 gap:  6.518326606896885e-05\n",
      "Iteration 3115 gap:  6.958747734020498e-05\n",
      "Iteration 3120 gap:  6.480387624058226e-05\n",
      "Iteration 3125 gap:  6.441504226528671e-05\n",
      "Iteration 3130 gap:  6.424572507807147e-05\n",
      "Iteration 3135 gap:  6.882220935583439e-05\n",
      "Iteration 3140 gap:  6.479258069563842e-05\n",
      "Iteration 3145 gap:  6.271254273643168e-05\n",
      "Iteration 3150 gap:  6.449083623050189e-05\n",
      "Iteration 3155 gap:  6.788469513252515e-05\n",
      "Iteration 3160 gap:  6.47431169545909e-05\n",
      "Iteration 3165 gap:  6.08210898703776e-05\n",
      "Iteration 3170 gap:  6.439728367729769e-05\n",
      "Iteration 3175 gap:  6.679364219586148e-05\n",
      "Iteration 3180 gap:  6.463950280571895e-05\n",
      "Iteration 3185 gap:  5.875960790524548e-05\n",
      "Iteration 3190 gap:  6.397665592561275e-05\n",
      "Iteration 3195 gap:  6.557121933065124e-05\n",
      "Iteration 3200 gap:  6.443419685547846e-05\n",
      "Iteration 3205 gap:  5.79898626837938e-05\n",
      "Iteration 3210 gap:  6.324427541681832e-05\n",
      "Iteration 3215 gap:  6.426167077416833e-05\n",
      "Iteration 3220 gap:  6.406494387184436e-05\n",
      "Iteration 3225 gap:  5.784562071653454e-05\n",
      "Iteration 3230 gap:  6.22109482603661e-05\n",
      "Iteration 3235 gap:  6.287450057496091e-05\n",
      "Iteration 3240 gap:  6.353300860767463e-05\n",
      "Iteration 3245 gap:  5.793497964728944e-05\n",
      "Iteration 3250 gap:  6.08088021537001e-05\n",
      "Iteration 3255 gap:  6.132775357658993e-05\n",
      "Iteration 3260 gap:  6.295716467824564e-05\n",
      "Iteration 3265 gap:  5.8161033864578826e-05\n",
      "Iteration 3270 gap:  5.913518919248295e-05\n",
      "Iteration 3275 gap:  5.966607794660739e-05\n",
      "Iteration 3280 gap:  6.227314343376644e-05\n",
      "Iteration 3285 gap:  5.8476491626879845e-05\n",
      "Iteration 3290 gap:  5.720963628602638e-05\n",
      "Iteration 3295 gap:  5.802664814513747e-05\n",
      "Iteration 3300 gap:  6.147295450881218e-05\n",
      "Iteration 3305 gap:  5.877119789732266e-05\n",
      "Iteration 3310 gap:  5.507713673225112e-05\n",
      "Iteration 3315 gap:  5.686478509764337e-05\n",
      "Iteration 3320 gap:  6.0541276710179837e-05\n",
      "Iteration 3325 gap:  5.8967781547181186e-05\n",
      "Iteration 3330 gap:  5.425189286406562e-05\n",
      "Iteration 3335 gap:  5.7037292711004106e-05\n",
      "Iteration 3340 gap:  5.948046285186859e-05\n",
      "Iteration 3345 gap:  5.9061936774296164e-05\n",
      "Iteration 3350 gap:  5.411664217186418e-05\n",
      "Iteration 3355 gap:  5.69618565579022e-05\n",
      "Iteration 3360 gap:  5.828483162390041e-05\n",
      "Iteration 3365 gap:  5.907942265193089e-05\n",
      "Iteration 3370 gap:  5.4075197118697016e-05\n",
      "Iteration 3375 gap:  5.6593937265203564e-05\n",
      "Iteration 3380 gap:  5.701997862816999e-05\n",
      "Iteration 3385 gap:  5.8985024454560886e-05\n",
      "Iteration 3390 gap:  5.411239043906502e-05\n",
      "Iteration 3395 gap:  5.590884630896076e-05\n",
      "Iteration 3400 gap:  5.574056860041532e-05\n",
      "Iteration 3405 gap:  5.878626702943146e-05\n",
      "Iteration 3410 gap:  5.416690893389475e-05\n",
      "Iteration 3415 gap:  5.491861595907643e-05\n",
      "Iteration 3420 gap:  5.4463666241844066e-05\n",
      "Iteration 3425 gap:  5.8416191989929533e-05\n",
      "Iteration 3430 gap:  5.4244690586402466e-05\n",
      "Iteration 3435 gap:  5.368225443824759e-05\n",
      "Iteration 3440 gap:  5.370396428544533e-05\n",
      "Iteration 3445 gap:  5.7846135455896786e-05\n",
      "Iteration 3450 gap:  5.432974028074522e-05\n",
      "Iteration 3455 gap:  5.222700060819596e-05\n",
      "Iteration 3460 gap:  5.40283362635563e-05\n",
      "Iteration 3465 gap:  5.709064460279745e-05\n",
      "Iteration 3470 gap:  5.439853260202909e-05\n",
      "Iteration 3475 gap:  5.057764246046981e-05\n",
      "Iteration 3480 gap:  5.4038549103352373e-05\n",
      "Iteration 3485 gap:  5.617985424272165e-05\n",
      "Iteration 3490 gap:  5.44040825193326e-05\n",
      "Iteration 3495 gap:  4.877212887166582e-05\n",
      "Iteration 3500 gap:  5.372177883145035e-05\n",
      "Iteration 3505 gap:  5.514332223394147e-05\n",
      "Iteration 3510 gap:  5.431022977303579e-05\n",
      "Iteration 3515 gap:  4.8651267432253675e-05\n",
      "Iteration 3520 gap:  5.309767256850284e-05\n",
      "Iteration 3525 gap:  5.401502435631311e-05\n",
      "Iteration 3530 gap:  5.407099143511784e-05\n",
      "Iteration 3535 gap:  4.8721007715135656e-05\n",
      "Iteration 3540 gap:  5.2147076538833215e-05\n",
      "Iteration 3545 gap:  5.2805714111647806e-05\n",
      "Iteration 3550 gap:  5.37104668305588e-05\n",
      "Iteration 3555 gap:  4.893676317696549e-05\n",
      "Iteration 3560 gap:  5.089654575413105e-05\n",
      "Iteration 3565 gap:  5.1492201518843483e-05\n",
      "Iteration 3570 gap:  5.323296154707835e-05\n",
      "Iteration 3575 gap:  4.924793951910367e-05\n",
      "Iteration 3580 gap:  4.9384033594723764e-05\n",
      "Iteration 3585 gap:  5.0081011240765694e-05\n",
      "Iteration 3590 gap:  5.265416070870943e-05\n",
      "Iteration 3595 gap:  4.963405598229498e-05\n",
      "Iteration 3600 gap:  4.76506398739418e-05\n",
      "Iteration 3605 gap:  4.8681128264727036e-05\n",
      "Iteration 3610 gap:  5.196665069207018e-05\n",
      "Iteration 3615 gap:  5.000969878637962e-05\n",
      "Iteration 3620 gap:  4.6137065001783384e-05\n",
      "Iteration 3625 gap:  4.825930724877692e-05\n",
      "Iteration 3630 gap:  5.1163428731293425e-05\n",
      "Iteration 3635 gap:  5.028465390377601e-05\n",
      "Iteration 3640 gap:  4.5957083905423524e-05\n",
      "Iteration 3645 gap:  4.83837343862592e-05\n",
      "Iteration 3650 gap:  5.026576824745943e-05\n",
      "Iteration 3655 gap:  5.044143469812301e-05\n",
      "Iteration 3660 gap:  4.596525835659504e-05\n",
      "Iteration 3665 gap:  4.8265861501639584e-05\n",
      "Iteration 3670 gap:  4.923796042294315e-05\n",
      "Iteration 3675 gap:  5.049895249364944e-05\n",
      "Iteration 3680 gap:  4.604291149762352e-05\n",
      "Iteration 3685 gap:  4.789632594404125e-05\n",
      "Iteration 3690 gap:  4.811752685485171e-05\n",
      "Iteration 3695 gap:  5.038587040406828e-05\n",
      "Iteration 3700 gap:  4.621605909782556e-05\n",
      "Iteration 3705 gap:  4.720709337202589e-05\n",
      "Iteration 3710 gap:  4.701075504315311e-05\n",
      "Iteration 3715 gap:  5.018689554320277e-05\n",
      "Iteration 3720 gap:  4.6386528718300735e-05\n",
      "Iteration 3725 gap:  4.624898450095172e-05\n",
      "Iteration 3730 gap:  4.5893959296883224e-05\n",
      "Iteration 3735 gap:  4.983937912106384e-05\n",
      "Iteration 3740 gap:  4.654503034468016e-05\n",
      "Iteration 3745 gap:  4.5038519537798916e-05\n",
      "Iteration 3750 gap:  4.608965607633131e-05\n",
      "Iteration 3755 gap:  4.933276214325044e-05\n",
      "Iteration 3760 gap:  4.666759738647386e-05\n",
      "Iteration 3765 gap:  4.3633450160784903e-05\n",
      "Iteration 3770 gap:  4.629841895015252e-05\n",
      "Iteration 3775 gap:  4.863553689488098e-05\n",
      "Iteration 3780 gap:  4.6749044461724676e-05\n",
      "Iteration 3785 gap:  4.2073445971235746e-05\n",
      "Iteration 3790 gap:  4.619442813119656e-05\n",
      "Iteration 3795 gap:  4.77797630141219e-05\n",
      "Iteration 3800 gap:  4.6761602992162477e-05\n",
      "Iteration 3805 gap:  4.169275395976557e-05\n",
      "Iteration 3810 gap:  4.5765655002916183e-05\n",
      "Iteration 3815 gap:  4.6792990948674174e-05\n",
      "Iteration 3820 gap:  4.668098714499802e-05\n",
      "Iteration 3825 gap:  4.185700805264814e-05\n",
      "Iteration 3830 gap:  4.501968029158032e-05\n",
      "Iteration 3835 gap:  4.5721009495180986e-05\n",
      "Iteration 3840 gap:  4.647654328937545e-05\n",
      "Iteration 3845 gap:  4.21130901731015e-05\n",
      "Iteration 3850 gap:  4.398727788562651e-05\n",
      "Iteration 3855 gap:  4.458541970897567e-05\n",
      "Iteration 3860 gap:  4.61404873693394e-05\n",
      "Iteration 3865 gap:  4.244369184591701e-05\n",
      "Iteration 3870 gap:  4.2699989295513774e-05\n",
      "Iteration 3875 gap:  4.3398298217423026e-05\n",
      "Iteration 3880 gap:  4.567267334354419e-05\n",
      "Iteration 3885 gap:  4.2827015237389965e-05\n",
      "Iteration 3890 gap:  4.119790136292156e-05\n",
      "Iteration 3895 gap:  4.221509088969677e-05\n",
      "Iteration 3900 gap:  4.508731335306493e-05\n",
      "Iteration 3905 gap:  4.321729351186576e-05\n",
      "Iteration 3910 gap:  3.985413546114813e-05\n",
      "Iteration 3915 gap:  4.162086864761827e-05\n",
      "Iteration 3920 gap:  4.440971668218108e-05\n",
      "Iteration 3925 gap:  4.357687228678797e-05\n",
      "Iteration 3930 gap:  3.976074321238032e-05\n",
      "Iteration 3935 gap:  4.181160028149389e-05\n",
      "Iteration 3940 gap:  4.364920435834252e-05\n",
      "Iteration 3945 gap:  4.382682291992346e-05\n",
      "Iteration 3950 gap:  3.977854886177967e-05\n",
      "Iteration 3955 gap:  4.174493887970643e-05\n",
      "Iteration 3960 gap:  4.280622981395199e-05\n",
      "Iteration 3965 gap:  4.3957480021616924e-05\n",
      "Iteration 3970 gap:  3.9913585803408314e-05\n",
      "Iteration 3975 gap:  4.144596561433955e-05\n",
      "Iteration 3980 gap:  4.185570478942857e-05\n",
      "Iteration 3985 gap:  4.3929381380258814e-05\n",
      "Iteration 3990 gap:  4.011418067007e-05\n",
      "Iteration 3995 gap:  4.090445753468508e-05\n",
      "Iteration 4000 gap:  4.0841543607061936e-05\n",
      "Iteration 4005 gap:  4.3730243811768155e-05\n",
      "Iteration 4010 gap:  4.038063156325267e-05\n",
      "Iteration 4015 gap:  4.005933018280672e-05\n",
      "Iteration 4020 gap:  3.9871342942643384e-05\n",
      "Iteration 4025 gap:  4.344741267459096e-05\n",
      "Iteration 4030 gap:  4.059605703654601e-05\n",
      "Iteration 4035 gap:  3.89903385243362e-05\n",
      "Iteration 4040 gap:  4.0073974310939064e-05\n",
      "Iteration 4045 gap:  4.302529000593802e-05\n",
      "Iteration 4050 gap:  4.076312571077434e-05\n",
      "Iteration 4055 gap:  3.7717212334531514e-05\n",
      "Iteration 4060 gap:  4.028062525407439e-05\n",
      "Iteration 4065 gap:  4.242953581184983e-05\n",
      "Iteration 4070 gap:  4.08815179389066e-05\n",
      "Iteration 4075 gap:  3.627776338638311e-05\n",
      "Iteration 4080 gap:  4.020814960481456e-05\n",
      "Iteration 4085 gap:  4.170289340799105e-05\n",
      "Iteration 4090 gap:  4.0901102899393305e-05\n",
      "Iteration 4095 gap:  3.635336510382503e-05\n",
      "Iteration 4100 gap:  3.9816149884019936e-05\n",
      "Iteration 4105 gap:  4.082766921192915e-05\n",
      "Iteration 4110 gap:  4.0850315851215235e-05\n",
      "Iteration 4115 gap:  3.659408891415472e-05\n",
      "Iteration 4120 gap:  3.911759446662e-05\n",
      "Iteration 4125 gap:  3.98386943999407e-05\n",
      "Iteration 4130 gap:  4.070466890393476e-05\n",
      "Iteration 4135 gap:  3.693089067841049e-05\n",
      "Iteration 4140 gap:  3.813851147632663e-05\n",
      "Iteration 4145 gap:  3.878858615669056e-05\n",
      "Iteration 4150 gap:  4.0435073004718713e-05\n",
      "Iteration 4155 gap:  3.730549938474326e-05\n",
      "Iteration 4160 gap:  3.6921195211037094e-05\n",
      "Iteration 4165 gap:  3.774343681500758e-05\n",
      "Iteration 4170 gap:  4.002435304412133e-05\n",
      "Iteration 4175 gap:  3.768141452836771e-05\n",
      "Iteration 4180 gap:  3.550827998299866e-05\n",
      "Iteration 4185 gap:  3.669465734046362e-05\n",
      "Iteration 4190 gap:  3.9490217595583577e-05\n",
      "Iteration 4195 gap:  3.805558389902153e-05\n",
      "Iteration 4200 gap:  3.485604725705915e-05\n",
      "Iteration 4205 gap:  3.653524278451892e-05\n",
      "Iteration 4210 gap:  3.8856713055646086e-05\n",
      "Iteration 4215 gap:  3.839196365618136e-05\n",
      "Iteration 4220 gap:  3.489030484993272e-05\n",
      "Iteration 4225 gap:  3.668542558510346e-05\n",
      "Iteration 4230 gap:  3.814627172882279e-05\n",
      "Iteration 4235 gap:  3.865847332973349e-05\n",
      "Iteration 4240 gap:  3.500711813519963e-05\n",
      "Iteration 4245 gap:  3.657845880106203e-05\n",
      "Iteration 4250 gap:  3.7367669015242466e-05\n",
      "Iteration 4255 gap:  3.880100589054303e-05\n",
      "Iteration 4260 gap:  3.518971389959713e-05\n",
      "Iteration 4265 gap:  3.623333617630564e-05\n",
      "Iteration 4270 gap:  3.651742540167202e-05\n",
      "Iteration 4275 gap:  3.877301985971693e-05\n",
      "Iteration 4280 gap:  3.5432083014652616e-05\n",
      "Iteration 4285 gap:  3.5640600868691585e-05\n",
      "Iteration 4290 gap:  3.563931257466457e-05\n",
      "Iteration 4295 gap:  3.858295295333658e-05\n",
      "Iteration 4300 gap:  3.571839593191628e-05\n",
      "Iteration 4305 gap:  3.480242454767524e-05\n",
      "Iteration 4310 gap:  3.5098897548713204e-05\n",
      "Iteration 4315 gap:  3.826145511820478e-05\n",
      "Iteration 4320 gap:  3.59746785796311e-05\n",
      "Iteration 4325 gap:  3.375701201652204e-05\n",
      "Iteration 4330 gap:  3.544770786179097e-05\n",
      "Iteration 4335 gap:  3.7823736724895696e-05\n",
      "Iteration 4340 gap:  3.616252003874054e-05\n",
      "Iteration 4345 gap:  3.2536318211373594e-05\n",
      "Iteration 4350 gap:  3.5524861613234204e-05\n",
      "Iteration 4355 gap:  3.7249153755858355e-05\n",
      "Iteration 4360 gap:  3.627581104637123e-05\n",
      "Iteration 4365 gap:  3.208675103577585e-05\n",
      "Iteration 4370 gap:  3.533659456289584e-05\n",
      "Iteration 4375 gap:  3.655619552228595e-05\n",
      "Iteration 4380 gap:  3.6275634390736666e-05\n",
      "Iteration 4385 gap:  3.224078279151499e-05\n",
      "Iteration 4390 gap:  3.48565796355893e-05\n",
      "Iteration 4395 gap:  3.57452953402837e-05\n",
      "Iteration 4400 gap:  3.6181881923336157e-05\n",
      "Iteration 4405 gap:  3.255401216545328e-05\n",
      "Iteration 4410 gap:  3.408069968979799e-05\n",
      "Iteration 4415 gap:  3.481061758819903e-05\n",
      "Iteration 4420 gap:  3.601388713625475e-05\n",
      "Iteration 4425 gap:  3.295612726483821e-05\n",
      "Iteration 4430 gap:  3.30526121941066e-05\n",
      "Iteration 4435 gap:  3.382482894137562e-05\n",
      "Iteration 4440 gap:  3.5734980850077314e-05\n",
      "Iteration 4445 gap:  3.337862172397843e-05\n",
      "Iteration 4450 gap:  3.181252059886175e-05\n",
      "Iteration 4455 gap:  3.2873318772441706e-05\n",
      "Iteration 4460 gap:  3.5322850223840074e-05\n",
      "Iteration 4465 gap:  3.375922176906965e-05\n",
      "Iteration 4470 gap:  3.09306412289434e-05\n",
      "Iteration 4475 gap:  3.2268631945497894e-05\n",
      "Iteration 4480 gap:  3.479085074936661e-05\n",
      "Iteration 4485 gap:  3.409865128539691e-05\n",
      "Iteration 4490 gap:  3.09831311151032e-05\n",
      "Iteration 4495 gap:  3.253204005410071e-05\n",
      "Iteration 4500 gap:  3.4153696330641026e-05\n",
      "Iteration 4505 gap:  3.4382316022874004e-05\n",
      "Iteration 4510 gap:  3.1117433610006184e-05\n",
      "Iteration 4515 gap:  3.253957790994022e-05\n",
      "Iteration 4520 gap:  3.345594171411115e-05\n",
      "Iteration 4525 gap:  3.458355893803944e-05\n",
      "Iteration 4530 gap:  3.1304389715991476e-05\n",
      "Iteration 4535 gap:  3.2291235533388196e-05\n",
      "Iteration 4540 gap:  3.271392317855115e-05\n",
      "Iteration 4545 gap:  3.465041889971765e-05\n",
      "Iteration 4550 gap:  3.1542484291158246e-05\n",
      "Iteration 4555 gap:  3.180030222527108e-05\n",
      "Iteration 4560 gap:  3.1940166098365363e-05\n",
      "Iteration 4565 gap:  3.456010593383407e-05\n",
      "Iteration 4570 gap:  3.181483651515382e-05\n",
      "Iteration 4575 gap:  3.1080669081418044e-05\n",
      "Iteration 4580 gap:  3.115974968909141e-05\n",
      "Iteration 4585 gap:  3.431953552168743e-05\n",
      "Iteration 4590 gap:  3.208587728104062e-05\n",
      "Iteration 4595 gap:  3.0161322618016406e-05\n",
      "Iteration 4600 gap:  3.155607122001802e-05\n",
      "Iteration 4605 gap:  3.393734100681778e-05\n",
      "Iteration 4610 gap:  3.231391828495411e-05\n",
      "Iteration 4615 gap:  2.907829827214492e-05\n",
      "Iteration 4620 gap:  3.168890712063055e-05\n",
      "Iteration 4625 gap:  3.341963748793031e-05\n",
      "Iteration 4630 gap:  3.2482612416284695e-05\n",
      "Iteration 4635 gap:  2.8662272200385974e-05\n",
      "Iteration 4640 gap:  3.155822636075056e-05\n",
      "Iteration 4645 gap:  3.2801980394681074e-05\n",
      "Iteration 4650 gap:  3.2542089354159476e-05\n",
      "Iteration 4655 gap:  2.8812821919632636e-05\n",
      "Iteration 4660 gap:  3.116502872030358e-05\n",
      "Iteration 4665 gap:  3.209909303431013e-05\n",
      "Iteration 4670 gap:  3.247332489036969e-05\n",
      "Iteration 4675 gap:  2.9099162240475707e-05\n",
      "Iteration 4680 gap:  3.0483556794802524e-05\n",
      "Iteration 4685 gap:  3.1287602001051074e-05\n",
      "Iteration 4690 gap:  3.232904356098576e-05\n",
      "Iteration 4695 gap:  2.948741517855291e-05\n",
      "Iteration 4700 gap:  2.9564082117183865e-05\n",
      "Iteration 4705 gap:  3.038652467779457e-05\n",
      "Iteration 4710 gap:  3.208865823800533e-05\n",
      "Iteration 4715 gap:  2.993382629024044e-05\n",
      "Iteration 4720 gap:  2.8436203805104476e-05\n",
      "Iteration 4725 gap:  2.949672942675896e-05\n",
      "Iteration 4730 gap:  3.1739071619740766e-05\n",
      "Iteration 4735 gap:  3.0357102527689417e-05\n",
      "Iteration 4740 gap:  2.7746764647673672e-05\n",
      "Iteration 4745 gap:  2.8860847821887692e-05\n",
      "Iteration 4750 gap:  3.1287226516796274e-05\n",
      "Iteration 4755 gap:  3.071020771866495e-05\n",
      "Iteration 4760 gap:  2.7794254153612474e-05\n",
      "Iteration 4765 gap:  2.9114933470519855e-05\n",
      "Iteration 4770 gap:  3.073213152976484e-05\n",
      "Iteration 4775 gap:  3.0982953725056106e-05\n",
      "Iteration 4780 gap:  2.795344949424461e-05\n",
      "Iteration 4785 gap:  2.9152074990268506e-05\n",
      "Iteration 4790 gap:  3.0080053650960448e-05\n",
      "Iteration 4795 gap:  3.115669716008407e-05\n",
      "Iteration 4800 gap:  2.817883627392881e-05\n",
      "Iteration 4805 gap:  2.89425940213639e-05\n",
      "Iteration 4810 gap:  2.9380727524008776e-05\n",
      "Iteration 4815 gap:  3.122208089273437e-05\n",
      "Iteration 4820 gap:  2.84470232936318e-05\n",
      "Iteration 4825 gap:  2.8475570608088585e-05\n",
      "Iteration 4830 gap:  2.8678808512871967e-05\n",
      "Iteration 4835 gap:  3.117704064681259e-05\n",
      "Iteration 4840 gap:  2.870846144426009e-05\n",
      "Iteration 4845 gap:  2.7783266145442465e-05\n",
      "Iteration 4850 gap:  2.803160693570783e-05\n",
      "Iteration 4855 gap:  3.097937124568739e-05\n",
      "Iteration 4860 gap:  2.895831856652986e-05\n",
      "Iteration 4865 gap:  2.690672949356987e-05\n",
      "Iteration 4870 gap:  2.841476177750657e-05\n",
      "Iteration 4875 gap:  3.062070421272489e-05\n",
      "Iteration 4880 gap:  2.918232390297648e-05\n",
      "Iteration 4885 gap:  2.5878953869018506e-05\n",
      "Iteration 4890 gap:  2.8533535591013237e-05\n",
      "Iteration 4895 gap:  3.0123394236081236e-05\n",
      "Iteration 4900 gap:  2.9349247432919334e-05\n",
      "Iteration 4905 gap:  2.5817475590383943e-05\n",
      "Iteration 4910 gap:  2.8381209223826698e-05\n",
      "Iteration 4915 gap:  2.952648229936905e-05\n",
      "Iteration 4920 gap:  2.9419308116673815e-05\n",
      "Iteration 4925 gap:  2.604587088755883e-05\n",
      "Iteration 4930 gap:  2.7956850676913447e-05\n",
      "Iteration 4935 gap:  2.8851723726686096e-05\n",
      "Iteration 4940 gap:  2.9384947024091446e-05\n",
      "Iteration 4945 gap:  2.6361448937584075e-05\n",
      "Iteration 4950 gap:  2.7281571324755394e-05\n",
      "Iteration 4955 gap:  2.810506133971158e-05\n",
      "Iteration 4960 gap:  2.9238785478225005e-05\n",
      "Iteration 4965 gap:  2.674837890948023e-05\n",
      "Iteration 4970 gap:  2.6384553673042266e-05\n",
      "Iteration 4975 gap:  2.728839567833763e-05\n",
      "Iteration 4980 gap:  2.89929272840328e-05\n",
      "Iteration 4985 gap:  2.7183262500729555e-05\n",
      "Iteration 4990 gap:  2.530259147082159e-05\n",
      "Iteration 4995 gap:  2.647154043078359e-05\n",
      "Iteration 5000 gap:  2.8650473112568076e-05\n",
      "Iteration 5005 gap:  2.761072473272952e-05\n",
      "Iteration 5010 gap:  2.5120486726870617e-05\n",
      "Iteration 5015 gap:  2.614574714343565e-05\n",
      "Iteration 5020 gap:  2.821816957498946e-05\n",
      "Iteration 5025 gap:  2.7964841291361342e-05\n",
      "Iteration 5030 gap:  2.519312166959775e-05\n",
      "Iteration 5035 gap:  2.6320446783245632e-05\n",
      "Iteration 5040 gap:  2.7711932934493255e-05\n",
      "Iteration 5045 gap:  2.8220159190517347e-05\n",
      "Iteration 5050 gap:  2.5385168780645007e-05\n",
      "Iteration 5055 gap:  2.629088122996226e-05\n",
      "Iteration 5060 gap:  2.7106181169800347e-05\n",
      "Iteration 5065 gap:  2.8364720899953788e-05\n",
      "Iteration 5070 gap:  2.5631034858253354e-05\n",
      "Iteration 5075 gap:  2.6047805557427584e-05\n",
      "Iteration 5080 gap:  2.643675840452442e-05\n",
      "Iteration 5085 gap:  2.8365698794718952e-05\n",
      "Iteration 5090 gap:  2.5933863993743422e-05\n",
      "Iteration 5095 gap:  2.554586887476562e-05\n",
      "Iteration 5100 gap:  2.578616813664336e-05\n",
      "Iteration 5105 gap:  2.82828549058034e-05\n",
      "Iteration 5110 gap:  2.6205954793745434e-05\n",
      "Iteration 5115 gap:  2.4838928312620467e-05\n",
      "Iteration 5120 gap:  2.553952588141284e-05\n",
      "Iteration 5125 gap:  2.807078519684314e-05\n",
      "Iteration 5130 gap:  2.6442404825743893e-05\n",
      "Iteration 5135 gap:  2.3953029250178837e-05\n",
      "Iteration 5140 gap:  2.5818048828452067e-05\n",
      "Iteration 5145 gap:  2.7708038425833248e-05\n",
      "Iteration 5150 gap:  2.6638697594560945e-05\n",
      "Iteration 5155 gap:  2.336222743615224e-05\n",
      "Iteration 5160 gap:  2.5846285273078973e-05\n",
      "Iteration 5165 gap:  2.722067546873097e-05\n",
      "Iteration 5170 gap:  2.6761928523855172e-05\n",
      "Iteration 5175 gap:  2.355333433362583e-05\n",
      "Iteration 5180 gap:  2.5600599996677964e-05\n",
      "Iteration 5185 gap:  2.6613417785814608e-05\n",
      "Iteration 5190 gap:  2.681387486180853e-05\n",
      "Iteration 5195 gap:  2.3850006055536888e-05\n",
      "Iteration 5200 gap:  2.5095752063830634e-05\n",
      "Iteration 5205 gap:  2.5929590944717695e-05\n",
      "Iteration 5210 gap:  2.6763830472287253e-05\n",
      "Iteration 5215 gap:  2.4209955644172165e-05\n",
      "Iteration 5220 gap:  2.435983628373828e-05\n",
      "Iteration 5225 gap:  2.5204654826749273e-05\n",
      "Iteration 5230 gap:  2.6599913852676238e-05\n",
      "Iteration 5235 gap:  2.4598479028192788e-05\n",
      "Iteration 5240 gap:  2.342663486104568e-05\n",
      "Iteration 5245 gap:  2.4467689386853397e-05\n",
      "Iteration 5250 gap:  2.632439837213507e-05\n",
      "Iteration 5255 gap:  2.49963667724451e-05\n",
      "Iteration 5260 gap:  2.2843256913873677e-05\n",
      "Iteration 5265 gap:  2.3732096981810002e-05\n",
      "Iteration 5270 gap:  2.595508516173295e-05\n",
      "Iteration 5275 gap:  2.5370968344096134e-05\n",
      "Iteration 5280 gap:  2.2920332547748945e-05\n",
      "Iteration 5285 gap:  2.3902279951915073e-05\n",
      "Iteration 5290 gap:  2.5509603658713242e-05\n",
      "Iteration 5295 gap:  2.5690988392557124e-05\n",
      "Iteration 5300 gap:  2.3079656663704817e-05\n",
      "Iteration 5305 gap:  2.396240179858289e-05\n",
      "Iteration 5310 gap:  2.499749285539421e-05\n",
      "Iteration 5315 gap:  2.5915035994306113e-05\n",
      "Iteration 5320 gap:  2.3298838215946027e-05\n",
      "Iteration 5325 gap:  2.3817400966796853e-05\n",
      "Iteration 5330 gap:  2.441571724398628e-05\n",
      "Iteration 5335 gap:  2.5996226763025376e-05\n",
      "Iteration 5340 gap:  2.3569614355678503e-05\n",
      "Iteration 5345 gap:  2.3458660980968382e-05\n",
      "Iteration 5350 gap:  2.3799280308045567e-05\n",
      "Iteration 5355 gap:  2.5937128003528098e-05\n",
      "Iteration 5360 gap:  2.387845456502946e-05\n",
      "Iteration 5365 gap:  2.2878651524449456e-05\n",
      "Iteration 5370 gap:  2.319545843898485e-05\n",
      "Iteration 5375 gap:  2.5773562087938462e-05\n",
      "Iteration 5380 gap:  2.4152889883333195e-05\n",
      "Iteration 5385 gap:  2.211897382820016e-05\n",
      "Iteration 5390 gap:  2.3484712048660317e-05\n",
      "Iteration 5395 gap:  2.5506259076046867e-05\n",
      "Iteration 5400 gap:  2.4368274364361397e-05\n",
      "Iteration 5405 gap:  2.136076116715513e-05\n",
      "Iteration 5410 gap:  2.359646831995299e-05\n",
      "Iteration 5415 gap:  2.510148620449293e-05\n",
      "Iteration 5420 gap:  2.4523439361767707e-05\n",
      "Iteration 5425 gap:  2.14752357159953e-05\n",
      "Iteration 5430 gap:  2.3472486208264698e-05\n",
      "Iteration 5435 gap:  2.4604239133863004e-05\n",
      "Iteration 5440 gap:  2.4575344643729125e-05\n",
      "Iteration 5445 gap:  2.173182228654147e-05\n",
      "Iteration 5450 gap:  2.3077769695512007e-05\n",
      "Iteration 5455 gap:  2.3989159928017312e-05\n",
      "Iteration 5460 gap:  2.4569214526815042e-05\n",
      "Iteration 5465 gap:  2.208531474101605e-05\n",
      "Iteration 5470 gap:  2.245292931146725e-05\n",
      "Iteration 5475 gap:  2.3293251725786668e-05\n",
      "Iteration 5480 gap:  2.4467815656736835e-05\n",
      "Iteration 5485 gap:  2.2489878001963337e-05\n",
      "Iteration 5490 gap:  2.161955925328307e-05\n",
      "Iteration 5495 gap:  2.260392236425046e-05\n",
      "Iteration 5500 gap:  2.425600249456039e-05\n",
      "Iteration 5505 gap:  2.287819888141529e-05\n",
      "Iteration 5510 gap:  2.0930291801335432e-05\n",
      "Iteration 5515 gap:  2.191691698266718e-05\n",
      "Iteration 5520 gap:  2.3945354380716655e-05\n",
      "Iteration 5525 gap:  2.323891940331224e-05\n",
      "Iteration 5530 gap:  2.1002828551441866e-05\n",
      "Iteration 5535 gap:  2.1831465544630557e-05\n",
      "Iteration 5540 gap:  2.3533321966917597e-05\n",
      "Iteration 5545 gap:  2.3547744450347352e-05\n",
      "Iteration 5550 gap:  2.1160920317564447e-05\n",
      "Iteration 5555 gap:  2.1960998575598634e-05\n",
      "Iteration 5560 gap:  2.304996900881484e-05\n",
      "Iteration 5565 gap:  2.378199536257064e-05\n",
      "Iteration 5570 gap:  2.137866409207545e-05\n",
      "Iteration 5575 gap:  2.1867398895591972e-05\n",
      "Iteration 5580 gap:  2.2519846608448635e-05\n",
      "Iteration 5585 gap:  2.3918693418945036e-05\n",
      "Iteration 5590 gap:  2.163228773510717e-05\n",
      "Iteration 5595 gap:  2.1549809331944392e-05\n",
      "Iteration 5600 gap:  2.197018769789505e-05\n",
      "Iteration 5605 gap:  2.3930642870428898e-05\n",
      "Iteration 5610 gap:  2.190643222987898e-05\n",
      "Iteration 5615 gap:  2.1035677557346144e-05\n",
      "Iteration 5620 gap:  2.1408443226511586e-05\n",
      "Iteration 5625 gap:  2.3805010419097883e-05\n",
      "Iteration 5630 gap:  2.2176727974776433e-05\n",
      "Iteration 5635 gap:  2.0348806413217346e-05\n",
      "Iteration 5640 gap:  2.1529121140839713e-05\n",
      "Iteration 5645 gap:  2.3544531004004998e-05\n",
      "Iteration 5650 gap:  2.2420281098112227e-05\n",
      "Iteration 5655 gap:  1.962382328452028e-05\n",
      "Iteration 5660 gap:  2.1665656072755723e-05\n",
      "Iteration 5665 gap:  2.316908158644937e-05\n",
      "Iteration 5670 gap:  2.2603811206223234e-05\n",
      "Iteration 5675 gap:  1.976572688044964e-05\n",
      "Iteration 5680 gap:  2.156957311338914e-05\n",
      "Iteration 5685 gap:  2.27089064626651e-05\n",
      "Iteration 5690 gap:  2.2687702651957853e-05\n",
      "Iteration 5695 gap:  1.9982307982446823e-05\n",
      "Iteration 5700 gap:  2.1233454278291042e-05\n",
      "Iteration 5705 gap:  2.2177418721902598e-05\n",
      "Iteration 5710 gap:  2.267239721670533e-05\n",
      "Iteration 5715 gap:  2.0305770690731695e-05\n",
      "Iteration 5720 gap:  2.0663676530252584e-05\n",
      "Iteration 5725 gap:  2.1557009081296652e-05\n",
      "Iteration 5730 gap:  2.257609705902386e-05\n",
      "Iteration 5735 gap:  2.0694316011982128e-05\n",
      "Iteration 5740 gap:  1.9898303743604018e-05\n",
      "Iteration 5745 gap:  2.087566933078877e-05\n",
      "Iteration 5750 gap:  2.2400189688909222e-05\n",
      "Iteration 5755 gap:  2.11211602690331e-05\n",
      "Iteration 5760 gap:  1.932265125642596e-05\n",
      "Iteration 5765 gap:  2.023209859858266e-05\n",
      "Iteration 5770 gap:  2.212090778525022e-05\n",
      "Iteration 5775 gap:  2.1488817165737917e-05\n",
      "Iteration 5780 gap:  1.9364693698731283e-05\n",
      "Iteration 5785 gap:  2.006431097567596e-05\n",
      "Iteration 5790 gap:  2.1766249351184985e-05\n",
      "Iteration 5795 gap:  2.178669634711472e-05\n",
      "Iteration 5800 gap:  1.9527535416730135e-05\n",
      "Iteration 5805 gap:  2.0195897177166522e-05\n",
      "Iteration 5810 gap:  2.131646921510466e-05\n",
      "Iteration 5815 gap:  2.2008521980865225e-05\n",
      "Iteration 5820 gap:  1.974655938780101e-05\n",
      "Iteration 5825 gap:  2.0130339327739666e-05\n",
      "Iteration 5830 gap:  2.0800817092714308e-05\n",
      "Iteration 5835 gap:  2.211493556814048e-05\n",
      "Iteration 5840 gap:  2.002036208298419e-05\n",
      "Iteration 5845 gap:  1.9832702404742886e-05\n",
      "Iteration 5850 gap:  2.0282903606227976e-05\n",
      "Iteration 5855 gap:  2.213766327718858e-05\n",
      "Iteration 5860 gap:  2.0289509767457137e-05\n",
      "Iteration 5865 gap:  1.9337687496123745e-05\n",
      "Iteration 5870 gap:  1.975926755359847e-05\n",
      "Iteration 5875 gap:  2.203774058684438e-05\n",
      "Iteration 5880 gap:  2.054309403359822e-05\n",
      "Iteration 5885 gap:  1.8671168151240813e-05\n",
      "Iteration 5890 gap:  1.9868797646205305e-05\n",
      "Iteration 5895 gap:  2.1802329819908817e-05\n",
      "Iteration 5900 gap:  2.076635375392044e-05\n",
      "Iteration 5905 gap:  1.8119338880517866e-05\n",
      "Iteration 5910 gap:  1.9999984810281646e-05\n",
      "Iteration 5915 gap:  2.1444924151126088e-05\n",
      "Iteration 5920 gap:  2.0935935818144902e-05\n",
      "Iteration 5925 gap:  1.8286692695879125e-05\n",
      "Iteration 5930 gap:  1.988984407302885e-05\n",
      "Iteration 5935 gap:  2.0982695917104444e-05\n",
      "Iteration 5940 gap:  2.103373569795064e-05\n",
      "Iteration 5945 gap:  1.8549113278421014e-05\n",
      "Iteration 5950 gap:  1.9541699363467835e-05\n",
      "Iteration 5955 gap:  2.0448516676874195e-05\n",
      "Iteration 5960 gap:  2.1039074096562693e-05\n",
      "Iteration 5965 gap:  1.8874884971820105e-05\n",
      "Iteration 5970 gap:  1.8980004383162274e-05\n",
      "Iteration 5975 gap:  1.9862971752826475e-05\n",
      "Iteration 5980 gap:  2.0943339006374018e-05\n",
      "Iteration 5985 gap:  1.9242545922892873e-05\n",
      "Iteration 5990 gap:  1.8234011728068822e-05\n",
      "Iteration 5995 gap:  1.92609716180292e-05\n",
      "Iteration 6000 gap:  2.07471589895869e-05\n",
      "Iteration 6005 gap:  1.9624215520208654e-05\n",
      "Iteration 6010 gap:  1.7897604013938917e-05\n",
      "Iteration 6015 gap:  1.865578926207867e-05\n",
      "Iteration 6020 gap:  2.0469845957105104e-05\n",
      "Iteration 6025 gap:  1.9988912033641615e-05\n",
      "Iteration 6030 gap:  1.7977490007259345e-05\n",
      "Iteration 6035 gap:  1.8591118810362683e-05\n",
      "Iteration 6040 gap:  2.012325010997129e-05\n",
      "Iteration 6045 gap:  2.028770444367778e-05\n",
      "Iteration 6050 gap:  1.8141967603524378e-05\n",
      "Iteration 6055 gap:  1.867095305607691e-05\n",
      "Iteration 6060 gap:  1.9709685191160453e-05\n",
      "Iteration 6065 gap:  2.050174501022628e-05\n",
      "Iteration 6070 gap:  1.8364595000319728e-05\n",
      "Iteration 6075 gap:  1.8567380385636767e-05\n",
      "Iteration 6080 gap:  1.922866090764419e-05\n",
      "Iteration 6085 gap:  2.0587688536244375e-05\n",
      "Iteration 6090 gap:  1.8635726943438957e-05\n",
      "Iteration 6095 gap:  1.826280517674972e-05\n",
      "Iteration 6100 gap:  1.8726645863442748e-05\n",
      "Iteration 6105 gap:  2.0558958896133017e-05\n",
      "Iteration 6110 gap:  1.8925374472122947e-05\n",
      "Iteration 6115 gap:  1.776224275573668e-05\n",
      "Iteration 6120 gap:  1.823255620742037e-05\n",
      "Iteration 6125 gap:  2.0436009048163672e-05\n",
      "Iteration 6130 gap:  1.9177647618273674e-05\n",
      "Iteration 6135 gap:  1.710090269413378e-05\n",
      "Iteration 6140 gap:  1.8448875475085558e-05\n",
      "Iteration 6145 gap:  2.0204065653228742e-05\n",
      "Iteration 6150 gap:  1.9381149293951072e-05\n",
      "Iteration 6155 gap:  1.6874200793715044e-05\n",
      "Iteration 6160 gap:  1.8523183411334188e-05\n",
      "Iteration 6165 gap:  1.9856380524707617e-05\n",
      "Iteration 6170 gap:  1.9519160481207276e-05\n",
      "Iteration 6175 gap:  1.704785077633053e-05\n",
      "Iteration 6180 gap:  1.836765600859991e-05\n",
      "Iteration 6185 gap:  1.9409417694626896e-05\n",
      "Iteration 6190 gap:  1.9583477195495025e-05\n",
      "Iteration 6195 gap:  1.733352902888452e-05\n",
      "Iteration 6200 gap:  1.797791109670044e-05\n",
      "Iteration 6205 gap:  1.887261000527163e-05\n",
      "Iteration 6210 gap:  1.957714602812688e-05\n",
      "Iteration 6215 gap:  1.768318388345458e-05\n",
      "Iteration 6220 gap:  1.7383746020616098e-05\n",
      "Iteration 6225 gap:  1.8302483237808698e-05\n",
      "Iteration 6230 gap:  1.9474556186172e-05\n",
      "Iteration 6235 gap:  1.804952296596829e-05\n",
      "Iteration 6240 gap:  1.6620620070795233e-05\n",
      "Iteration 6245 gap:  1.7733056515700785e-05\n",
      "Iteration 6250 gap:  1.9271016933830598e-05\n",
      "Iteration 6255 gap:  1.840078761045083e-05\n",
      "Iteration 6260 gap:  1.666243940084966e-05\n",
      "Iteration 6265 gap:  1.7185209018888425e-05\n",
      "Iteration 6270 gap:  1.897363545078079e-05\n",
      "Iteration 6275 gap:  1.8720812869688075e-05\n",
      "Iteration 6280 gap:  1.6794797581987098e-05\n",
      "Iteration 6285 gap:  1.7322972802380487e-05\n",
      "Iteration 6290 gap:  1.860835589229115e-05\n",
      "Iteration 6295 gap:  1.8991045308835997e-05\n",
      "Iteration 6300 gap:  1.6981731595144822e-05\n",
      "Iteration 6305 gap:  1.7339589684028933e-05\n",
      "Iteration 6310 gap:  1.8192522165949576e-05\n",
      "Iteration 6315 gap:  1.9170521536493457e-05\n",
      "Iteration 6320 gap:  1.721390714481963e-05\n",
      "Iteration 6325 gap:  1.7159123420484867e-05\n",
      "Iteration 6330 gap:  1.7743273329096088e-05\n",
      "Iteration 6335 gap:  1.923223533611962e-05\n",
      "Iteration 6340 gap:  1.7480509749201456e-05\n",
      "Iteration 6345 gap:  1.6790486563555973e-05\n",
      "Iteration 6350 gap:  1.7279494100019832e-05\n",
      "Iteration 6355 gap:  1.9175597735621164e-05\n",
      "Iteration 6360 gap:  1.7752114337854508e-05\n",
      "Iteration 6365 gap:  1.625597424442793e-05\n",
      "Iteration 6370 gap:  1.703281402820611e-05\n",
      "Iteration 6375 gap:  1.9004238957232022e-05\n",
      "Iteration 6380 gap:  1.799391340273626e-05\n",
      "Iteration 6385 gap:  1.5690945746327234e-05\n",
      "Iteration 6390 gap:  1.721683083616421e-05\n",
      "Iteration 6395 gap:  1.8730333845473623e-05\n",
      "Iteration 6400 gap:  1.8184186187264473e-05\n",
      "Iteration 6405 gap:  1.582031640812165e-05\n",
      "Iteration 6410 gap:  1.7193245761326637e-05\n",
      "Iteration 6415 gap:  1.8368045201666572e-05\n",
      "Iteration 6420 gap:  1.8291004958037593e-05\n",
      "Iteration 6425 gap:  1.6014367185790412e-05\n",
      "Iteration 6430 gap:  1.6955433871423953e-05\n",
      "Iteration 6435 gap:  1.7934435685762473e-05\n",
      "Iteration 6440 gap:  1.8305151387787433e-05\n",
      "Iteration 6445 gap:  1.631612543739891e-05\n",
      "Iteration 6450 gap:  1.649612371845688e-05\n",
      "Iteration 6455 gap:  1.7409668838952452e-05\n",
      "Iteration 6460 gap:  1.8257895281648118e-05\n",
      "Iteration 6465 gap:  1.6680299621818495e-05\n",
      "Iteration 6470 gap:  1.5855177538270926e-05\n",
      "Iteration 6475 gap:  1.6842515199011476e-05\n",
      "Iteration 6480 gap:  1.8129558843726912e-05\n",
      "Iteration 6485 gap:  1.7063363991376423e-05\n",
      "Iteration 6490 gap:  1.5545746823220075e-05\n",
      "Iteration 6495 gap:  1.6303774342363297e-05\n",
      "Iteration 6500 gap:  1.7905507216919858e-05\n",
      "Iteration 6505 gap:  1.739274708162375e-05\n",
      "Iteration 6510 gap:  1.562261391202524e-05\n",
      "Iteration 6515 gap:  1.605310720281805e-05\n",
      "Iteration 6520 gap:  1.75976899198238e-05\n",
      "Iteration 6525 gap:  1.7667495459949834e-05\n",
      "Iteration 6530 gap:  1.5790416500849336e-05\n",
      "Iteration 6535 gap:  1.6177516814541715e-05\n",
      "Iteration 6540 gap:  1.721373120411318e-05\n",
      "Iteration 6545 gap:  1.7873722856942553e-05\n",
      "Iteration 6550 gap:  1.6011693395434623e-05\n",
      "Iteration 6555 gap:  1.6100572207300434e-05\n",
      "Iteration 6560 gap:  1.6795492201349127e-05\n",
      "Iteration 6565 gap:  1.799901738375187e-05\n",
      "Iteration 6570 gap:  1.625844255026543e-05\n",
      "Iteration 6575 gap:  1.5826641068750202e-05\n",
      "Iteration 6580 gap:  1.6364609512153905e-05\n",
      "Iteration 6585 gap:  1.801846143906216e-05\n",
      "Iteration 6590 gap:  1.651023618332026e-05\n",
      "Iteration 6595 gap:  1.537950957064549e-05\n",
      "Iteration 6600 gap:  1.5933160442904715e-05\n",
      "Iteration 6605 gap:  1.7912777134920788e-05\n",
      "Iteration 6610 gap:  1.675194054318041e-05\n",
      "Iteration 6615 gap:  1.4788777025098732e-05\n",
      "Iteration 6620 gap:  1.603222979901231e-05\n",
      "Iteration 6625 gap:  1.7687069917005083e-05\n",
      "Iteration 6630 gap:  1.6965173930238997e-05\n",
      "Iteration 6635 gap:  1.4725913016822023e-05\n",
      "Iteration 6640 gap:  1.6098933806329985e-05\n",
      "Iteration 6645 gap:  1.7366844490163125e-05\n",
      "Iteration 6650 gap:  1.71132372890348e-05\n",
      "Iteration 6655 gap:  1.49106551364242e-05\n",
      "Iteration 6660 gap:  1.5949716410834647e-05\n",
      "Iteration 6665 gap:  1.6973029582534327e-05\n",
      "Iteration 6670 gap:  1.7179491807683966e-05\n",
      "Iteration 6675 gap:  1.5173678367952359e-05\n",
      "Iteration 6680 gap:  1.558990478872646e-05\n",
      "Iteration 6685 gap:  1.651466037727589e-05\n",
      "Iteration 6690 gap:  1.71626806986791e-05\n",
      "Iteration 6695 gap:  1.54994948509124e-05\n",
      "Iteration 6700 gap:  1.5045372017352676e-05\n",
      "Iteration 6705 gap:  1.5996555264019552e-05\n",
      "Iteration 6710 gap:  1.706191545325364e-05\n",
      "Iteration 6715 gap:  1.5863614129030257e-05\n",
      "Iteration 6720 gap:  1.4571428473997283e-05\n",
      "Iteration 6725 gap:  1.5471047333182053e-05\n",
      "Iteration 6730 gap:  1.6881629325171676e-05\n",
      "Iteration 6735 gap:  1.6223619036914716e-05\n",
      "Iteration 6740 gap:  1.4620959694733315e-05\n",
      "Iteration 6745 gap:  1.4966890618528517e-05\n",
      "Iteration 6750 gap:  1.662650248723807e-05\n",
      "Iteration 6755 gap:  1.652509456673279e-05\n",
      "Iteration 6760 gap:  1.4746250945996131e-05\n",
      "Iteration 6765 gap:  1.5095310280710539e-05\n",
      "Iteration 6770 gap:  1.630425793258672e-05\n",
      "Iteration 6775 gap:  1.6754353652559395e-05\n",
      "Iteration 6780 gap:  1.494541052254883e-05\n",
      "Iteration 6785 gap:  1.509636192864594e-05\n",
      "Iteration 6790 gap:  1.5909610178610478e-05\n",
      "Iteration 6795 gap:  1.6886582589803467e-05\n",
      "Iteration 6800 gap:  1.5191751699838996e-05\n",
      "Iteration 6805 gap:  1.4908235915600532e-05\n",
      "Iteration 6810 gap:  1.5490429865150368e-05\n",
      "Iteration 6815 gap:  1.6924733641510148e-05\n",
      "Iteration 6820 gap:  1.5454435280060075e-05\n",
      "Iteration 6825 gap:  1.4533303376251805e-05\n",
      "Iteration 6830 gap:  1.5072594374554438e-05\n",
      "Iteration 6835 gap:  1.6874384530962683e-05\n",
      "Iteration 6840 gap:  1.5692071343720304e-05\n",
      "Iteration 6845 gap:  1.4001103024963157e-05\n",
      "Iteration 6850 gap:  1.4950725905349405e-05\n",
      "Iteration 6855 gap:  1.670761692329492e-05\n",
      "Iteration 6860 gap:  1.5900129035628652e-05\n",
      "Iteration 6865 gap:  1.3788341442666496e-05\n",
      "Iteration 6870 gap:  1.5082553165568502e-05\n",
      "Iteration 6875 gap:  1.6435159023941992e-05\n",
      "Iteration 6880 gap:  1.6056744261860878e-05\n",
      "Iteration 6885 gap:  1.3956698899031394e-05\n",
      "Iteration 6890 gap:  1.4998585003200837e-05\n",
      "Iteration 6895 gap:  1.6061145936330234e-05\n",
      "Iteration 6900 gap:  1.61566905192978e-05\n",
      "Iteration 6905 gap:  1.4211999200153258e-05\n",
      "Iteration 6910 gap:  1.4704062678061458e-05\n",
      "Iteration 6915 gap:  1.5621623263850637e-05\n",
      "Iteration 6920 gap:  1.6175875755697344e-05\n",
      "Iteration 6925 gap:  1.4518986999612071e-05\n",
      "Iteration 6930 gap:  1.4222009738606989e-05\n",
      "Iteration 6935 gap:  1.514718591444364e-05\n",
      "Iteration 6940 gap:  1.610329223705742e-05\n",
      "Iteration 6945 gap:  1.484905092113964e-05\n",
      "Iteration 6950 gap:  1.367536441665429e-05\n",
      "Iteration 6955 gap:  1.4660378009068165e-05\n",
      "Iteration 6960 gap:  1.5941923226514554e-05\n",
      "Iteration 6965 gap:  1.5183551773489956e-05\n",
      "Iteration 6970 gap:  1.3721859588866625e-05\n",
      "Iteration 6975 gap:  1.4178480543081129e-05\n",
      "Iteration 6980 gap:  1.570580007487221e-05\n",
      "Iteration 6985 gap:  1.5491607893158843e-05\n",
      "Iteration 6990 gap:  1.3846583429344417e-05\n",
      "Iteration 6995 gap:  1.4147402484621097e-05\n",
      "Iteration 7000 gap:  1.540860508952857e-05\n",
      "Iteration 7005 gap:  1.5748237382928743e-05\n",
      "Iteration 7010 gap:  1.4026513894926929e-05\n",
      "Iteration 7015 gap:  1.417263636516175e-05\n",
      "Iteration 7020 gap:  1.5058498128495135e-05\n",
      "Iteration 7025 gap:  1.5912235880655157e-05\n",
      "Iteration 7030 gap:  1.4250705926366347e-05\n",
      "Iteration 7035 gap:  1.4030424197064573e-05\n",
      "Iteration 7040 gap:  1.4663435023265503e-05\n",
      "Iteration 7045 gap:  1.5959341293503293e-05\n",
      "Iteration 7050 gap:  1.4512377115027952e-05\n",
      "Iteration 7055 gap:  1.3705409673658853e-05\n",
      "Iteration 7060 gap:  1.426691267736313e-05\n",
      "Iteration 7065 gap:  1.5914774067760096e-05\n",
      "Iteration 7070 gap:  1.4764215799989433e-05\n",
      "Iteration 7075 gap:  1.3228512478757892e-05\n",
      "Iteration 7080 gap:  1.4004443844417569e-05\n",
      "Iteration 7085 gap:  1.577620494624954e-05\n",
      "Iteration 7090 gap:  1.497798552535512e-05\n",
      "Iteration 7095 gap:  1.299583136527005e-05\n",
      "Iteration 7100 gap:  1.4154772357055645e-05\n",
      "Iteration 7105 gap:  1.5535494266194494e-05\n",
      "Iteration 7110 gap:  1.5142448615224069e-05\n",
      "Iteration 7115 gap:  1.3123599271025466e-05\n",
      "Iteration 7120 gap:  1.411408988410967e-05\n",
      "Iteration 7125 gap:  1.5213352936804814e-05\n",
      "Iteration 7130 gap:  1.522893653188584e-05\n",
      "Iteration 7135 gap:  1.3351057605581751e-05\n",
      "Iteration 7140 gap:  1.3861237596668463e-05\n",
      "Iteration 7145 gap:  1.4805546010354664e-05\n",
      "Iteration 7150 gap:  1.525660795154149e-05\n",
      "Iteration 7155 gap:  1.3652881521553084e-05\n",
      "Iteration 7160 gap:  1.3422423194742183e-05\n",
      "Iteration 7165 gap:  1.433514720278195e-05\n",
      "Iteration 7170 gap:  1.5209217843370482e-05\n",
      "Iteration 7175 gap:  1.3993761848851705e-05\n",
      "Iteration 7180 gap:  1.2902938752112902e-05\n",
      "Iteration 7185 gap:  1.3870138449945113e-05\n",
      "Iteration 7190 gap:  1.5072156727746755e-05\n",
      "Iteration 7195 gap:  1.4316462385921547e-05\n",
      "Iteration 7200 gap:  1.2933432720962923e-05\n",
      "Iteration 7205 gap:  1.3410629888521708e-05\n",
      "Iteration 7210 gap:  1.4857881997731859e-05\n",
      "Iteration 7215 gap:  1.4608194410237196e-05\n",
      "Iteration 7220 gap:  1.3055458968569411e-05\n",
      "Iteration 7225 gap:  1.3299526504140236e-05\n",
      "Iteration 7230 gap:  1.456960564311105e-05\n",
      "Iteration 7235 gap:  1.4851083877109872e-05\n",
      "Iteration 7240 gap:  1.3233980131532874e-05\n",
      "Iteration 7245 gap:  1.3347085846493467e-05\n",
      "Iteration 7250 gap:  1.4228163406737604e-05\n",
      "Iteration 7255 gap:  1.5016735127215686e-05\n",
      "Iteration 7260 gap:  1.345495684385023e-05\n",
      "Iteration 7265 gap:  1.321076806726218e-05\n",
      "Iteration 7270 gap:  1.386384724799683e-05\n",
      "Iteration 7275 gap:  1.5094711412755313e-05\n",
      "Iteration 7280 gap:  1.369305338688731e-05\n",
      "Iteration 7285 gap:  1.290516761703886e-05\n",
      "Iteration 7290 gap:  1.3487286111446561e-05\n",
      "Iteration 7295 gap:  1.5066628260784753e-05\n",
      "Iteration 7300 gap:  1.3929899946141244e-05\n",
      "Iteration 7305 gap:  1.2451655130807371e-05\n",
      "Iteration 7310 gap:  1.3184830205237308e-05\n",
      "Iteration 7315 gap:  1.4928915797240982e-05\n",
      "Iteration 7320 gap:  1.4145390230535515e-05\n",
      "Iteration 7325 gap:  1.2256561010504097e-05\n",
      "Iteration 7330 gap:  1.3338142936858421e-05\n",
      "Iteration 7335 gap:  1.4691709656067253e-05\n",
      "Iteration 7340 gap:  1.4315523965413579e-05\n",
      "Iteration 7345 gap:  1.2395842343526642e-05\n",
      "Iteration 7350 gap:  1.3298821333496136e-05\n",
      "Iteration 7355 gap:  1.4380549703818524e-05\n",
      "Iteration 7360 gap:  1.441141775354593e-05\n",
      "Iteration 7365 gap:  1.2616975865797908e-05\n",
      "Iteration 7370 gap:  1.3057681868766657e-05\n",
      "Iteration 7375 gap:  1.400198610046477e-05\n",
      "Iteration 7380 gap:  1.4437746076401137e-05\n",
      "Iteration 7385 gap:  1.2902771654721423e-05\n",
      "Iteration 7390 gap:  1.263886093649802e-05\n",
      "Iteration 7395 gap:  1.3565679952642906e-05\n",
      "Iteration 7400 gap:  1.4383481718449609e-05\n",
      "Iteration 7405 gap:  1.3228413252908133e-05\n",
      "Iteration 7410 gap:  1.2205438686130332e-05\n",
      "Iteration 7415 gap:  1.3109671053279648e-05\n",
      "Iteration 7420 gap:  1.4255861861711683e-05\n",
      "Iteration 7425 gap:  1.3563701494245795e-05\n",
      "Iteration 7430 gap:  1.2246212339528384e-05\n",
      "Iteration 7435 gap:  1.2668869833643015e-05\n",
      "Iteration 7440 gap:  1.4055013726976817e-05\n",
      "Iteration 7445 gap:  1.3855644745874862e-05\n",
      "Iteration 7450 gap:  1.2351176678471187e-05\n",
      "Iteration 7455 gap:  1.2536404163154824e-05\n",
      "Iteration 7460 gap:  1.379241761217953e-05\n",
      "Iteration 7465 gap:  1.4085136967212364e-05\n",
      "Iteration 7470 gap:  1.2530342740901812e-05\n",
      "Iteration 7475 gap:  1.2579194196282728e-05\n",
      "Iteration 7480 gap:  1.3462235974259773e-05\n",
      "Iteration 7485 gap:  1.4233671913388424e-05\n",
      "Iteration 7490 gap:  1.2752172665664308e-05\n",
      "Iteration 7495 gap:  1.2450790008833312e-05\n",
      "Iteration 7500 gap:  1.3101777981527896e-05\n",
      "Iteration 7505 gap:  1.4292128821757899e-05\n",
      "Iteration 7510 gap:  1.299572370783153e-05\n",
      "Iteration 7515 gap:  1.2147670935713784e-05\n",
      "Iteration 7520 gap:  1.2741396281323869e-05\n",
      "Iteration 7525 gap:  1.4268467121603123e-05\n",
      "Iteration 7530 gap:  1.3220685340376015e-05\n",
      "Iteration 7535 gap:  1.1698040838781232e-05\n",
      "Iteration 7540 gap:  1.2461447846001672e-05\n",
      "Iteration 7545 gap:  1.413930667326646e-05\n",
      "Iteration 7550 gap:  1.3420119379270457e-05\n",
      "Iteration 7555 gap:  1.1603731572884524e-05\n",
      "Iteration 7560 gap:  1.2601181967386577e-05\n",
      "Iteration 7565 gap:  1.3910863654265082e-05\n",
      "Iteration 7570 gap:  1.3574290824380775e-05\n",
      "Iteration 7575 gap:  1.1760749812739224e-05\n",
      "Iteration 7580 gap:  1.2542992965103306e-05\n",
      "Iteration 7585 gap:  1.3590712938882366e-05\n",
      "Iteration 7590 gap:  1.3674673522034997e-05\n",
      "Iteration 7595 gap:  1.1995796304231643e-05\n",
      "Iteration 7600 gap:  1.2291968776556583e-05\n",
      "Iteration 7605 gap:  1.3210395806595443e-05\n",
      "Iteration 7610 gap:  1.3699825383794995e-05\n",
      "Iteration 7615 gap:  1.2279244946455936e-05\n",
      "Iteration 7620 gap:  1.1868138156179153e-05\n",
      "Iteration 7625 gap:  1.279590055902613e-05\n",
      "Iteration 7630 gap:  1.3641793774055166e-05\n",
      "Iteration 7635 gap:  1.258575399548656e-05\n",
      "Iteration 7640 gap:  1.1553575174794162e-05\n",
      "Iteration 7645 gap:  1.2370970756014898e-05\n",
      "Iteration 7650 gap:  1.3502654419905724e-05\n",
      "Iteration 7655 gap:  1.2893508759159733e-05\n",
      "Iteration 7660 gap:  1.1609386557698276e-05\n",
      "Iteration 7665 gap:  1.195217941762916e-05\n",
      "Iteration 7670 gap:  1.3296695970499428e-05\n",
      "Iteration 7675 gap:  1.3173765636809165e-05\n",
      "Iteration 7680 gap:  1.1737178711002105e-05\n",
      "Iteration 7685 gap:  1.1869756781190954e-05\n",
      "Iteration 7690 gap:  1.3034506195941375e-05\n",
      "Iteration 7695 gap:  1.3402559761621635e-05\n",
      "Iteration 7700 gap:  1.191358144431165e-05\n",
      "Iteration 7705 gap:  1.1878811880194906e-05\n",
      "Iteration 7710 gap:  1.2722854090319036e-05\n",
      "Iteration 7715 gap:  1.354071506715071e-05\n",
      "Iteration 7720 gap:  1.212963743618678e-05\n",
      "Iteration 7725 gap:  1.173113257352254e-05\n",
      "Iteration 7730 gap:  1.237616601085234e-05\n",
      "Iteration 7735 gap:  1.3573227279961575e-05\n",
      "Iteration 7740 gap:  1.237592207170568e-05\n",
      "Iteration 7745 gap:  1.141801210757798e-05\n",
      "Iteration 7750 gap:  1.2031403922252437e-05\n",
      "Iteration 7755 gap:  1.3523272969828692e-05\n",
      "Iteration 7760 gap:  1.260330334346138e-05\n",
      "Iteration 7765 gap:  1.0974344326952767e-05\n",
      "Iteration 7770 gap:  1.1825047976643521e-05\n",
      "Iteration 7775 gap:  1.3389129529250976e-05\n",
      "Iteration 7780 gap:  1.2791105292730975e-05\n",
      "Iteration 7785 gap:  1.1053407001082594e-05\n",
      "Iteration 7790 gap:  1.192207260197753e-05\n",
      "Iteration 7795 gap:  1.3157980603140107e-05\n",
      "Iteration 7800 gap:  1.2929099788672183e-05\n",
      "Iteration 7805 gap:  1.1201055218290623e-05\n",
      "Iteration 7810 gap:  1.1837171242423672e-05\n",
      "Iteration 7815 gap:  1.2853334953488726e-05\n",
      "Iteration 7820 gap:  1.2996888761551695e-05\n",
      "Iteration 7825 gap:  1.1442270500150453e-05\n",
      "Iteration 7830 gap:  1.1558529836086517e-05\n",
      "Iteration 7835 gap:  1.2471085291620998e-05\n",
      "Iteration 7840 gap:  1.3010884025888014e-05\n",
      "Iteration 7845 gap:  1.1736325102318368e-05\n",
      "Iteration 7850 gap:  1.1115182279197722e-05\n",
      "Iteration 7855 gap:  1.2058962724159628e-05\n",
      "Iteration 7860 gap:  1.2946062655949664e-05\n",
      "Iteration 7865 gap:  1.2042381729304719e-05\n",
      "Iteration 7870 gap:  1.0978571834296957e-05\n",
      "Iteration 7875 gap:  1.1651294805126167e-05\n",
      "Iteration 7880 gap:  1.2802083583229873e-05\n",
      "Iteration 7885 gap:  1.2329674336120089e-05\n",
      "Iteration 7890 gap:  1.1057471464903657e-05\n",
      "Iteration 7895 gap:  1.1271273755886213e-05\n",
      "Iteration 7900 gap:  1.2582369474101185e-05\n",
      "Iteration 7905 gap:  1.2583199081539487e-05\n",
      "Iteration 7910 gap:  1.1200080999473894e-05\n",
      "Iteration 7915 gap:  1.126913157434295e-05\n",
      "Iteration 7920 gap:  1.2309704759017048e-05\n",
      "Iteration 7925 gap:  1.2782557309631848e-05\n",
      "Iteration 7930 gap:  1.1386062256646401e-05\n",
      "Iteration 7935 gap:  1.1235909248230591e-05\n",
      "Iteration 7940 gap:  1.2001469376132778e-05\n",
      "Iteration 7945 gap:  1.2903017360343938e-05\n",
      "Iteration 7950 gap:  1.1600089309948824e-05\n",
      "Iteration 7955 gap:  1.1040377147331082e-05\n",
      "Iteration 7960 gap:  1.1675916179620938e-05\n",
      "Iteration 7965 gap:  1.2927152111319451e-05\n",
      "Iteration 7970 gap:  1.1825702589451925e-05\n",
      "Iteration 7975 gap:  1.0700262147445017e-05\n",
      "Iteration 7980 gap:  1.1345635485715544e-05\n",
      "Iteration 7985 gap:  1.2852155803100285e-05\n",
      "Iteration 7990 gap:  1.2039129647645197e-05\n",
      "Iteration 7995 gap:  1.0439929341243825e-05\n",
      "Iteration 8000 gap:  1.126261430045572e-05\n",
      "Iteration 8005 gap:  1.2679815112326409e-05\n",
      "Iteration 8010 gap:  1.22222281815354e-05\n",
      "Iteration 8015 gap:  1.0550403687581422e-05\n",
      "Iteration 8020 gap:  1.1300431051575188e-05\n",
      "Iteration 8025 gap:  1.2434039535047514e-05\n",
      "Iteration 8030 gap:  1.234241878672604e-05\n",
      "Iteration 8035 gap:  1.0719071855291862e-05\n",
      "Iteration 8040 gap:  1.1161037475504454e-05\n",
      "Iteration 8045 gap:  1.213034341307484e-05\n",
      "Iteration 8050 gap:  1.2386580412138137e-05\n",
      "Iteration 8055 gap:  1.0964864595897073e-05\n",
      "Iteration 8060 gap:  1.0842033432378884e-05\n",
      "Iteration 8065 gap:  1.1759868800698126e-05\n",
      "Iteration 8070 gap:  1.2370064576827655e-05\n",
      "Iteration 8075 gap:  1.1259389009865561e-05\n",
      "Iteration 8080 gap:  1.0453880653626957e-05\n",
      "Iteration 8085 gap:  1.1350171739588077e-05\n",
      "Iteration 8090 gap:  1.2288024977047396e-05\n",
      "Iteration 8095 gap:  1.1576361121146128e-05\n",
      "Iteration 8100 gap:  1.0479606900704042e-05\n",
      "Iteration 8105 gap:  1.0960330383780192e-05\n",
      "Iteration 8110 gap:  1.2130824917078176e-05\n",
      "Iteration 8115 gap:  1.1850755655129497e-05\n",
      "Iteration 8120 gap:  1.056513990677077e-05\n",
      "Iteration 8125 gap:  1.0621616818751178e-05\n",
      "Iteration 8130 gap:  1.1911699668576414e-05\n",
      "Iteration 8135 gap:  1.2073276396462607e-05\n",
      "Iteration 8140 gap:  1.072484136516172e-05\n",
      "Iteration 8145 gap:  1.0700878582015072e-05\n",
      "Iteration 8150 gap:  1.1627999150110035e-05\n",
      "Iteration 8155 gap:  1.2230785299605085e-05\n",
      "Iteration 8160 gap:  1.0925776881276494e-05\n",
      "Iteration 8165 gap:  1.061667109952813e-05\n",
      "Iteration 8170 gap:  1.131805986248624e-05\n",
      "Iteration 8175 gap:  1.2313539931252393e-05\n",
      "Iteration 8180 gap:  1.114370496940742e-05\n",
      "Iteration 8185 gap:  1.0372204530206819e-05\n",
      "Iteration 8190 gap:  1.1002363806633664e-05\n",
      "Iteration 8195 gap:  1.2312512253476182e-05\n",
      "Iteration 8200 gap:  1.1355115169142671e-05\n",
      "Iteration 8205 gap:  9.990841509099901e-06\n",
      "\n"
     ]
    }
   ],
   "source": [
    "df = pd.read_csv(\"lobeke.csv\")\n",
    "df.dropna(inplace=True)\n",
    "\n",
    "# Lobeke National Park Bounding Box\n",
    "# lat_min, lon_min = 2.05522, 15.8790\n",
    "# lat_max, lon_max = 2.2837, 16.2038\n",
    "\n",
    "lat_min, lon_min = 2.0530, 15.8790\n",
    "lat_max, lon_max = 2.2837, 16.2038\n",
    "\n",
    "coordinate_rectangle = [lat_min, lat_max, lon_min, lon_max]\n",
    "\n",
    "schedule_form_kwargs = {\n",
    "    \"schedule_form\": True,\n",
    "    \"simple\": False,\n",
    "    \"attacker_penalty_factor\": 5,\n",
    "    \"defender_penalty_factor\": 5,\n",
    "}\n",
    "\n",
    "general_sum_kwargs = {\n",
    "    \"general_sum\": False,\n",
    "    \"attacker_feature_value\":  42, \n",
    "    \"defender_feature_value\": 69, \n",
    "    \"defender_step_cost\": 32.5, \n",
    "}\n",
    "\n",
    "boulou_camp = (2.2,15.9)\n",
    "# lobeke_camp = (2.25,15.75)\n",
    "kabo_djembe = (2.0532352380408088, 16.085709866529694)\n",
    "bomassa = (2.2037280296158355, 16.187056364164913)\n",
    "inner_post = (2.2,15.98)\n",
    "\n",
    "srmp_num_defenders_li = []\n",
    "srmp_dts = []\n",
    "\n",
    "srmp_gaps_li = []\n",
    "srmp_interval_times_li = []\n",
    "srmp_num_timesteps_li = []\n",
    "\n",
    "# for num_timesteps in [7,8,9,10]:\n",
    "#     for num_defenders in [1,2,3]:\n",
    "#         for dt in [1,2]:\n",
    "#             gsg = GreenSecurityGame(df, coordinate_rectangle, \"centroid\", num_clusters=10, num_rows=7, num_columns=7)\n",
    "#             gsg.generate(num_attackers=1, num_defenders=num_defenders, home_base_assignments=[(kabo_djembe, bomassa, inner_post) for i in range(num_defenders)], num_timesteps=num_timesteps, generate_utility_matrix=True, defense_time_threshold=dt, generate_actions=False, force_return=True, general_sum=False, **schedule_form_kwargs)\n",
    "#             D_d, U, gaps, interval_times = regret_matching(gsg.schedule_form_dict[\"defender_utility_matrix\"], runtime=120, interval=5, iterations=10000, averaging=0, alternations=False, plus=True, predictive=False, verbose=True)\n",
    "#             srmp_num_defenders_li.append(num_defenders)\n",
    "#             srmp_dts.append(dt)\n",
    "#             srmp_gaps_li.append(gaps)\n",
    "#             srmp_interval_times_li.append(interval_times)\n",
    "#             srmp_num_timesteps_li.append(num_timesteps)\n",
    "\n",
    "\n",
    "gsg = GreenSecurityGame(df, coordinate_rectangle, \"centroid\", num_clusters=10, num_rows=7, num_columns=7)\n",
    "gsg.generate(num_attackers=1, num_defenders=2, home_base_assignments=[(kabo_djembe, bomassa, inner_post),(kabo_djembe, bomassa, inner_post)], num_timesteps=8, generate_utility_matrix=True, defense_time_threshold=1, generate_actions=False, force_return=True, general_sum=False, **schedule_form_kwargs)\n",
    "D_d, U, gaps, interval_times = regret_matching(gsg.schedule_form_dict[\"defender_utility_matrix\"], runtime=120, interval=5, iterations=10000, averaging=1, alternations=True, plus=True, predictive=False, verbose=True)\n",
    "srmp_num_defenders_li.append(2)\n",
    "srmp_dts.append(1)\n",
    "srmp_gaps_li.append(gaps)\n",
    "srmp_interval_times_li.append(interval_times)\n",
    "srmp_num_timesteps_li.append(8)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "8c464a13-dfc2-4aed-b06f-ff86a0b768f9",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>num_timesteps</th>\n",
       "      <th>num_attackers</th>\n",
       "      <th>num_defenders</th>\n",
       "      <th>defense_time_threshold</th>\n",
       "      <th>interval_number</th>\n",
       "      <th>iteration_times</th>\n",
       "      <th>gaps</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>2</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>0.050267</td>\n",
       "      <td>0.316876</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>2</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>0.049117</td>\n",
       "      <td>0.207773</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>2</td>\n",
       "      <td>1</td>\n",
       "      <td>2</td>\n",
       "      <td>0.049594</td>\n",
       "      <td>0.178039</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>2</td>\n",
       "      <td>1</td>\n",
       "      <td>3</td>\n",
       "      <td>0.048528</td>\n",
       "      <td>0.16566</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>2</td>\n",
       "      <td>1</td>\n",
       "      <td>4</td>\n",
       "      <td>0.060105</td>\n",
       "      <td>0.143952</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1636</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>2</td>\n",
       "      <td>1</td>\n",
       "      <td>1636</td>\n",
       "      <td>0.058956</td>\n",
       "      <td>0.00001</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1637</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>2</td>\n",
       "      <td>1</td>\n",
       "      <td>1637</td>\n",
       "      <td>0.0667</td>\n",
       "      <td>0.000011</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1638</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>2</td>\n",
       "      <td>1</td>\n",
       "      <td>1638</td>\n",
       "      <td>0.050129</td>\n",
       "      <td>0.000012</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1639</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>2</td>\n",
       "      <td>1</td>\n",
       "      <td>1639</td>\n",
       "      <td>0.06601</td>\n",
       "      <td>0.000011</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1640</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>2</td>\n",
       "      <td>1</td>\n",
       "      <td>1640</td>\n",
       "      <td>0.058213</td>\n",
       "      <td>0.00001</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>1641 rows × 7 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "      num_timesteps  num_attackers  num_defenders  defense_time_threshold  \\\n",
       "0                 8              1              2                       1   \n",
       "1                 8              1              2                       1   \n",
       "2                 8              1              2                       1   \n",
       "3                 8              1              2                       1   \n",
       "4                 8              1              2                       1   \n",
       "...             ...            ...            ...                     ...   \n",
       "1636              8              1              2                       1   \n",
       "1637              8              1              2                       1   \n",
       "1638              8              1              2                       1   \n",
       "1639              8              1              2                       1   \n",
       "1640              8              1              2                       1   \n",
       "\n",
       "      interval_number iteration_times      gaps  \n",
       "0                   0        0.050267  0.316876  \n",
       "1                   1        0.049117  0.207773  \n",
       "2                   2        0.049594  0.178039  \n",
       "3                   3        0.048528   0.16566  \n",
       "4                   4        0.060105  0.143952  \n",
       "...               ...             ...       ...  \n",
       "1636             1636        0.058956   0.00001  \n",
       "1637             1637          0.0667  0.000011  \n",
       "1638             1638        0.050129  0.000012  \n",
       "1639             1639         0.06601  0.000011  \n",
       "1640             1640        0.058213   0.00001  \n",
       "\n",
       "[1641 rows x 7 columns]"
      ]
     },
     "execution_count": 16,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df = pd.DataFrame({\n",
    "    \"num_timesteps\": srmp_num_timesteps_li,\n",
    "    \"num_attackers\": [1 for i in range(len(srmp_num_timesteps_li))],\n",
    "    \"num_defenders\": srmp_num_defenders_li,\n",
    "    \"defense_time_threshold\": srmp_dts,\n",
    "    \"iteration_times\": srmp_interval_times_li,\n",
    "    \"gaps\": srmp_gaps_li\n",
    "})\n",
    "\n",
    "# Step 2: Explode list columns\n",
    "exploded_df = df.explode([\"iteration_times\", \"gaps\"], ignore_index=True)\n",
    "\n",
    "# Optional: Add a column for iteration number within each trial\n",
    "exploded_df[\"interval_number\"] = exploded_df.groupby([\"num_timesteps\",\"num_defenders\",\"defense_time_threshold\"]).cumcount()\n",
    "\n",
    "# Reorder if desired\n",
    "cols = [\"num_timesteps\", \"num_attackers\", \"num_defenders\", \"defense_time_threshold\", \"interval_number\", \"iteration_times\", \"gaps\"]\n",
    "exploded_df = exploded_df[cols]\n",
    "\n",
    "exploded_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "9837f89c-4be1-4461-94c9-08daa1f28336",
   "metadata": {},
   "outputs": [],
   "source": [
    "exploded_df[\"interval_number\"] = exploded_df[\"interval_number\"]+1\n",
    "exploded_df[\"iteration_number\"] = exploded_df[\"interval_number\"]*5"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "3875afb6-8d69-4ae1-bbcf-99d73daf6e96",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>num_timesteps</th>\n",
       "      <th>num_attackers</th>\n",
       "      <th>num_defenders</th>\n",
       "      <th>defense_time_threshold</th>\n",
       "      <th>interval_number</th>\n",
       "      <th>iteration_times</th>\n",
       "      <th>gaps</th>\n",
       "      <th>iteration_number</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>2</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>0.050267</td>\n",
       "      <td>0.316876</td>\n",
       "      <td>5</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>2</td>\n",
       "      <td>1</td>\n",
       "      <td>2</td>\n",
       "      <td>0.049117</td>\n",
       "      <td>0.207773</td>\n",
       "      <td>10</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>2</td>\n",
       "      <td>1</td>\n",
       "      <td>3</td>\n",
       "      <td>0.049594</td>\n",
       "      <td>0.178039</td>\n",
       "      <td>15</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>2</td>\n",
       "      <td>1</td>\n",
       "      <td>4</td>\n",
       "      <td>0.048528</td>\n",
       "      <td>0.16566</td>\n",
       "      <td>20</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>2</td>\n",
       "      <td>1</td>\n",
       "      <td>5</td>\n",
       "      <td>0.060105</td>\n",
       "      <td>0.143952</td>\n",
       "      <td>25</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1636</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>2</td>\n",
       "      <td>1</td>\n",
       "      <td>1637</td>\n",
       "      <td>0.058956</td>\n",
       "      <td>0.00001</td>\n",
       "      <td>8185</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1637</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>2</td>\n",
       "      <td>1</td>\n",
       "      <td>1638</td>\n",
       "      <td>0.0667</td>\n",
       "      <td>0.000011</td>\n",
       "      <td>8190</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1638</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>2</td>\n",
       "      <td>1</td>\n",
       "      <td>1639</td>\n",
       "      <td>0.050129</td>\n",
       "      <td>0.000012</td>\n",
       "      <td>8195</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1639</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>2</td>\n",
       "      <td>1</td>\n",
       "      <td>1640</td>\n",
       "      <td>0.06601</td>\n",
       "      <td>0.000011</td>\n",
       "      <td>8200</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1640</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>2</td>\n",
       "      <td>1</td>\n",
       "      <td>1641</td>\n",
       "      <td>0.058213</td>\n",
       "      <td>0.00001</td>\n",
       "      <td>8205</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>1641 rows × 8 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "      num_timesteps  num_attackers  num_defenders  defense_time_threshold  \\\n",
       "0                 8              1              2                       1   \n",
       "1                 8              1              2                       1   \n",
       "2                 8              1              2                       1   \n",
       "3                 8              1              2                       1   \n",
       "4                 8              1              2                       1   \n",
       "...             ...            ...            ...                     ...   \n",
       "1636              8              1              2                       1   \n",
       "1637              8              1              2                       1   \n",
       "1638              8              1              2                       1   \n",
       "1639              8              1              2                       1   \n",
       "1640              8              1              2                       1   \n",
       "\n",
       "      interval_number iteration_times      gaps  iteration_number  \n",
       "0                   1        0.050267  0.316876                 5  \n",
       "1                   2        0.049117  0.207773                10  \n",
       "2                   3        0.049594  0.178039                15  \n",
       "3                   4        0.048528   0.16566                20  \n",
       "4                   5        0.060105  0.143952                25  \n",
       "...               ...             ...       ...               ...  \n",
       "1636             1637        0.058956   0.00001              8185  \n",
       "1637             1638          0.0667  0.000011              8190  \n",
       "1638             1639        0.050129  0.000012              8195  \n",
       "1639             1640         0.06601  0.000011              8200  \n",
       "1640             1641        0.058213   0.00001              8205  \n",
       "\n",
       "[1641 rows x 8 columns]"
      ]
     },
     "execution_count": 18,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "exploded_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "dca74d19-471f-424d-95f2-4ac94a1ce9cf",
   "metadata": {},
   "outputs": [],
   "source": [
    "exploded_df.to_csv(\"GSG_SF_NEW_RMP_FINAL_FIXED.csv\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "5769fec8-3e03-4f31-9a76-bf693cfa5eae",
   "metadata": {},
   "source": [
    "## PRM+ (DONE)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7628ec3a-33e0-4551-b396-ccdb3bbbbd62",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "df = pd.read_csv(\"lobeke.csv\")\n",
    "df.dropna(inplace=True)\n",
    "\n",
    "# Lobeke National Park Bounding Box\n",
    "# lat_min, lon_min = 2.05522, 15.8790\n",
    "# lat_max, lon_max = 2.2837, 16.2038\n",
    "\n",
    "lat_min, lon_min = 2.0530, 15.8790\n",
    "lat_max, lon_max = 2.2837, 16.2038\n",
    "\n",
    "coordinate_rectangle = [lat_min, lat_max, lon_min, lon_max]\n",
    "\n",
    "schedule_form_kwargs = {\n",
    "    \"schedule_form\": True,\n",
    "    \"simple\": False,\n",
    "    \"attacker_penalty_factor\": 5,\n",
    "    \"defender_penalty_factor\": 5,\n",
    "    \"extra_coverage_weight\":1\n",
    "}\n",
    "\n",
    "general_sum_kwargs = {\n",
    "    \"general_sum\": False,\n",
    "    \"attacker_feature_value\":  42, \n",
    "    \"defender_feature_value\": 69, \n",
    "    \"defender_step_cost\": 32.5, \n",
    "}\n",
    "\n",
    "boulou_camp = (2.2,15.9)\n",
    "# lobeke_camp = (2.25,15.75)\n",
    "kabo_djembe = (2.0532352380408088, 16.085709866529694)\n",
    "bomassa = (2.2037280296158355, 16.187056364164913)\n",
    "inner_post = (2.2,15.98)\n",
    "\n",
    "sprmp_num_defenders_li = []\n",
    "sprmp_dts = []\n",
    "\n",
    "sprmp_gaps_li = []\n",
    "sprmp_interval_times_li = []\n",
    "sprmp_num_timesteps_li = []\n",
    "\n",
    "for num_timesteps in [7,8,9,10]:\n",
    "    for num_defenders in [1,2,3]:\n",
    "        for dt in [1,2]:\n",
    "            gsg = GreenSecurityGame(df, coordinate_rectangle, \"centroid\", num_clusters=10, num_rows=7, num_columns=7)\n",
    "            gsg.generate(num_attackers=1, num_defenders=num_defenders, home_base_assignments=[(kabo_djembe, bomassa, inner_post) for i in range(num_defenders)], num_timesteps=num_timesteps, generate_utility_matrix=True, defense_time_threshold=dt, generate_actions=False, force_return=True, general_sum=False, **schedule_form_kwargs)\n",
    "            D_d, U, gaps, interval_times = regret_matching(gsg.schedule_form_dict[\"defender_utility_matrix\"], runtime=120, interval=5, iterations=10000, averaging=2, alternations=True, plus=True, predictive=True, verbose=True)\n",
    "            sprmp_num_defenders_li.append(num_defenders)\n",
    "            sprmp_dts.append(dt)\n",
    "            sprmp_gaps_li.append(gaps)\n",
    "            sprmp_interval_times_li.append(interval_times)\n",
    "            sprmp_num_timesteps_li.append(num_timesteps)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "51a51335-30bd-46ca-b58b-4ed0112cfb8e",
   "metadata": {},
   "outputs": [],
   "source": [
    "df = pd.DataFrame({\n",
    "    \"num_timesteps\": sprmp_num_timesteps_li,\n",
    "    \"num_attackers\": [1 for i in range(len(sprmp_num_timesteps_li))],\n",
    "    \"num_defenders\": sprmp_num_defenders_li,\n",
    "    \"defense_time_threshold\": sprmp_dts,\n",
    "    \"iteration_times\": sprmp_interval_times_li,\n",
    "    \"gaps\": sprmp_gaps_li\n",
    "})\n",
    "\n",
    "# Step 2: Explode list columns\n",
    "exploded_df = df.explode([\"iteration_times\", \"gaps\"], ignore_index=True)\n",
    "\n",
    "# Optional: Add a column for iteration number within each trial\n",
    "exploded_df[\"interval_number\"] = exploded_df.groupby([\"num_timesteps\",\"num_defenders\",\"defense_time_threshold\"]).cumcount()\n",
    "\n",
    "# Reorder if desired\n",
    "cols = [\"num_timesteps\", \"num_attackers\", \"num_defenders\", \"defense_time_threshold\", \"interval_number\", \"iteration_times\", \"gaps\"]\n",
    "exploded_df = exploded_df[cols]\n",
    "\n",
    "exploded_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "43f8db3c-acc4-4517-a26c-4a2703a3c8f4",
   "metadata": {},
   "outputs": [],
   "source": [
    "exploded_df[\"interval_number\"] = exploded_df[\"interval_number\"]+1\n",
    "exploded_df[\"iteration_number\"] = exploded_df[\"interval_number\"]*5"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6632d9a9-12e1-47cc-a4f3-970bd0b9d867",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "exploded_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2745635a-bfc3-41f6-9fe8-5490509223b2",
   "metadata": {},
   "outputs": [],
   "source": [
    "exploded_df.to_csv(\"GSG_SF_PRMP_FINAL_FIXED.csv\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7bedaddc-3e57-4751-89ce-d386b09c3337",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "id": "1da28607-9373-47ae-9342-78c3f3ff9b4d",
   "metadata": {
    "jp-MarkdownHeadingCollapsed": true
   },
   "source": [
    "# ISG DO NFG"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "27ecf0d4-2372-4275-a470-214ec509cd68",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "import warnings\n",
    "warnings.filterwarnings('ignore', category=FutureWarning)\n",
    "\n",
    "schedule_form_kwargs = {\n",
    "    \"schedule_form\": False,\n",
    "    \"simple\": False,\n",
    "    \"attacker_penalty_factor\": 3,\n",
    "    \"defender_penalty_factor\": 3,\n",
    "    \"extra_coverage_weight\":0.9\n",
    "}\n",
    "\n",
    "general_sum_kwargs = {\n",
    "    \"general_sum\": False,\n",
    "    \"attacker_feature_value\":  42, \n",
    "    \"defender_feature_value\": 69, \n",
    "    \"defender_step_cost\": 32.5, \n",
    "}\n",
    "\n",
    "# Bounding box for Hoboken, NJ\n",
    "# bbox_hoboken_small = (40.752635, 40.745600, -74.030386,-74.043903)\n",
    "bbox_hoboken_low = (40.745411, 40.735486, -74.025857,-74.041479)\n",
    "bbox_hoboken_east = (40.748337, 40.734641,-74.022961,-74.031286)\n",
    "bbox_downtown = (40.718721, 40.714078, -73.996074, -74.002651)\n",
    "bbox_downtown_large = (40.7215, 40.710, -73.9935, -74.010)\n",
    "# 40.7060, -74.0140, 40.7205, -73.9935\n",
    "college_police = (40.743293077312465, -74.02670221027175)\n",
    "police_station = (40.73768931976651, -74.02990519431108)\n",
    "traffic_police = (40.7366602084371, -74.03449866349136)\n",
    "downtown_station = (40.71232433042349, -74.00187755238431)\n",
    "fifth_ave_station = (40.71637413934789, -73.9973285259067)\n",
    "fifth_precinct = (40.71625547686622, -73.99736909131171)\n",
    "booking_station = (40.716191530904815, -74.00102237385177)\n",
    "police_plaza = (40.71236124409745, -74.00173715463521)\n",
    "troop_nyc = (40.71657885026091, -74.00641139014367)\n",
    "first_precinct = (40.720411300417446, -74.0070247584372)\n",
    "\n",
    "num_timesteps_li = []\n",
    "num_attackers_li = []\n",
    "num_defenders_li = []\n",
    "supports=[]\n",
    "dims_li = []\n",
    "dts = []\n",
    "frs = []\n",
    "defender_actions_sizes = []\n",
    "attacker_actions_sizes = []\n",
    "iterations_to_converge = []\n",
    "iteration_times_li = []\n",
    "gaps_li = []\n",
    "i=0\n",
    "for num_timesteps in [7,8,9,10,11]:\n",
    "    for num_attackers in [1,2,3]:\n",
    "        for num_defenders in [1,2,3]:\n",
    "            for dt in [1,2]:\n",
    "                for fr in [True, False]:\n",
    "                    isg = InfraSecurityGame(df_combined, ny_blocks_gdf, INFRA_WEIGHTS, bbox=bbox_downtown_large)\n",
    "                    isg.generate(num_attackers=num_attackers, num_defenders=num_defenders, home_base_assignments=[(fifth_precinct,booking_station, troop_nyc, first_precinct, police_plaza) for i in range(num_defenders)], num_timesteps=num_timesteps, generate_utility_matrix=False, generate_actions=False, normalize=True, force_return=fr, defense_time_threshold=dt, **general_sum_kwargs, **schedule_form_kwargs)\n",
    "                    D_a, D_d, u, A_a, A_d, c, iteration_times, gaps = double_oracle(isg,eps=1e-12, verbose=False)\n",
    "                    support = sum([1 for p in D_d if p!=0])\n",
    "                    supports.append(support)\n",
    "                    num_timesteps_li.append(num_timesteps)\n",
    "                    num_attackers_li.append(num_attackers)\n",
    "                    num_defenders_li.append(num_defenders)\n",
    "                    dts.append(dt)\n",
    "                    frs.append(fr)\n",
    "                    iterations_to_converge.append(c)\n",
    "                    defender_actions_sizes.append(len(A_d))\n",
    "                    attacker_actions_sizes.append(len(A_a))\n",
    "                    iteration_times_li.append(iteration_times)\n",
    "                    gaps_li.append(gaps)\n",
    "                    print(f\"{i}/179: timesteps:{num_timesteps}, num_attackers:{num_attackers}, num_defenders:{num_defenders}, dt:{dt}, fr:{fr}, support:{support}\")\n",
    "                    i+=1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ac07ff90-0383-480a-97b4-60acfc2ba14a",
   "metadata": {},
   "outputs": [],
   "source": [
    "isg.draw_graph()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "416d0469-a825-4a59-9545-98db37c467bd",
   "metadata": {},
   "outputs": [],
   "source": [
    "df = pd.DataFrame({\n",
    "    \"num_timesteps\": num_timesteps_li,\n",
    "    \"num_attackers\": num_attackers_li,\n",
    "    \"num_defenders\": num_defenders_li,\n",
    "    \"defense_time_threshold\": dts,\n",
    "    \"force_return\": frs,\n",
    "    \"def_support\": supports,\n",
    "    \"iterations_to_converge\": iterations_to_converge,\n",
    "    \"iteration_time\": iteration_times_li,\n",
    "    \"gap\": gaps_li,\n",
    "    \"defender_actions_size\": defender_actions_sizes,\n",
    "    \"attacker_actions_size\": attacker_actions_sizes\n",
    "})\n",
    "\n",
    "# Step 2: Explode list columns\n",
    "exploded_df = df.explode([\"iteration_time\", \"gap\"], ignore_index=True)\n",
    "\n",
    "# Optional: Add a column for iteration number within each grouped trial\n",
    "exploded_df[\"iteration_number\"] = exploded_df.groupby(\n",
    "    [\"num_timesteps\", \"num_attackers\", \"num_defenders\", \"force_return\", \"defense_time_threshold\"]\n",
    ").cumcount()\n",
    "\n",
    "# Reorder if desired\n",
    "cols = [\n",
    "    \"num_timesteps\",\"num_attackers\", \"num_defenders\", \"force_return\", \"defense_time_threshold\",\n",
    "    \"iteration_number\", \"iteration_time\", \"gap\", \n",
    "    \"iterations_to_converge\", \"def_support\", \"defender_actions_size\", \"attacker_actions_size\"\n",
    "]\n",
    "exploded_df = exploded_df[cols]\n",
    "\n",
    "# Make iteration number 1-indexed\n",
    "exploded_df[\"iteration_number\"] += 1\n",
    "exploded_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "176bc277-f847-477b-a9ad-c8be08a23521",
   "metadata": {},
   "outputs": [],
   "source": [
    "exploded_df.to_csv(\"ISG_NFG_DO_MASS_FINAL.csv\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c4518b7c-f450-4141-8180-70072f7b6a6f",
   "metadata": {
    "jp-MarkdownHeadingCollapsed": true
   },
   "source": [
    "# ISG RM NFG"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "f46160c6-3a18-4d45-b056-42292b3b5e76",
   "metadata": {},
   "source": [
    "## RM"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2e3e4c88-cac1-48a3-adbd-01b5b1944edd",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "import warnings\n",
    "warnings.filterwarnings('ignore', category=FutureWarning)\n",
    "\n",
    "schedule_form_kwargs = {\n",
    "    \"schedule_form\": False,\n",
    "    \"simple\": False,\n",
    "    \"attacker_penalty_factor\": 3,\n",
    "    \"defender_penalty_factor\": 3,\n",
    "    \"extra_coverage_weight\":0.9\n",
    "}\n",
    "\n",
    "general_sum_kwargs = {\n",
    "    \"general_sum\": False,\n",
    "    \"attacker_feature_value\":  42, \n",
    "    \"defender_feature_value\": 69, \n",
    "    \"defender_step_cost\": 32.5, \n",
    "}\n",
    "\n",
    "# Bounding box for Hoboken, NJ\n",
    "# bbox_hoboken_small = (40.752635, 40.745600, -74.030386,-74.043903)\n",
    "bbox_hoboken_low = (40.745411, 40.735486, -74.025857,-74.041479)\n",
    "bbox_hoboken_east = (40.748337, 40.734641,-74.022961,-74.031286)\n",
    "bbox_downtown = (40.718721, 40.714078, -73.996074, -74.002651)\n",
    "bbox_downtown_large = (40.7215, 40.710, -73.9935, -74.010)\n",
    "# 40.7060, -74.0140, 40.7205, -73.9935\n",
    "college_police = (40.743293077312465, -74.02670221027175)\n",
    "police_station = (40.73768931976651, -74.02990519431108)\n",
    "traffic_police = (40.7366602084371, -74.03449866349136)\n",
    "downtown_station = (40.71232433042349, -74.00187755238431)\n",
    "fifth_ave_station = (40.71637413934789, -73.9973285259067)\n",
    "fifth_precinct = (40.71625547686622, -73.99736909131171)\n",
    "booking_station = (40.716191530904815, -74.00102237385177)\n",
    "police_plaza = (40.71236124409745, -74.00173715463521)\n",
    "troop_nyc = (40.71657885026091, -74.00641139014367)\n",
    "first_precinct = (40.720411300417446, -74.0070247584372)\n",
    "\n",
    "rm_num_timesteps_li = []\n",
    "rm_num_attackers_li= []\n",
    "rm_gaps_li = []\n",
    "rm_interval_times_li = []\n",
    "rm_dts = []\n",
    "\n",
    "start=time.time()\n",
    "for num_timesteps in [7,8,9,10]:\n",
    "    for num_attackers in [1,2,3]:\n",
    "        for dt in [1,2]:\n",
    "            print(f\"starting {num_timesteps} timesteps, {num_attackers} attackers, {dt} dt. Time since start: {time.time()-start}\")\n",
    "            isg = InfraSecurityGame(df_combined, ny_blocks_gdf, INFRA_WEIGHTS, bbox=bbox_downtown_large)\n",
    "            isg.generate(num_attackers=num_attackers, num_defenders=1, home_base_assignments=[(fifth_precinct,booking_station, troop_nyc, first_precinct, police_plaza)], num_timesteps=num_timesteps, generate_utility_matrix=True, generate_actions=False, normalize=True, force_return=False, defense_time_threshold=dt, **general_sum_kwargs, **schedule_form_kwargs)\n",
    "            D_d, U, gaps, interval_times = regret_matching(isg.utility_matrix, runtime=120, interval=5, iterations=10000, averaging=0, alternations=False, plus=False, predictive=False, verbose=False)\n",
    "            rm_num_timesteps_li.append(num_timesteps)\n",
    "            rm_num_attackers_li.append(num_attackers)\n",
    "            rm_dts.append(dt)\n",
    "            rm_gaps_li.append(gaps)\n",
    "            rm_interval_times_li.append(interval_times)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ad1eb628-7ad2-462e-9ca0-5a2995a323df",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "df = pd.DataFrame({\n",
    "    \"num_timesteps\": rm_num_timesteps_li,\n",
    "    \"num_attackers\": rm_num_attackers_li,\n",
    "    \"num_defenders\": [1 for i in range(len(rm_num_timesteps_li))],\n",
    "    \"defense_time_threshold\": rm_dts,\n",
    "    \"iteration_times\": rm_interval_times_li,\n",
    "    \"gaps\": rm_gaps_li\n",
    "})\n",
    "\n",
    "# Step 2: Explode list columns\n",
    "exploded_df = df.explode([\"iteration_times\", \"gaps\"], ignore_index=True)\n",
    "\n",
    "# Optional: Add a column for iteration number within each trial\n",
    "exploded_df[\"interval_number\"] = exploded_df.groupby([\"num_timesteps\",\"num_attackers\",\"defense_time_threshold\"]).cumcount()\n",
    "\n",
    "# Reorder if desired\n",
    "cols = [\"num_timesteps\", \"num_attackers\", \"num_defenders\", \"defense_time_threshold\", \"interval_number\", \"iteration_times\", \"gaps\"]\n",
    "exploded_df = exploded_df[cols]\n",
    "\n",
    "exploded_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3f239d6b-2849-4d28-9635-db17fb74b9ad",
   "metadata": {},
   "outputs": [],
   "source": [
    "exploded_df[\"interval_number\"] = exploded_df[\"interval_number\"]+1\n",
    "exploded_df[\"iteration_number\"] = exploded_df[\"interval_number\"]*5"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2757f2dd-8f92-438f-a2d5-b5e9e3daa294",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "exploded_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6ed350e5-cb2e-438b-a65e-240cb16aff4a",
   "metadata": {},
   "outputs": [],
   "source": [
    "exploded_df.to_csv(\"ISG_NFG_RM_FINAL.csv\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e6d93e77-671a-4d32-b772-147b0b0b8976",
   "metadata": {
    "scrolled": true
   },
   "source": [
    "## RM+"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "a962407f-3a14-459d-8004-aa52194e2cbf",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "import warnings\n",
    "warnings.filterwarnings('ignore', category=FutureWarning)\n",
    "\n",
    "schedule_form_kwargs = {\n",
    "    \"schedule_form\": False,\n",
    "    \"simple\": False,\n",
    "    \"attacker_penalty_factor\": 3,\n",
    "    \"defender_penalty_factor\": 3,\n",
    "}\n",
    "\n",
    "general_sum_kwargs = {\n",
    "    \"general_sum\": False,\n",
    "    \"attacker_feature_value\":  42, \n",
    "    \"defender_feature_value\": 69, \n",
    "    \"defender_step_cost\": 32.5, \n",
    "}\n",
    "\n",
    "# Bounding box for Hoboken, NJ\n",
    "# bbox_hoboken_small = (40.752635, 40.745600, -74.030386,-74.043903)\n",
    "bbox_hoboken_low = (40.745411, 40.735486, -74.025857,-74.041479)\n",
    "bbox_hoboken_east = (40.748337, 40.734641,-74.022961,-74.031286)\n",
    "bbox_downtown = (40.718721, 40.714078, -73.996074, -74.002651)\n",
    "bbox_downtown_large = (40.7215, 40.710, -73.9935, -74.010)\n",
    "# 40.7060, -74.0140, 40.7205, -73.9935\n",
    "college_police = (40.743293077312465, -74.02670221027175)\n",
    "police_station = (40.73768931976651, -74.02990519431108)\n",
    "traffic_police = (40.7366602084371, -74.03449866349136)\n",
    "downtown_station = (40.71232433042349, -74.00187755238431)\n",
    "fifth_ave_station = (40.71637413934789, -73.9973285259067)\n",
    "fifth_precinct = (40.71625547686622, -73.99736909131171)\n",
    "booking_station = (40.716191530904815, -74.00102237385177)\n",
    "police_plaza = (40.71236124409745, -74.00173715463521)\n",
    "troop_nyc = (40.71657885026091, -74.00641139014367)\n",
    "first_precinct = (40.720411300417446, -74.0070247584372)\n",
    "\n",
    "rmp_num_timesteps_li = []\n",
    "rmp_num_attackers_li= []\n",
    "rmp_gaps_li = []\n",
    "rmp_interval_times_li = []\n",
    "rmp_dts = []\n",
    "\n",
    "start=time.time()\n",
    "# for num_timesteps in [7,8,9,10]:\n",
    "#     for num_attackers in [1,2,3]:\n",
    "#         for dt in [1,2]:\n",
    "#             print(f\"starting {num_timesteps} timesteps, {num_attackers} attackers, {dt} dt. Time since start: {time.time()-start}\")\n",
    "#             isg = InfraSecurityGame(df_combined, ny_blocks_gdf, INFRA_WEIGHTS, bbox=bbox_downtown_large)\n",
    "#             isg.generate(num_attackers=num_attackers, num_defenders=1, home_base_assignments=[(fifth_precinct,booking_station, troop_nyc, first_precinct, police_plaza)], num_timesteps=num_timesteps, generate_utility_matrix=True, generate_actions=False, normalize=True, force_return=False, defense_time_threshold=dt, **general_sum_kwargs, **schedule_form_kwargs)\n",
    "#             D_d, U, gaps, interval_times = regret_matching(isg.utility_matrix, runtime=120, interval=5, iterations=10000, averaging=0, alternations=False, plus=True, predictive=False, verbose=False)\n",
    "#             rmp_num_timesteps_li.append(num_timesteps)\n",
    "#             rmp_num_attackers_li.append(num_attackers)\n",
    "#             rmp_dts.append(dt)\n",
    "#             rmp_gaps_li.append(gaps)\n",
    "#             rmp_interval_times_li.append(interval_times)\n",
    "\n",
    "\n",
    "\n",
    "isg = InfraSecurityGame(df_combined, ny_blocks_gdf, INFRA_WEIGHTS, bbox=bbox_downtown_large)\n",
    "isg.generate(num_attackers=1, num_defenders=1, home_base_assignments=[(fifth_precinct,booking_station, troop_nyc, first_precinct, police_plaza)], num_timesteps=8, generate_utility_matrix=True, generate_actions=False, force_return=False, defense_time_threshold=1, **general_sum_kwargs, **schedule_form_kwargs)\n",
    "D_d, U, gaps, interval_times = regret_matching(isg.utility_matrix, runtime=120, interval=5, iterations=10000, averaging=1, alternations=True, plus=True, predictive=False, verbose=False)\n",
    "rmp_num_timesteps_li.append(8)\n",
    "rmp_num_attackers_li.append(1)\n",
    "rmp_dts.append(1)\n",
    "rmp_gaps_li.append(gaps)\n",
    "rmp_interval_times_li.append(interval_times)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "589de3b3-e1d0-4546-99d4-3aef67c5090d",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>num_timesteps</th>\n",
       "      <th>num_attackers</th>\n",
       "      <th>num_defenders</th>\n",
       "      <th>defense_time_threshold</th>\n",
       "      <th>interval_number</th>\n",
       "      <th>iteration_times</th>\n",
       "      <th>gaps</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>0.729563</td>\n",
       "      <td>0.549458</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>0.719773</td>\n",
       "      <td>0.605135</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>2</td>\n",
       "      <td>0.83092</td>\n",
       "      <td>0.342011</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>3</td>\n",
       "      <td>0.830932</td>\n",
       "      <td>0.246801</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>4</td>\n",
       "      <td>0.739043</td>\n",
       "      <td>0.1578</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>124</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>124</td>\n",
       "      <td>0.723793</td>\n",
       "      <td>0.004107</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>125</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>125</td>\n",
       "      <td>0.736015</td>\n",
       "      <td>0.004324</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>126</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>126</td>\n",
       "      <td>0.814987</td>\n",
       "      <td>0.004659</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>127</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>127</td>\n",
       "      <td>0.802024</td>\n",
       "      <td>0.004352</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>128</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>128</td>\n",
       "      <td>0.779307</td>\n",
       "      <td>0.004673</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>129 rows × 7 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "     num_timesteps  num_attackers  num_defenders  defense_time_threshold  \\\n",
       "0                8              1              1                       1   \n",
       "1                8              1              1                       1   \n",
       "2                8              1              1                       1   \n",
       "3                8              1              1                       1   \n",
       "4                8              1              1                       1   \n",
       "..             ...            ...            ...                     ...   \n",
       "124              8              1              1                       1   \n",
       "125              8              1              1                       1   \n",
       "126              8              1              1                       1   \n",
       "127              8              1              1                       1   \n",
       "128              8              1              1                       1   \n",
       "\n",
       "     interval_number iteration_times      gaps  \n",
       "0                  0        0.729563  0.549458  \n",
       "1                  1        0.719773  0.605135  \n",
       "2                  2         0.83092  0.342011  \n",
       "3                  3        0.830932  0.246801  \n",
       "4                  4        0.739043    0.1578  \n",
       "..               ...             ...       ...  \n",
       "124              124        0.723793  0.004107  \n",
       "125              125        0.736015  0.004324  \n",
       "126              126        0.814987  0.004659  \n",
       "127              127        0.802024  0.004352  \n",
       "128              128        0.779307  0.004673  \n",
       "\n",
       "[129 rows x 7 columns]"
      ]
     },
     "execution_count": 25,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df = pd.DataFrame({\n",
    "    \"num_timesteps\": rmp_num_timesteps_li,\n",
    "    \"num_attackers\": rmp_num_attackers_li,\n",
    "    \"num_defenders\": [1 for i in range(len(rmp_num_timesteps_li))],\n",
    "    \"defense_time_threshold\": rmp_dts,\n",
    "    \"iteration_times\": rmp_interval_times_li,\n",
    "    \"gaps\": rmp_gaps_li\n",
    "})\n",
    "\n",
    "# Step 2: Explode list columns\n",
    "exploded_df = df.explode([\"iteration_times\", \"gaps\"], ignore_index=True)\n",
    "\n",
    "# Optional: Add a column for iteration number within each trial\n",
    "exploded_df[\"interval_number\"] = exploded_df.groupby([\"num_timesteps\",\"num_attackers\",\"defense_time_threshold\"]).cumcount()\n",
    "\n",
    "# Reorder if desired\n",
    "cols = [\"num_timesteps\", \"num_attackers\", \"num_defenders\", \"defense_time_threshold\", \"interval_number\", \"iteration_times\", \"gaps\"]\n",
    "exploded_df = exploded_df[cols]\n",
    "\n",
    "exploded_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "b7e09e50-7cd9-4359-9523-bad0c552fac7",
   "metadata": {},
   "outputs": [],
   "source": [
    "exploded_df[\"interval_number\"] = exploded_df[\"interval_number\"]+1\n",
    "exploded_df[\"iteration_number\"] = exploded_df[\"interval_number\"]*5"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "515cceb8-16ff-4120-8b85-ea7a633c5aec",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>num_timesteps</th>\n",
       "      <th>num_attackers</th>\n",
       "      <th>num_defenders</th>\n",
       "      <th>defense_time_threshold</th>\n",
       "      <th>interval_number</th>\n",
       "      <th>iteration_times</th>\n",
       "      <th>gaps</th>\n",
       "      <th>iteration_number</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>0.729563</td>\n",
       "      <td>0.549458</td>\n",
       "      <td>5</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>2</td>\n",
       "      <td>0.719773</td>\n",
       "      <td>0.605135</td>\n",
       "      <td>10</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>3</td>\n",
       "      <td>0.83092</td>\n",
       "      <td>0.342011</td>\n",
       "      <td>15</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>4</td>\n",
       "      <td>0.830932</td>\n",
       "      <td>0.246801</td>\n",
       "      <td>20</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>5</td>\n",
       "      <td>0.739043</td>\n",
       "      <td>0.1578</td>\n",
       "      <td>25</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>124</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>125</td>\n",
       "      <td>0.723793</td>\n",
       "      <td>0.004107</td>\n",
       "      <td>625</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>125</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>126</td>\n",
       "      <td>0.736015</td>\n",
       "      <td>0.004324</td>\n",
       "      <td>630</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>126</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>127</td>\n",
       "      <td>0.814987</td>\n",
       "      <td>0.004659</td>\n",
       "      <td>635</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>127</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>128</td>\n",
       "      <td>0.802024</td>\n",
       "      <td>0.004352</td>\n",
       "      <td>640</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>128</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>129</td>\n",
       "      <td>0.779307</td>\n",
       "      <td>0.004673</td>\n",
       "      <td>645</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>129 rows × 8 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "     num_timesteps  num_attackers  num_defenders  defense_time_threshold  \\\n",
       "0                8              1              1                       1   \n",
       "1                8              1              1                       1   \n",
       "2                8              1              1                       1   \n",
       "3                8              1              1                       1   \n",
       "4                8              1              1                       1   \n",
       "..             ...            ...            ...                     ...   \n",
       "124              8              1              1                       1   \n",
       "125              8              1              1                       1   \n",
       "126              8              1              1                       1   \n",
       "127              8              1              1                       1   \n",
       "128              8              1              1                       1   \n",
       "\n",
       "     interval_number iteration_times      gaps  iteration_number  \n",
       "0                  1        0.729563  0.549458                 5  \n",
       "1                  2        0.719773  0.605135                10  \n",
       "2                  3         0.83092  0.342011                15  \n",
       "3                  4        0.830932  0.246801                20  \n",
       "4                  5        0.739043    0.1578                25  \n",
       "..               ...             ...       ...               ...  \n",
       "124              125        0.723793  0.004107               625  \n",
       "125              126        0.736015  0.004324               630  \n",
       "126              127        0.814987  0.004659               635  \n",
       "127              128        0.802024  0.004352               640  \n",
       "128              129        0.779307  0.004673               645  \n",
       "\n",
       "[129 rows x 8 columns]"
      ]
     },
     "execution_count": 27,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "exploded_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "307555a7-c79f-4334-a63d-07806a3f3b08",
   "metadata": {},
   "outputs": [],
   "source": [
    "exploded_df.to_csv(\"ISG_NFG_NWE_RMP_FINAL.csv\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "715b0be8-8ebf-4f9b-b388-4f93c2f22e5b",
   "metadata": {},
   "source": [
    "## PRM+"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "17edf12d-1dcc-435e-b528-6c852c0d703e",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "import warnings\n",
    "warnings.filterwarnings('ignore', category=FutureWarning)\n",
    "\n",
    "schedule_form_kwargs = {\n",
    "    \"schedule_form\": False,\n",
    "    \"simple\": False,\n",
    "    \"attacker_penalty_factor\": 3,\n",
    "    \"defender_penalty_factor\": 3,\n",
    "    \"extra_coverage_weight\":0.9\n",
    "}\n",
    "\n",
    "general_sum_kwargs = {\n",
    "    \"general_sum\": False,\n",
    "    \"attacker_feature_value\":  42, \n",
    "    \"defender_feature_value\": 69, \n",
    "    \"defender_step_cost\": 32.5, \n",
    "}\n",
    "\n",
    "# Bounding box for Hoboken, NJ\n",
    "# bbox_hoboken_small = (40.752635, 40.745600, -74.030386,-74.043903)\n",
    "bbox_hoboken_low = (40.745411, 40.735486, -74.025857,-74.041479)\n",
    "bbox_hoboken_east = (40.748337, 40.734641,-74.022961,-74.031286)\n",
    "bbox_downtown = (40.718721, 40.714078, -73.996074, -74.002651)\n",
    "bbox_downtown_large = (40.7215, 40.710, -73.9935, -74.010)\n",
    "# 40.7060, -74.0140, 40.7205, -73.9935\n",
    "college_police = (40.743293077312465, -74.02670221027175)\n",
    "police_station = (40.73768931976651, -74.02990519431108)\n",
    "traffic_police = (40.7366602084371, -74.03449866349136)\n",
    "downtown_station = (40.71232433042349, -74.00187755238431)\n",
    "fifth_ave_station = (40.71637413934789, -73.9973285259067)\n",
    "fifth_precinct = (40.71625547686622, -73.99736909131171)\n",
    "booking_station = (40.716191530904815, -74.00102237385177)\n",
    "police_plaza = (40.71236124409745, -74.00173715463521)\n",
    "troop_nyc = (40.71657885026091, -74.00641139014367)\n",
    "first_precinct = (40.720411300417446, -74.0070247584372)\n",
    "\n",
    "prmp_num_timesteps_li = []\n",
    "prmp_num_attackers_li= []\n",
    "prmp_gaps_li = []\n",
    "prmp_interval_times_li = []\n",
    "prmp_dts = []\n",
    "\n",
    "start=time.time()\n",
    "for num_timesteps in [7,8,9]:\n",
    "    for num_attackers in [1,2,3]:\n",
    "        for dt in [1,2]:\n",
    "            print(f\"starting {num_timesteps} timesteps, {num_attackers} attackers, {dt} dt. Time since start: {time.time()-start}\")\n",
    "            isg = InfraSecurityGame(df_combined, ny_blocks_gdf, INFRA_WEIGHTS, bbox=bbox_downtown_large)\n",
    "            isg.generate(num_attackers=num_attackers, num_defenders=1, home_base_assignments=[(fifth_precinct,booking_station, troop_nyc, first_precinct, police_plaza)], num_timesteps=num_timesteps, generate_utility_matrix=True, generate_actions=False, normalize=True, force_return=False, defense_time_threshold=dt, **general_sum_kwargs, **schedule_form_kwargs)\n",
    "            D_d, U, gaps, interval_times = regret_matching(isg.utility_matrix, runtime=120, interval=5, iterations=10000, averaging=2, alternations=True, plus=True, predictive=True, verbose=False)\n",
    "            prmp_num_timesteps_li.append(num_timesteps)\n",
    "            prmp_num_attackers_li.append(num_attackers)\n",
    "            prmp_dts.append(dt)\n",
    "            prmp_gaps_li.append(gaps)\n",
    "            prmp_interval_times_li.append(interval_times)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0ab69f9a-e9af-49a0-b3b5-c63675535782",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "df = pd.DataFrame({\n",
    "    \"num_timesteps\": prmp_num_timesteps_li,\n",
    "    \"num_attackers\": prmp_num_attackers_li,\n",
    "    \"num_defenders\": [1 for i in range(len(prmp_num_timesteps_li))],\n",
    "    \"defense_time_threshold\": prmp_dts,\n",
    "    \"iteration_times\": prmp_interval_times_li,\n",
    "    \"gaps\": prmp_gaps_li\n",
    "})\n",
    "\n",
    "# Step 2: Explode list columns\n",
    "exploded_df = df.explode([\"iteration_times\", \"gaps\"], ignore_index=True)\n",
    "\n",
    "# Optional: Add a column for iteration number within each trial\n",
    "exploded_df[\"interval_number\"] = exploded_df.groupby([\"num_timesteps\",\"num_attackers\"]).cumcount()\n",
    "\n",
    "# Reorder if desired\n",
    "cols = [\"num_timesteps\", \"num_attackers\", \"num_defenders\", \"defense_time_threshold\", \"interval_number\", \"iteration_times\", \"gaps\"]\n",
    "exploded_df = exploded_df[cols]\n",
    "\n",
    "exploded_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a09d7681-e939-42ee-8593-08b41df2dfc8",
   "metadata": {},
   "outputs": [],
   "source": [
    "exploded_df[\"interval_number\"] = exploded_df[\"interval_number\"]+1\n",
    "exploded_df[\"iteration_number\"] = exploded_df[\"interval_number\"]*5"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4fc7634d-912f-45b1-9f52-e7c611979a18",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "exploded_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fe74d848-33f3-41f6-bc01-2879cdf37dc6",
   "metadata": {},
   "outputs": [],
   "source": [
    "exploded_df.to_csv(\"ISG_NFG_PRMP_FINAL.csv\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "1fc7860a-2709-4b0f-8b6c-22d94a3f8d97",
   "metadata": {
    "jp-MarkdownHeadingCollapsed": true
   },
   "source": [
    "# ISG DO SF"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "803b335a-ad99-4290-8e9b-679c463cc777",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Set parameter WLSAccessID\n",
      "Set parameter WLSSecret\n",
      "Set parameter LicenseID to value 2455389\n",
      "Academic license 2455389 - for non-commercial use only - registered to jc___@columbia.edu\n",
      "0/23: timesteps:7, num_defenders:1, dt:1, support:3\n",
      "1/23: timesteps:7, num_defenders:1, dt:2, support:1\n"
     ]
    },
    {
     "ename": "KeyboardInterrupt",
     "evalue": "",
     "output_type": "error",
     "traceback": [
      "\u001b[1;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[1;31mKeyboardInterrupt\u001b[0m                         Traceback (most recent call last)",
      "Cell \u001b[1;32mIn[3], line 51\u001b[0m\n\u001b[0;32m     49\u001b[0m \u001b[38;5;28;01mfor\u001b[39;00m dt \u001b[38;5;129;01min\u001b[39;00m [\u001b[38;5;241m1\u001b[39m,\u001b[38;5;241m2\u001b[39m]:\n\u001b[0;32m     50\u001b[0m     isg \u001b[38;5;241m=\u001b[39m InfraSecurityGame(df_combined, ny_blocks_gdf, INFRA_WEIGHTS, bbox\u001b[38;5;241m=\u001b[39mbbox_downtown_large)\n\u001b[1;32m---> 51\u001b[0m     \u001b[43misg\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mgenerate\u001b[49m\u001b[43m(\u001b[49m\u001b[43mnum_attackers\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;241;43m1\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mnum_defenders\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mnum_defenders\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mhome_base_assignments\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43m[\u001b[49m\u001b[43m(\u001b[49m\u001b[43mfifth_precinct\u001b[49m\u001b[43m,\u001b[49m\u001b[43mbooking_station\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mtroop_nyc\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mfirst_precinct\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mpolice_plaza\u001b[49m\u001b[43m)\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;28;43;01mfor\u001b[39;49;00m\u001b[43m \u001b[49m\u001b[43mi\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;129;43;01min\u001b[39;49;00m\u001b[43m \u001b[49m\u001b[38;5;28;43mrange\u001b[39;49m\u001b[43m(\u001b[49m\u001b[43mnum_defenders\u001b[49m\u001b[43m)\u001b[49m\u001b[43m]\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mnum_timesteps\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mnum_timesteps\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mgenerate_utility_matrix\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;28;43;01mTrue\u001b[39;49;00m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mgenerate_actions\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;28;43;01mFalse\u001b[39;49;00m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mnormalize\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;28;43;01mTrue\u001b[39;49;00m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mforce_return\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;28;43;01mTrue\u001b[39;49;00m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mdefense_time_threshold\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mdt\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43mgeneral_sum_kwargs\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43mschedule_form_kwargs\u001b[49m\u001b[43m)\u001b[49m\n\u001b[0;32m     52\u001b[0m     D_a, D_d, u, A_a, A_d, c, iteration_times, gaps \u001b[38;5;241m=\u001b[39m double_oracle_sf(isg\u001b[38;5;241m.\u001b[39mschedule_form_dict,eps\u001b[38;5;241m=\u001b[39m\u001b[38;5;241m1e-12\u001b[39m, verbose\u001b[38;5;241m=\u001b[39m\u001b[38;5;28;01mFalse\u001b[39;00m)\n\u001b[0;32m     53\u001b[0m     support \u001b[38;5;241m=\u001b[39m \u001b[38;5;28msum\u001b[39m([\u001b[38;5;241m1\u001b[39m \u001b[38;5;28;01mfor\u001b[39;00m p \u001b[38;5;129;01min\u001b[39;00m D_d \u001b[38;5;28;01mif\u001b[39;00m p\u001b[38;5;241m!=\u001b[39m\u001b[38;5;241m0\u001b[39m])\n",
      "File \u001b[1;32m~\\GameGenerators\\notebooks\\..\\security_game\\infra_security_game.py:265\u001b[0m, in \u001b[0;36mInfraSecurityGame.generate\u001b[1;34m(self, num_attackers, num_defenders, home_base_assignments, num_timesteps, interdiction_protocol, defense_time_threshold, generate_utility_matrix, generate_actions, normalize, force_return, schedule_form, general_sum, attacker_feature_value, defender_feature_value, defender_step_cost, simple, attacker_penalty_factor, defender_penalty_factor, extra_coverage_weight)\u001b[0m\n\u001b[0;32m    263\u001b[0m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mdefense_time_threshold \u001b[38;5;241m=\u001b[39m defense_time_threshold\n\u001b[0;32m    264\u001b[0m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mforce_return \u001b[38;5;241m=\u001b[39m force_return\n\u001b[1;32m--> 265\u001b[0m \u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mcreate_security_game_graph\u001b[49m\u001b[43m(\u001b[49m\u001b[43mnormalize\u001b[49m\u001b[43m)\u001b[49m\n\u001b[0;32m    266\u001b[0m \u001b[38;5;66;03m# self.graph.add_edge(3, 36)\u001b[39;00m\n\u001b[0;32m    267\u001b[0m \u001b[38;5;66;03m# self.graph.add_edge(6, 25) # Specifically for experiment\u001b[39;00m\n\u001b[0;32m    268\u001b[0m \u001b[38;5;66;03m# self.graph.add_edge(25, 6)\u001b[39;00m\n\u001b[1;32m   (...)\u001b[0m\n\u001b[0;32m    345\u001b[0m \n\u001b[0;32m    346\u001b[0m \u001b[38;5;66;03m#DO Testing, remove nodes that are not reachable for dt=1 at timesteps 7 with force return\u001b[39;00m\n\u001b[0;32m    347\u001b[0m \u001b[38;5;28;01mfor\u001b[39;00m n \u001b[38;5;129;01min\u001b[39;00m [\u001b[38;5;241m51\u001b[39m, \u001b[38;5;241m57\u001b[39m, \u001b[38;5;241m73\u001b[39m, \u001b[38;5;241m86\u001b[39m, \u001b[38;5;241m105\u001b[39m, \u001b[38;5;241m113\u001b[39m, \u001b[38;5;241m124\u001b[39m, \u001b[38;5;241m135\u001b[39m, \u001b[38;5;241m146\u001b[39m, \u001b[38;5;241m167\u001b[39m, \u001b[38;5;241m236\u001b[39m]:\n",
      "File \u001b[1;32m~\\GameGenerators\\notebooks\\..\\security_game\\infra_security_game.py:66\u001b[0m, in \u001b[0;36mInfraSecurityGame.create_security_game_graph\u001b[1;34m(self, normalize)\u001b[0m\n\u001b[0;32m     64\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21mcreate_security_game_graph\u001b[39m(\u001b[38;5;28mself\u001b[39m, normalize\u001b[38;5;241m=\u001b[39m\u001b[38;5;28;01mTrue\u001b[39;00m):\n\u001b[0;32m     65\u001b[0m     north, south, east, west \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mbbox\n\u001b[1;32m---> 66\u001b[0m     \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mgraph \u001b[38;5;241m=\u001b[39m \u001b[43mox\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mgraph_from_bbox\u001b[49m\u001b[43m(\u001b[49m\u001b[43mnorth\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43msouth\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43meast\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mwest\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mnetwork_type\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[38;5;124;43mdrive\u001b[39;49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[43m)\u001b[49m\n\u001b[0;32m     67\u001b[0m     \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mgraph \u001b[38;5;241m=\u001b[39m nx\u001b[38;5;241m.\u001b[39mconvert_node_labels_to_integers(\u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mgraph)\n\u001b[0;32m     68\u001b[0m     \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mgraph \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mgraph\u001b[38;5;241m.\u001b[39mto_undirected()\n",
      "File \u001b[1;32m~\\AppData\\Local\\Programs\\Python\\Python312\\Lib\\site-packages\\osmnx\\graph.py:112\u001b[0m, in \u001b[0;36mgraph_from_bbox\u001b[1;34m(north, south, east, west, bbox, network_type, simplify, retain_all, truncate_by_edge, clean_periphery, custom_filter)\u001b[0m\n\u001b[0;32m    109\u001b[0m polygon \u001b[38;5;241m=\u001b[39m utils_geo\u001b[38;5;241m.\u001b[39mbbox_to_poly(bbox\u001b[38;5;241m=\u001b[39mbbox)\n\u001b[0;32m    111\u001b[0m \u001b[38;5;66;03m# create graph using this polygon geometry\u001b[39;00m\n\u001b[1;32m--> 112\u001b[0m G \u001b[38;5;241m=\u001b[39m \u001b[43mgraph_from_polygon\u001b[49m\u001b[43m(\u001b[49m\n\u001b[0;32m    113\u001b[0m \u001b[43m    \u001b[49m\u001b[43mpolygon\u001b[49m\u001b[43m,\u001b[49m\n\u001b[0;32m    114\u001b[0m \u001b[43m    \u001b[49m\u001b[43mnetwork_type\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mnetwork_type\u001b[49m\u001b[43m,\u001b[49m\n\u001b[0;32m    115\u001b[0m \u001b[43m    \u001b[49m\u001b[43msimplify\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43msimplify\u001b[49m\u001b[43m,\u001b[49m\n\u001b[0;32m    116\u001b[0m \u001b[43m    \u001b[49m\u001b[43mretain_all\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mretain_all\u001b[49m\u001b[43m,\u001b[49m\n\u001b[0;32m    117\u001b[0m \u001b[43m    \u001b[49m\u001b[43mtruncate_by_edge\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mtruncate_by_edge\u001b[49m\u001b[43m,\u001b[49m\n\u001b[0;32m    118\u001b[0m \u001b[43m    \u001b[49m\u001b[43mclean_periphery\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mclean_periphery\u001b[49m\u001b[43m,\u001b[49m\n\u001b[0;32m    119\u001b[0m \u001b[43m    \u001b[49m\u001b[43mcustom_filter\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mcustom_filter\u001b[49m\u001b[43m,\u001b[49m\n\u001b[0;32m    120\u001b[0m \u001b[43m\u001b[49m\u001b[43m)\u001b[49m\n\u001b[0;32m    122\u001b[0m utils\u001b[38;5;241m.\u001b[39mlog(\u001b[38;5;124mf\u001b[39m\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mgraph_from_bbox returned graph with \u001b[39m\u001b[38;5;132;01m{\u001b[39;00m\u001b[38;5;28mlen\u001b[39m(G)\u001b[38;5;132;01m:\u001b[39;00m\u001b[38;5;124m,\u001b[39m\u001b[38;5;132;01m}\u001b[39;00m\u001b[38;5;124m nodes and \u001b[39m\u001b[38;5;132;01m{\u001b[39;00m\u001b[38;5;28mlen\u001b[39m(G\u001b[38;5;241m.\u001b[39medges)\u001b[38;5;132;01m:\u001b[39;00m\u001b[38;5;124m,\u001b[39m\u001b[38;5;132;01m}\u001b[39;00m\u001b[38;5;124m edges\u001b[39m\u001b[38;5;124m\"\u001b[39m)\n\u001b[0;32m    123\u001b[0m \u001b[38;5;28;01mreturn\u001b[39;00m G\n",
      "File \u001b[1;32m~\\AppData\\Local\\Programs\\Python\\Python312\\Lib\\site-packages\\osmnx\\graph.py:504\u001b[0m, in \u001b[0;36mgraph_from_polygon\u001b[1;34m(polygon, network_type, simplify, retain_all, truncate_by_edge, clean_periphery, custom_filter)\u001b[0m\n\u001b[0;32m    502\u001b[0m \u001b[38;5;66;03m# create buffered graph from the downloaded data\u001b[39;00m\n\u001b[0;32m    503\u001b[0m bidirectional \u001b[38;5;241m=\u001b[39m network_type \u001b[38;5;129;01min\u001b[39;00m settings\u001b[38;5;241m.\u001b[39mbidirectional_network_types\n\u001b[1;32m--> 504\u001b[0m G_buff \u001b[38;5;241m=\u001b[39m \u001b[43m_create_graph\u001b[49m\u001b[43m(\u001b[49m\u001b[43mresponse_jsons\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mretain_all\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;28;43;01mTrue\u001b[39;49;00m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mbidirectional\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mbidirectional\u001b[49m\u001b[43m)\u001b[49m\n\u001b[0;32m    506\u001b[0m \u001b[38;5;66;03m# truncate buffered graph to the buffered polygon and retain_all for\u001b[39;00m\n\u001b[0;32m    507\u001b[0m \u001b[38;5;66;03m# now. needed because overpass returns entire ways that also include\u001b[39;00m\n\u001b[0;32m    508\u001b[0m \u001b[38;5;66;03m# nodes outside the poly if the way (that is, a way with a single OSM\u001b[39;00m\n\u001b[0;32m    509\u001b[0m \u001b[38;5;66;03m# ID) has a node inside the poly at some point.\u001b[39;00m\n\u001b[0;32m    510\u001b[0m G_buff \u001b[38;5;241m=\u001b[39m truncate\u001b[38;5;241m.\u001b[39mtruncate_graph_polygon(G_buff, poly_buff, \u001b[38;5;28;01mTrue\u001b[39;00m, truncate_by_edge)\n",
      "File \u001b[1;32m~\\AppData\\Local\\Programs\\Python\\Python312\\Lib\\site-packages\\osmnx\\graph.py:676\u001b[0m, in \u001b[0;36m_create_graph\u001b[1;34m(response_jsons, retain_all, bidirectional)\u001b[0m\n\u001b[0;32m    674\u001b[0m \u001b[38;5;66;03m# add length (great-circle distance between nodes) attribute to each edge\u001b[39;00m\n\u001b[0;32m    675\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;28mlen\u001b[39m(G\u001b[38;5;241m.\u001b[39medges) \u001b[38;5;241m>\u001b[39m \u001b[38;5;241m0\u001b[39m:\n\u001b[1;32m--> 676\u001b[0m     G \u001b[38;5;241m=\u001b[39m \u001b[43mdistance\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43madd_edge_lengths\u001b[49m\u001b[43m(\u001b[49m\u001b[43mG\u001b[49m\u001b[43m)\u001b[49m\n\u001b[0;32m    678\u001b[0m \u001b[38;5;28;01mreturn\u001b[39;00m G\n",
      "File \u001b[1;32m~\\AppData\\Local\\Programs\\Python\\Python312\\Lib\\site-packages\\osmnx\\distance.py:228\u001b[0m, in \u001b[0;36madd_edge_lengths\u001b[1;34m(G, precision, edges)\u001b[0m\n\u001b[0;32m    226\u001b[0m     c \u001b[38;5;241m=\u001b[39m np\u001b[38;5;241m.\u001b[39marray([(y[u], x[u], y[v], x[v]) \u001b[38;5;28;01mfor\u001b[39;00m u, v, k \u001b[38;5;129;01min\u001b[39;00m uvk])\n\u001b[0;32m    227\u001b[0m     \u001b[38;5;66;03m# ensure all coordinates can be converted to float and are non-null\u001b[39;00m\n\u001b[1;32m--> 228\u001b[0m     \u001b[38;5;28;01massert\u001b[39;00m \u001b[38;5;129;01mnot\u001b[39;00m np\u001b[38;5;241m.\u001b[39misnan(\u001b[43mc\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mastype\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;28;43mfloat\u001b[39;49m\u001b[43m)\u001b[49m)\u001b[38;5;241m.\u001b[39many()\n\u001b[0;32m    229\u001b[0m \u001b[38;5;28;01mexcept\u001b[39;00m (\u001b[38;5;167;01mAssertionError\u001b[39;00m, \u001b[38;5;167;01mKeyError\u001b[39;00m) \u001b[38;5;28;01mas\u001b[39;00m e:  \u001b[38;5;66;03m# pragma: no cover\u001b[39;00m\n\u001b[0;32m    230\u001b[0m     msg \u001b[38;5;241m=\u001b[39m \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124msome edges missing nodes, possibly due to input data clipping issue\u001b[39m\u001b[38;5;124m\"\u001b[39m\n",
      "\u001b[1;31mKeyboardInterrupt\u001b[0m: "
     ]
    }
   ],
   "source": [
    "import warnings\n",
    "warnings.filterwarnings('ignore', category=FutureWarning)\n",
    "\n",
    "schedule_form_kwargs = {\n",
    "    \"schedule_form\": True,\n",
    "    \"simple\": False,\n",
    "    \"attacker_penalty_factor\": 3,\n",
    "    \"defender_penalty_factor\": 3,\n",
    "    \"extra_coverage_weight\":1.0\n",
    "}\n",
    "\n",
    "general_sum_kwargs = {\n",
    "    \"general_sum\": False,\n",
    "    \"attacker_feature_value\":  42, \n",
    "    \"defender_feature_value\": 69, \n",
    "    \"defender_step_cost\": 32.5, \n",
    "}\n",
    "\n",
    "# Bounding box for Hoboken, NJ\n",
    "# bbox_hoboken_small = (40.752635, 40.745600, -74.030386,-74.043903)\n",
    "bbox_hoboken_low = (40.745411, 40.735486, -74.025857,-74.041479)\n",
    "bbox_hoboken_east = (40.748337, 40.734641,-74.022961,-74.031286)\n",
    "bbox_downtown = (40.718721, 40.714078, -73.996074, -74.002651)\n",
    "bbox_downtown_large = (40.7215, 40.710, -73.9935, -74.010)\n",
    "# 40.7060, -74.0140, 40.7205, -73.9935\n",
    "college_police = (40.743293077312465, -74.02670221027175)\n",
    "police_station = (40.73768931976651, -74.02990519431108)\n",
    "traffic_police = (40.7366602084371, -74.03449866349136)\n",
    "downtown_station = (40.71232433042349, -74.00187755238431)\n",
    "fifth_ave_station = (40.71637413934789, -73.9973285259067)\n",
    "fifth_precinct = (40.71625547686622, -73.99736909131171)\n",
    "booking_station = (40.716191530904815, -74.00102237385177)\n",
    "police_plaza = (40.71236124409745, -74.00173715463521)\n",
    "troop_nyc = (40.71657885026091, -74.00641139014367)\n",
    "first_precinct = (40.720411300417446, -74.0070247584372)\n",
    "\n",
    "num_timesteps_li = []\n",
    "num_defenders_li = []\n",
    "supports=[]\n",
    "dts = []\n",
    "defender_actions_sizes = []\n",
    "attacker_actions_sizes = []\n",
    "iterations_to_converge = []\n",
    "iteration_times_li = []\n",
    "gaps_li = []\n",
    "i=0\n",
    "for num_timesteps in [7,8,9,10]:\n",
    "    for num_defenders in [1,2,3]:\n",
    "        for dt in [1,2]:\n",
    "            isg = InfraSecurityGame(df_combined, ny_blocks_gdf, INFRA_WEIGHTS, bbox=bbox_downtown_large)\n",
    "            isg.generate(num_attackers=1, num_defenders=num_defenders, home_base_assignments=[(fifth_precinct,booking_station, troop_nyc, first_precinct, police_plaza) for i in range(num_defenders)], num_timesteps=num_timesteps, generate_utility_matrix=True, generate_actions=False, normalize=True, force_return=True, defense_time_threshold=dt, **general_sum_kwargs, **schedule_form_kwargs)\n",
    "            D_a, D_d, u, A_a, A_d, c, iteration_times, gaps = double_oracle_sf(isg.schedule_form_dict,eps=1e-12, verbose=False)\n",
    "            support = sum([1 for p in D_d if p!=0])\n",
    "            supports.append(support)\n",
    "            num_timesteps_li.append(num_timesteps)\n",
    "            num_defenders_li.append(num_defenders)\n",
    "            dts.append(dt)\n",
    "            iterations_to_converge.append(c)\n",
    "            defender_actions_sizes.append(len(A_d))\n",
    "            attacker_actions_sizes.append(len(A_a))\n",
    "            iteration_times_li.append(iteration_times)\n",
    "            gaps_li.append(gaps)\n",
    "            print(f\"{i}/23: timesteps:{num_timesteps}, num_defenders:{num_defenders}, dt:{dt}, support:{support}\")\n",
    "            i+=1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0aeea510-d28d-4383-aa89-494227e214aa",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "df = pd.DataFrame({\n",
    "    \"num_timesteps\": num_timesteps_li,\n",
    "    \"num_defenders\": num_defenders_li,\n",
    "    \"defense_time_threshold\": dts,\n",
    "    \"def_support\": supports,\n",
    "    \"iterations_to_converge\": iterations_to_converge,\n",
    "    \"iteration_time\": iteration_times_li,\n",
    "    \"gap\": gaps_li,\n",
    "    \"defender_actions_size\": defender_actions_sizes,\n",
    "    \"attacker_actions_size\": attacker_actions_sizes\n",
    "})\n",
    "\n",
    "# Step 2: Explode list columns\n",
    "exploded_df = df.explode([\"iteration_time\", \"gap\"], ignore_index=True)\n",
    "\n",
    "# Optional: Add a column for iteration number within each grouped trial\n",
    "exploded_df[\"iteration_number\"] = exploded_df.groupby(\n",
    "    [\"num_timesteps\", \"num_defenders\", \"defense_time_threshold\"]\n",
    ").cumcount()\n",
    "\n",
    "# Reorder if desired\n",
    "cols = [\n",
    "    \"num_timesteps\", \"num_defenders\", \"defense_time_threshold\",\n",
    "    \"iteration_number\", \"iteration_time\", \"gap\", \n",
    "    \"iterations_to_converge\", \"def_support\", \"defender_actions_size\", \"attacker_actions_size\"\n",
    "]\n",
    "exploded_df = exploded_df[cols]\n",
    "\n",
    "# Make iteration number 1-indexed\n",
    "exploded_df[\"iteration_number\"] += 1\n",
    "\n",
    "exploded_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e89c2956-a805-43d0-9724-0f71e9e2ff22",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "exploded_df.to_csv(\"GSG_SF_DO_MASS_FINAL.csv\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "a7ffde91-f349-40b3-bdf6-2af7b008fffa",
   "metadata": {},
   "source": [
    "# ISG RM SF"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "afbccead-e4f9-4feb-a566-e72abdfe7582",
   "metadata": {},
   "source": [
    "## RM"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5b59cd8e-7dda-4423-8b11-1499d37f6d0a",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "import warnings\n",
    "warnings.filterwarnings('ignore', category=FutureWarning)\n",
    "\n",
    "schedule_form_kwargs = {\n",
    "    \"schedule_form\": True,\n",
    "    \"simple\": False,\n",
    "    \"attacker_penalty_factor\": 3,\n",
    "    \"defender_penalty_factor\": 3,\n",
    "    \"extra_coverage_weight\":1\n",
    "}\n",
    "\n",
    "general_sum_kwargs = {\n",
    "    \"general_sum\": False,\n",
    "    \"attacker_feature_value\":  42, \n",
    "    \"defender_feature_value\": 69, \n",
    "    \"defender_step_cost\": 32.5, \n",
    "}\n",
    "\n",
    "# Bounding box for Hoboken, NJ\n",
    "# bbox_hoboken_small = (40.752635, 40.745600, -74.030386,-74.043903)\n",
    "bbox_hoboken_low = (40.745411, 40.735486, -74.025857,-74.041479)\n",
    "bbox_hoboken_east = (40.748337, 40.734641,-74.022961,-74.031286)\n",
    "bbox_downtown = (40.718721, 40.714078, -73.996074, -74.002651)\n",
    "bbox_downtown_large = (40.7215, 40.710, -73.9935, -74.010)\n",
    "# 40.7060, -74.0140, 40.7205, -73.9935\n",
    "college_police = (40.743293077312465, -74.02670221027175)\n",
    "police_station = (40.73768931976651, -74.02990519431108)\n",
    "traffic_police = (40.7366602084371, -74.03449866349136)\n",
    "downtown_station = (40.71232433042349, -74.00187755238431)\n",
    "fifth_ave_station = (40.71637413934789, -73.9973285259067)\n",
    "fifth_precinct = (40.71625547686622, -73.99736909131171)\n",
    "booking_station = (40.716191530904815, -74.00102237385177)\n",
    "police_plaza = (40.71236124409745, -74.00173715463521)\n",
    "troop_nyc = (40.71657885026091, -74.00641139014367)\n",
    "first_precinct = (40.720411300417446, -74.0070247584372)\n",
    "\n",
    "srm_num_timesteps_li = []\n",
    "srm_num_defenders_li= []\n",
    "srm_gaps_li = []\n",
    "srm_interval_times_li = []\n",
    "srm_dts = []\n",
    "\n",
    "start = time.time()\n",
    "for num_timesteps in [7,8,9,10]:\n",
    "    for num_defenders in [1,2,3]:\n",
    "        for dt in [1,2]:\n",
    "            print(f\"starting {num_timesteps} timesteps, {num_defenders} defenders, {dt} dt. Time since start: {time.time()-start}\")\n",
    "            isg = InfraSecurityGame(df_combined, ny_blocks_gdf, INFRA_WEIGHTS, bbox=bbox_downtown_large)\n",
    "            isg.generate(num_attackers=1, num_defenders=num_defenders, home_base_assignments=[(fifth_precinct,booking_station, troop_nyc, first_precinct, police_plaza) for i in range(num_defenders)], num_timesteps=num_timesteps, generate_utility_matrix=True, generate_actions=False, normalize=True, force_return=False, defense_time_threshold=dt, **general_sum_kwargs, **schedule_form_kwargs)\n",
    "            D_d, U, gaps, interval_times = regret_matching(isg.schedule_form_dict[\"defender_utility_matrix\"], runtime=120, interval=5, iterations=10000, averaging=0, alternations=False, plus=False, predictive=False, verbose=False)\n",
    "            srm_num_timesteps_li.append(num_timesteps)\n",
    "            srm_num_defenders_li.append(num_defenders)\n",
    "            srm_dts.append(dt)\n",
    "            srm_gaps_li.append(gaps)\n",
    "            srm_interval_times_li.append(interval_times)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f4377bda-bad9-4374-b88f-8a23ddde564d",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "df = pd.DataFrame({\n",
    "    \"num_timesteps\": srm_num_timesteps_li,\n",
    "    \"num_attackers\": [1 for i in range(len(srm_num_timesteps_li))],\n",
    "    \"num_defenders\": srm_num_defenders_li,\n",
    "    \"defense_time_threshold\": srm_dts,\n",
    "    \"iteration_times\": srm_interval_times_li,\n",
    "    \"gaps\": srm_gaps_li\n",
    "})\n",
    "\n",
    "# Step 2: Explode list columns\n",
    "exploded_df = df.explode([\"iteration_times\", \"gaps\"], ignore_index=True)\n",
    "\n",
    "# Optional: Add a column for iteration number within each trial\n",
    "exploded_df[\"interval_number\"] = exploded_df.groupby([\"num_timesteps\",\"num_defenders\",\"defense_time_threshold\"]).cumcount()\n",
    "\n",
    "# Reorder if desired\n",
    "cols = [\"num_timesteps\", \"num_attackers\", \"num_defenders\", \"defense_time_threshold\", \"interval_number\", \"iteration_times\", \"gaps\"]\n",
    "exploded_df = exploded_df[cols]\n",
    "\n",
    "exploded_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d0036e24-1858-4018-aa14-28d76aa75a80",
   "metadata": {},
   "outputs": [],
   "source": [
    "exploded_df[\"interval_number\"] = exploded_df[\"interval_number\"]+1\n",
    "exploded_df[\"iteration_number\"] = exploded_df[\"interval_number\"]*5"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5c21ea57-9b89-48ca-b974-e6c375a8c307",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "exploded_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ede32a24-eff1-42bd-9b79-114ad56afdbf",
   "metadata": {},
   "outputs": [],
   "source": [
    "exploded_df.to_csv(\"ISG_SF_RM_FINAL.csv\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "4f01e705-8961-4049-9d47-06764afa0b32",
   "metadata": {},
   "source": [
    "## RM+"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "id": "ea68d358-70af-4bf7-a160-209025455e20",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration 5 gap:  0.3291100995199514\n",
      "Iteration 10 gap:  0.3032754352319451\n",
      "Iteration 15 gap:  0.25078459795552965\n",
      "Iteration 20 gap:  0.18361216358041\n",
      "Iteration 25 gap:  0.18970649948216656\n",
      "Iteration 30 gap:  0.1306736299894199\n",
      "Iteration 35 gap:  0.08532226692061506\n",
      "Iteration 40 gap:  0.055826586591956384\n",
      "Iteration 45 gap:  0.03401778527102994\n",
      "Iteration 50 gap:  0.028969902257946267\n",
      "Iteration 55 gap:  0.03235888746526849\n",
      "Iteration 60 gap:  0.03680069664156421\n",
      "Iteration 65 gap:  0.038449469657900526\n",
      "Iteration 70 gap:  0.03245780624901673\n",
      "Iteration 75 gap:  0.023607791341489104\n",
      "Iteration 80 gap:  0.021991578589614313\n",
      "Iteration 85 gap:  0.018147426103273134\n",
      "Iteration 90 gap:  0.017227202534622066\n",
      "Iteration 95 gap:  0.017220619081911637\n",
      "Iteration 100 gap:  0.015892297353764295\n",
      "Iteration 105 gap:  0.01597225141939035\n",
      "Iteration 110 gap:  0.014302133846703313\n",
      "Iteration 115 gap:  0.01205668708297708\n",
      "Iteration 120 gap:  0.00995463720836487\n",
      "Iteration 125 gap:  0.009045367551522465\n",
      "Iteration 130 gap:  0.00918505436856154\n",
      "Iteration 135 gap:  0.00917210180518746\n",
      "Iteration 140 gap:  0.009220108828549456\n",
      "Iteration 145 gap:  0.007817821824707916\n",
      "Iteration 150 gap:  0.007045730053167998\n",
      "Iteration 155 gap:  0.006009892236093717\n",
      "Iteration 160 gap:  0.005511633670681304\n",
      "Iteration 165 gap:  0.00579115035963973\n",
      "Iteration 170 gap:  0.005815207918415444\n",
      "Iteration 175 gap:  0.006094794970476547\n",
      "Iteration 180 gap:  0.005450654857491577\n",
      "Iteration 185 gap:  0.004565817981413256\n",
      "Iteration 190 gap:  0.0037873962018327156\n",
      "Iteration 195 gap:  0.0037710926327392813\n",
      "Iteration 200 gap:  0.004091763129229431\n",
      "Iteration 205 gap:  0.00428223112267373\n",
      "Iteration 210 gap:  0.004348401182393435\n",
      "Iteration 215 gap:  0.003558424728168308\n",
      "Iteration 220 gap:  0.003194373120509686\n",
      "Iteration 225 gap:  0.002724507233012319\n",
      "Iteration 230 gap:  0.0026255158209577134\n",
      "Iteration 235 gap:  0.002978872055721893\n",
      "Iteration 240 gap:  0.0031905213428092827\n",
      "Iteration 245 gap:  0.003295995595778478\n",
      "Iteration 250 gap:  0.0028146394146504883\n",
      "Iteration 255 gap:  0.0022647783632988583\n",
      "Iteration 260 gap:  0.001892318289562378\n",
      "Iteration 265 gap:  0.0021516528676618907\n",
      "Iteration 270 gap:  0.002391120999178542\n",
      "Iteration 275 gap:  0.002546548265820403\n",
      "Iteration 280 gap:  0.002551028067490413\n",
      "Iteration 285 gap:  0.002016683620383819\n",
      "Iteration 290 gap:  0.0017742294744719223\n",
      "Iteration 295 gap:  0.001489054086900754\n",
      "Iteration 300 gap:  0.001575607343278218\n",
      "Iteration 305 gap:  0.0018672357093026393\n",
      "Iteration 310 gap:  0.0021189328869804513\n",
      "Iteration 315 gap:  0.0020462035002967727\n",
      "Iteration 320 gap:  0.0016517204820879483\n",
      "Iteration 325 gap:  0.0013045740539599504\n",
      "Iteration 330 gap:  0.0011157577144021436\n",
      "Iteration 335 gap:  0.0014423443477150077\n",
      "Iteration 340 gap:  0.0015929494837135794\n",
      "Iteration 345 gap:  0.0017253693760748146\n",
      "Iteration 350 gap:  0.0016748708951169755\n",
      "Iteration 355 gap:  0.0013039141970873636\n",
      "Iteration 360 gap:  0.0010824161369871743\n",
      "Iteration 365 gap:  0.0009230425752675409\n",
      "Iteration 370 gap:  0.0010778896791017178\n",
      "Iteration 375 gap:  0.0013345772711366166\n",
      "Iteration 380 gap:  0.0015420322408907783\n",
      "Iteration 385 gap:  0.0013507314493706457\n",
      "Iteration 390 gap:  0.0010615073074638492\n",
      "Iteration 395 gap:  0.0009071871380486041\n",
      "Iteration 400 gap:  0.0007445188386804857\n",
      "Iteration 405 gap:  0.001036073258508019\n",
      "Iteration 410 gap:  0.0011489159438056729\n",
      "Iteration 415 gap:  0.001260601305191067\n",
      "Iteration 420 gap:  0.0011826494278239785\n",
      "Iteration 425 gap:  0.0009087421206067092\n",
      "Iteration 430 gap:  0.0008061586552748912\n",
      "Iteration 435 gap:  0.0006343864429400048\n",
      "Iteration 440 gap:  0.0007959989354742181\n",
      "Iteration 445 gap:  0.0010391233207694972\n",
      "Iteration 450 gap:  0.001172726644723232\n",
      "Iteration 455 gap:  0.0009515065372027731\n",
      "Iteration 460 gap:  0.0007318279452361853\n",
      "Iteration 465 gap:  0.000710625578712154\n",
      "Iteration 470 gap:  0.0005578887580878766\n",
      "Iteration 475 gap:  0.00076663363275975\n",
      "Iteration 480 gap:  0.0008904095895139741\n",
      "Iteration 485 gap:  0.0009603723616359305\n",
      "Iteration 490 gap:  0.0008942215960390798\n",
      "Iteration 495 gap:  0.000647205955718988\n",
      "Iteration 500 gap:  0.0006261888376248859\n",
      "Iteration 505 gap:  0.00046413114304966196\n",
      "Iteration 510 gap:  0.0006179051898334009\n",
      "Iteration 515 gap:  0.0008486368433415215\n",
      "Iteration 520 gap:  0.000910523472763658\n",
      "Iteration 525 gap:  0.0007162912345060057\n",
      "Iteration 530 gap:  0.0005267147925605564\n",
      "Iteration 535 gap:  0.0005932268291486964\n",
      "Iteration 540 gap:  0.00043123922599791475\n",
      "Iteration 545 gap:  0.0005918576406878651\n",
      "Iteration 550 gap:  0.0007232541780513579\n",
      "Iteration 555 gap:  0.0007643891659991353\n",
      "Iteration 560 gap:  0.0007135553509314829\n",
      "Iteration 565 gap:  0.0005187599359873785\n",
      "Iteration 570 gap:  0.0005087248286402835\n",
      "Iteration 575 gap:  0.0003474889359112443\n",
      "Iteration 580 gap:  0.0005026116538247583\n",
      "Iteration 585 gap:  0.0006997050756872292\n",
      "Iteration 590 gap:  0.0007253618682274698\n",
      "Iteration 595 gap:  0.0005673176751705977\n",
      "Iteration 600 gap:  0.0004038316732738467\n",
      "Iteration 605 gap:  0.000513617729795024\n",
      "Iteration 610 gap:  0.00033975597796670476\n",
      "Iteration 615 gap:  0.0004771407139193551\n",
      "Iteration 620 gap:  0.0006017473697331188\n",
      "Iteration 625 gap:  0.0006388476537910193\n",
      "Iteration 630 gap:  0.000586955228316477\n",
      "Iteration 635 gap:  0.00043269174668914\n",
      "Iteration 640 gap:  0.0004284574374372463\n",
      "Iteration 645 gap:  0.0002748795524684655\n",
      "Iteration 650 gap:  0.000421058969567345\n",
      "Iteration 655 gap:  0.0005818083881014013\n",
      "Iteration 660 gap:  0.00060108739069753\n",
      "Iteration 665 gap:  0.0004659283722260321\n",
      "Iteration 670 gap:  0.0003546283494024749\n",
      "Iteration 675 gap:  0.00044750840861651486\n",
      "Iteration 680 gap:  0.0002830471221019204\n",
      "Iteration 685 gap:  0.00038782748291571467\n",
      "Iteration 690 gap:  0.0005124989308043504\n",
      "Iteration 695 gap:  0.0005502824423342934\n",
      "Iteration 700 gap:  0.0004945190913004938\n",
      "Iteration 705 gap:  0.00036837349482821136\n",
      "Iteration 710 gap:  0.00036993626481074404\n",
      "Iteration 715 gap:  0.0002272040429999178\n",
      "Iteration 720 gap:  0.00035294603366209376\n",
      "Iteration 725 gap:  0.0004906194709101142\n",
      "Iteration 730 gap:  0.0005133219488376306\n",
      "Iteration 735 gap:  0.00039692791524331694\n",
      "Iteration 740 gap:  0.0003162237811451529\n",
      "Iteration 745 gap:  0.0003938429113456432\n",
      "Iteration 750 gap:  0.00024392587030797053\n",
      "Iteration 755 gap:  0.00031903941188410334\n",
      "Iteration 760 gap:  0.0004364586655502545\n",
      "Iteration 765 gap:  0.0004856512614164199\n",
      "Iteration 770 gap:  0.00042537078719989685\n",
      "Iteration 775 gap:  0.00031623218760773453\n",
      "Iteration 780 gap:  0.0003263388995019545\n",
      "Iteration 785 gap:  0.0002055335270120806\n",
      "Iteration 790 gap:  0.000294938344970741\n",
      "Iteration 795 gap:  0.00041273216578630034\n",
      "Iteration 800 gap:  0.00044760069414723214\n",
      "Iteration 805 gap:  0.0003477382232117687\n",
      "Iteration 810 gap:  0.0002789528570443789\n",
      "Iteration 815 gap:  0.00035008214529336223\n",
      "Iteration 820 gap:  0.00022090896334686638\n",
      "Iteration 825 gap:  0.00026088483971525855\n",
      "Iteration 830 gap:  0.0003726138848455518\n",
      "Iteration 835 gap:  0.00043350710484574284\n",
      "Iteration 840 gap:  0.0003751824771872081\n",
      "Iteration 845 gap:  0.0002726703989827106\n",
      "Iteration 850 gap:  0.0002920334515721379\n",
      "Iteration 855 gap:  0.00020436300910642302\n",
      "Iteration 860 gap:  0.00024161720659759967\n",
      "Iteration 865 gap:  0.0003493646430884345\n",
      "Iteration 870 gap:  0.0003964483021077214\n",
      "Iteration 875 gap:  0.0003150283506946905\n",
      "Iteration 880 gap:  0.0002431984976593582\n",
      "Iteration 885 gap:  0.0003138089087345586\n",
      "Iteration 890 gap:  0.00020985136213108602\n",
      "Iteration 895 gap:  0.00021004607259034191\n",
      "Iteration 900 gap:  0.00031720138760865657\n",
      "Iteration 905 gap:  0.000388265425587897\n",
      "Iteration 910 gap:  0.0003415213112364368\n",
      "Iteration 915 gap:  0.00023177065134705188\n",
      "Iteration 920 gap:  0.0002646798529354899\n",
      "Iteration 925 gap:  0.00020874031642731383\n",
      "Iteration 930 gap:  0.00019269065367649718\n",
      "Iteration 935 gap:  0.00029694407041003235\n",
      "Iteration 940 gap:  0.0003528923015955199\n",
      "Iteration 945 gap:  0.0002956464577674178\n",
      "Iteration 950 gap:  0.00022534566723214633\n",
      "Iteration 955 gap:  0.0002844381626760928\n",
      "Iteration 960 gap:  0.00020638625761115748\n",
      "Iteration 965 gap:  0.0001658102212083179\n",
      "Iteration 970 gap:  0.00026849391289912594\n",
      "Iteration 975 gap:  0.00034802868017758115\n",
      "Iteration 980 gap:  0.0003182031777186345\n",
      "Iteration 985 gap:  0.00019170643472260496\n",
      "Iteration 990 gap:  0.00023978500749027853\n",
      "Iteration 995 gap:  0.00021422582800412204\n",
      "Iteration 1000 gap:  0.0001499109180728153\n",
      "Iteration 1005 gap:  0.00025071613551630456\n",
      "Iteration 1010 gap:  0.0003132680421689682\n",
      "Iteration 1015 gap:  0.000284015968115614\n",
      "Iteration 1020 gap:  0.00022347503022873694\n",
      "Iteration 1025 gap:  0.00025938033431349705\n",
      "Iteration 1030 gap:  0.00020599162286827344\n",
      "Iteration 1035 gap:  0.00012848547237886976\n",
      "Iteration 1040 gap:  0.0002239465298176646\n",
      "Iteration 1045 gap:  0.00031099769899184393\n",
      "Iteration 1050 gap:  0.0002992788997924767\n",
      "Iteration 1055 gap:  0.00018572917894321694\n",
      "Iteration 1060 gap:  0.00021333219967839545\n",
      "Iteration 1065 gap:  0.0002186139363949402\n",
      "Iteration 1070 gap:  0.00011848381661061502\n",
      "Iteration 1075 gap:  0.00020759700339068043\n",
      "Iteration 1080 gap:  0.00027550576266205384\n",
      "Iteration 1085 gap:  0.00027325814723416775\n",
      "Iteration 1090 gap:  0.000225780243013729\n",
      "Iteration 1095 gap:  0.00023351290415918324\n",
      "Iteration 1100 gap:  0.0002043894836876725\n",
      "Iteration 1105 gap:  9.73188462863872e-05\n",
      "Iteration 1110 gap:  0.00018057110146207922\n",
      "Iteration 1115 gap:  0.0002744810069444936\n",
      "Iteration 1120 gap:  0.00028280018772630644\n",
      "Iteration 1125 gap:  0.00019062015503562568\n",
      "Iteration 1130 gap:  0.00018444503989034633\n",
      "Iteration 1135 gap:  0.0002201990642304863\n",
      "Iteration 1140 gap:  0.00013881463744636058\n",
      "Iteration 1145 gap:  0.0001736859693959314\n",
      "Iteration 1150 gap:  0.00023717124538064072\n",
      "Iteration 1155 gap:  0.0002606490818703455\n",
      "Iteration 1160 gap:  0.0002305279407833205\n",
      "Iteration 1165 gap:  0.00020339688515436105\n",
      "Iteration 1170 gap:  0.0001992525917606236\n",
      "Iteration 1175 gap:  0.00011423317854869497\n",
      "Iteration 1180 gap:  0.0001389651540401049\n",
      "Iteration 1185 gap:  0.00023785264311149135\n",
      "Iteration 1190 gap:  0.00026460605706446483\n",
      "Iteration 1195 gap:  0.00019757498688455222\n",
      "Iteration 1200 gap:  0.0001515642822560448\n",
      "Iteration 1205 gap:  0.00021639038910609143\n",
      "Iteration 1210 gap:  0.0001572317055972272\n",
      "Iteration 1215 gap:  0.0001378854590944889\n",
      "Iteration 1220 gap:  0.0001971669202515125\n",
      "Iteration 1225 gap:  0.0002439822114987389\n",
      "Iteration 1230 gap:  0.00023465129170952004\n",
      "Iteration 1235 gap:  0.00016801988779535648\n",
      "Iteration 1240 gap:  0.00018801154797093433\n",
      "Iteration 1245 gap:  0.00013906222617049435\n",
      "Iteration 1250 gap:  0.00010052432676577183\n",
      "Iteration 1255 gap:  0.00020031738010739542\n",
      "Iteration 1260 gap:  0.00024158430927906371\n",
      "Iteration 1265 gap:  0.00020381207677033775\n",
      "Iteration 1270 gap:  0.0001445941540471063\n",
      "Iteration 1275 gap:  0.00020424908135141528\n",
      "Iteration 1280 gap:  0.00017117467770777495\n",
      "Iteration 1285 gap:  9.94053210213175e-05\n",
      "Iteration 1290 gap:  0.0001562554990213738\n",
      "Iteration 1295 gap:  0.00022148874824273745\n",
      "Iteration 1300 gap:  0.00023394409502003333\n",
      "Iteration 1305 gap:  0.00015191412206788657\n",
      "Iteration 1310 gap:  0.00016861921390226575\n",
      "Iteration 1315 gap:  0.00015882660699773066\n",
      "Iteration 1320 gap:  8.925314309315979e-05\n",
      "Iteration 1325 gap:  0.00016178379564391054\n",
      "Iteration 1330 gap:  0.00021440320136417723\n",
      "Iteration 1335 gap:  0.00020479398466771714\n",
      "Iteration 1340 gap:  0.00016435980549345253\n",
      "Iteration 1345 gap:  0.0001824608572160158\n",
      "Iteration 1350 gap:  0.00017702957185655732\n",
      "Iteration 1355 gap:  8.775883878497925e-05\n",
      "Iteration 1360 gap:  0.00011610366855174803\n",
      "Iteration 1365 gap:  0.00019241958342752774\n",
      "Iteration 1370 gap:  0.00022617218791548543\n",
      "Iteration 1375 gap:  0.0001710024705447455\n",
      "Iteration 1380 gap:  0.00014162079212881595\n",
      "Iteration 1385 gap:  0.00016804075615683978\n",
      "Iteration 1390 gap:  0.00011842989262633719\n",
      "Iteration 1395 gap:  0.00012318256009796746\n",
      "Iteration 1400 gap:  0.00018185019621458354\n",
      "Iteration 1405 gap:  0.00019905757678029268\n",
      "Iteration 1410 gap:  0.00018039784800588654\n",
      "Iteration 1415 gap:  0.00015029495943186255\n",
      "Iteration 1420 gap:  0.00017245554050882017\n",
      "Iteration 1425 gap:  0.00012295827548414184\n",
      "Iteration 1430 gap:  8.115798589586332e-05\n",
      "Iteration 1435 gap:  0.0001602905429403112\n",
      "Iteration 1440 gap:  0.00021072328640187044\n",
      "Iteration 1445 gap:  0.00018324818842851975\n",
      "Iteration 1450 gap:  0.00012120946110744102\n",
      "Iteration 1455 gap:  0.0001626895572487408\n",
      "Iteration 1460 gap:  0.0001388898122280935\n",
      "Iteration 1465 gap:  8.886882571390586e-05\n",
      "Iteration 1470 gap:  0.00014251902550072026\n",
      "Iteration 1475 gap:  0.00018644885478585893\n",
      "Iteration 1480 gap:  0.00018786959351402288\n",
      "Iteration 1485 gap:  0.00012496007135770482\n",
      "Iteration 1490 gap:  0.0001560737863194328\n",
      "Iteration 1495 gap:  0.00014728841221700595\n",
      "Iteration 1500 gap:  7.338532485812177e-05\n",
      "Iteration 1505 gap:  0.000122005208855136\n",
      "\n"
     ]
    }
   ],
   "source": [
    "import warnings\n",
    "warnings.filterwarnings('ignore', category=FutureWarning)\n",
    "\n",
    "schedule_form_kwargs = {\n",
    "    \"schedule_form\": True,\n",
    "    \"simple\": False,\n",
    "    \"attacker_penalty_factor\": 3,\n",
    "    \"defender_penalty_factor\": 3,\n",
    "}\n",
    "\n",
    "general_sum_kwargs = {\n",
    "    \"general_sum\": False,\n",
    "    \"attacker_feature_value\":  42, \n",
    "    \"defender_feature_value\": 69, \n",
    "    \"defender_step_cost\": 32.5, \n",
    "}\n",
    "\n",
    "# Bounding box for Hoboken, NJ\n",
    "# bbox_hoboken_small = (40.752635, 40.745600, -74.030386,-74.043903)\n",
    "bbox_hoboken_low = (40.745411, 40.735486, -74.025857,-74.041479)\n",
    "bbox_hoboken_east = (40.748337, 40.734641,-74.022961,-74.031286)\n",
    "bbox_downtown = (40.718721, 40.714078, -73.996074, -74.002651)\n",
    "bbox_downtown_large = (40.7215, 40.710, -73.9935, -74.010)\n",
    "# 40.7060, -74.0140, 40.7205, -73.9935\n",
    "college_police = (40.743293077312465, -74.02670221027175)\n",
    "police_station = (40.73768931976651, -74.02990519431108)\n",
    "traffic_police = (40.7366602084371, -74.03449866349136)\n",
    "downtown_station = (40.71232433042349, -74.00187755238431)\n",
    "fifth_ave_station = (40.71637413934789, -73.9973285259067)\n",
    "fifth_precinct = (40.71625547686622, -73.99736909131171)\n",
    "booking_station = (40.716191530904815, -74.00102237385177)\n",
    "police_plaza = (40.71236124409745, -74.00173715463521)\n",
    "troop_nyc = (40.71657885026091, -74.00641139014367)\n",
    "first_precinct = (40.720411300417446, -74.0070247584372)\n",
    "\n",
    "srmp_num_timesteps_li = []\n",
    "srmp_num_defenders_li= []\n",
    "srmp_gaps_li = []\n",
    "srmp_interval_times_li = []\n",
    "srmp_dts = []\n",
    "\n",
    "# start = time.time()\n",
    "# for num_timesteps in [7,8,9,10]:\n",
    "#     for num_defenders in [1,2,3]:\n",
    "#         for dt in [1,2]:\n",
    "#             print(f\"starting {num_timesteps} timesteps, {num_defenders} defenders, {dt} dt. Time since start: {time.time()-start}\")\n",
    "#             isg = InfraSecurityGame(df_combined, ny_blocks_gdf, INFRA_WEIGHTS, bbox=bbox_downtown_large)\n",
    "#             isg.generate(num_attackers=1, num_defenders=num_defenders, home_base_assignments=[(fifth_precinct,booking_station, troop_nyc, first_precinct, police_plaza) for i in range(num_defenders)], num_timesteps=num_timesteps, generate_utility_matrix=True, generate_actions=False, normalize=True, force_return=False, defense_time_threshold=dt, **general_sum_kwargs, **schedule_form_kwargs)\n",
    "#             D_d, U, gaps, interval_times = regret_matching(isg.schedule_form_dict[\"defender_utility_matrix\"], runtime=120, interval=5, iterations=10000, averaging=0, alternations=False, plus=True, predictive=False, verbose=False)\n",
    "#             srmp_num_timesteps_li.append(num_timesteps)\n",
    "#             srmp_num_defenders_li.append(num_defenders)\n",
    "#             srmp_dts.append(dt)\n",
    "#             srmp_gaps_li.append(gaps)\n",
    "#             srmp_interval_times_li.append(interval_times)\n",
    "\n",
    "isg = InfraSecurityGame(df_combined, ny_blocks_gdf, INFRA_WEIGHTS, bbox=bbox_downtown_large)\n",
    "isg.generate(num_attackers=1, num_defenders=2, home_base_assignments=[(fifth_precinct,booking_station, troop_nyc, first_precinct, police_plaza),(fifth_precinct,booking_station, troop_nyc, first_precinct, police_plaza)], num_timesteps=8, generate_utility_matrix=True, generate_actions=False, force_return=False, defense_time_threshold=1, **general_sum_kwargs, **schedule_form_kwargs)\n",
    "D_d, U, gaps, interval_times = regret_matching(isg.schedule_form_dict[\"defender_utility_matrix\"], runtime=120, interval=5, iterations=10000, averaging=1, alternations=True, plus=True, predictive=False, verbose=True)\n",
    "srmp_num_timesteps_li.append(8)\n",
    "srmp_num_defenders_li.append(2)\n",
    "srmp_dts.append(1)\n",
    "srmp_gaps_li.append(gaps)\n",
    "srmp_interval_times_li.append(interval_times)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "id": "ec80b770-e837-4b31-aff8-6b8e234f2ab6",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>num_timesteps</th>\n",
       "      <th>num_attackers</th>\n",
       "      <th>num_defenders</th>\n",
       "      <th>defense_time_threshold</th>\n",
       "      <th>interval_number</th>\n",
       "      <th>iteration_times</th>\n",
       "      <th>gaps</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>2</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>0.316202</td>\n",
       "      <td>0.32911</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>2</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>0.277185</td>\n",
       "      <td>0.303275</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>2</td>\n",
       "      <td>1</td>\n",
       "      <td>2</td>\n",
       "      <td>0.29678</td>\n",
       "      <td>0.250785</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>2</td>\n",
       "      <td>1</td>\n",
       "      <td>3</td>\n",
       "      <td>0.372289</td>\n",
       "      <td>0.183612</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>2</td>\n",
       "      <td>1</td>\n",
       "      <td>4</td>\n",
       "      <td>0.307578</td>\n",
       "      <td>0.189706</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>296</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>2</td>\n",
       "      <td>1</td>\n",
       "      <td>296</td>\n",
       "      <td>0.307277</td>\n",
       "      <td>0.000125</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>297</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>2</td>\n",
       "      <td>1</td>\n",
       "      <td>297</td>\n",
       "      <td>0.330485</td>\n",
       "      <td>0.000156</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>298</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>2</td>\n",
       "      <td>1</td>\n",
       "      <td>298</td>\n",
       "      <td>0.349593</td>\n",
       "      <td>0.000147</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>299</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>2</td>\n",
       "      <td>1</td>\n",
       "      <td>299</td>\n",
       "      <td>0.346905</td>\n",
       "      <td>0.000073</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>300</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>2</td>\n",
       "      <td>1</td>\n",
       "      <td>300</td>\n",
       "      <td>0.342199</td>\n",
       "      <td>0.000122</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>301 rows × 7 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "     num_timesteps  num_attackers  num_defenders  defense_time_threshold  \\\n",
       "0                8              1              2                       1   \n",
       "1                8              1              2                       1   \n",
       "2                8              1              2                       1   \n",
       "3                8              1              2                       1   \n",
       "4                8              1              2                       1   \n",
       "..             ...            ...            ...                     ...   \n",
       "296              8              1              2                       1   \n",
       "297              8              1              2                       1   \n",
       "298              8              1              2                       1   \n",
       "299              8              1              2                       1   \n",
       "300              8              1              2                       1   \n",
       "\n",
       "     interval_number iteration_times      gaps  \n",
       "0                  0        0.316202   0.32911  \n",
       "1                  1        0.277185  0.303275  \n",
       "2                  2         0.29678  0.250785  \n",
       "3                  3        0.372289  0.183612  \n",
       "4                  4        0.307578  0.189706  \n",
       "..               ...             ...       ...  \n",
       "296              296        0.307277  0.000125  \n",
       "297              297        0.330485  0.000156  \n",
       "298              298        0.349593  0.000147  \n",
       "299              299        0.346905  0.000073  \n",
       "300              300        0.342199  0.000122  \n",
       "\n",
       "[301 rows x 7 columns]"
      ]
     },
     "execution_count": 40,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df = pd.DataFrame({\n",
    "    \"num_timesteps\": srmp_num_timesteps_li,\n",
    "    \"num_attackers\": [1 for i in range(len(srmp_num_timesteps_li))],\n",
    "    \"num_defenders\": srmp_num_defenders_li,\n",
    "    \"defense_time_threshold\": srmp_dts,\n",
    "    \"iteration_times\": srmp_interval_times_li,\n",
    "    \"gaps\": srmp_gaps_li\n",
    "})\n",
    "\n",
    "# Step 2: Explode list columns\n",
    "exploded_df = df.explode([\"iteration_times\", \"gaps\"], ignore_index=True)\n",
    "\n",
    "# Optional: Add a column for iteration number within each trial\n",
    "exploded_df[\"interval_number\"] = exploded_df.groupby([\"num_timesteps\",\"num_defenders\",\"defense_time_threshold\"]).cumcount()\n",
    "\n",
    "# Reorder if desired\n",
    "cols = [\"num_timesteps\", \"num_attackers\", \"num_defenders\", \"defense_time_threshold\", \"interval_number\", \"iteration_times\", \"gaps\"]\n",
    "exploded_df = exploded_df[cols]\n",
    "\n",
    "exploded_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "id": "d2f3e0e6-c676-4227-b11d-39c58b229045",
   "metadata": {},
   "outputs": [],
   "source": [
    "exploded_df[\"interval_number\"] = exploded_df[\"interval_number\"]+1\n",
    "exploded_df[\"iteration_number\"] = exploded_df[\"interval_number\"]*5"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "id": "5b410a74-a551-4881-816a-7b5597c06eaa",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>num_timesteps</th>\n",
       "      <th>num_attackers</th>\n",
       "      <th>num_defenders</th>\n",
       "      <th>defense_time_threshold</th>\n",
       "      <th>interval_number</th>\n",
       "      <th>iteration_times</th>\n",
       "      <th>gaps</th>\n",
       "      <th>iteration_number</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>2</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>0.316202</td>\n",
       "      <td>0.32911</td>\n",
       "      <td>5</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>2</td>\n",
       "      <td>1</td>\n",
       "      <td>2</td>\n",
       "      <td>0.277185</td>\n",
       "      <td>0.303275</td>\n",
       "      <td>10</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>2</td>\n",
       "      <td>1</td>\n",
       "      <td>3</td>\n",
       "      <td>0.29678</td>\n",
       "      <td>0.250785</td>\n",
       "      <td>15</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>2</td>\n",
       "      <td>1</td>\n",
       "      <td>4</td>\n",
       "      <td>0.372289</td>\n",
       "      <td>0.183612</td>\n",
       "      <td>20</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>2</td>\n",
       "      <td>1</td>\n",
       "      <td>5</td>\n",
       "      <td>0.307578</td>\n",
       "      <td>0.189706</td>\n",
       "      <td>25</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>296</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>2</td>\n",
       "      <td>1</td>\n",
       "      <td>297</td>\n",
       "      <td>0.307277</td>\n",
       "      <td>0.000125</td>\n",
       "      <td>1485</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>297</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>2</td>\n",
       "      <td>1</td>\n",
       "      <td>298</td>\n",
       "      <td>0.330485</td>\n",
       "      <td>0.000156</td>\n",
       "      <td>1490</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>298</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>2</td>\n",
       "      <td>1</td>\n",
       "      <td>299</td>\n",
       "      <td>0.349593</td>\n",
       "      <td>0.000147</td>\n",
       "      <td>1495</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>299</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>2</td>\n",
       "      <td>1</td>\n",
       "      <td>300</td>\n",
       "      <td>0.346905</td>\n",
       "      <td>0.000073</td>\n",
       "      <td>1500</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>300</th>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>2</td>\n",
       "      <td>1</td>\n",
       "      <td>301</td>\n",
       "      <td>0.342199</td>\n",
       "      <td>0.000122</td>\n",
       "      <td>1505</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>301 rows × 8 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "     num_timesteps  num_attackers  num_defenders  defense_time_threshold  \\\n",
       "0                8              1              2                       1   \n",
       "1                8              1              2                       1   \n",
       "2                8              1              2                       1   \n",
       "3                8              1              2                       1   \n",
       "4                8              1              2                       1   \n",
       "..             ...            ...            ...                     ...   \n",
       "296              8              1              2                       1   \n",
       "297              8              1              2                       1   \n",
       "298              8              1              2                       1   \n",
       "299              8              1              2                       1   \n",
       "300              8              1              2                       1   \n",
       "\n",
       "     interval_number iteration_times      gaps  iteration_number  \n",
       "0                  1        0.316202   0.32911                 5  \n",
       "1                  2        0.277185  0.303275                10  \n",
       "2                  3         0.29678  0.250785                15  \n",
       "3                  4        0.372289  0.183612                20  \n",
       "4                  5        0.307578  0.189706                25  \n",
       "..               ...             ...       ...               ...  \n",
       "296              297        0.307277  0.000125              1485  \n",
       "297              298        0.330485  0.000156              1490  \n",
       "298              299        0.349593  0.000147              1495  \n",
       "299              300        0.346905  0.000073              1500  \n",
       "300              301        0.342199  0.000122              1505  \n",
       "\n",
       "[301 rows x 8 columns]"
      ]
     },
     "execution_count": 42,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "exploded_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "id": "08675446-c51b-4673-9c88-1f50aecdfad6",
   "metadata": {},
   "outputs": [],
   "source": [
    "exploded_df.to_csv(\"ISG_SF_NEw_RMP_FINAL.csv\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "0340f5fe-6138-407e-a311-54d080d4c72a",
   "metadata": {},
   "source": [
    "## PRM+"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6254382c-d7aa-4aca-a483-4ac9b248e7fe",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "import warnings\n",
    "warnings.filterwarnings('ignore', category=FutureWarning)\n",
    "\n",
    "schedule_form_kwargs = {\n",
    "    \"schedule_form\": True,\n",
    "    \"simple\": False,\n",
    "    \"attacker_penalty_factor\": 3,\n",
    "    \"defender_penalty_factor\": 3,\n",
    "    \"extra_coverage_weight\":1\n",
    "}\n",
    "\n",
    "general_sum_kwargs = {\n",
    "    \"general_sum\": False,\n",
    "    \"attacker_feature_value\":  42, \n",
    "    \"defender_feature_value\": 69, \n",
    "    \"defender_step_cost\": 32.5, \n",
    "}\n",
    "\n",
    "# Bounding box for Hoboken, NJ\n",
    "# bbox_hoboken_small = (40.752635, 40.745600, -74.030386,-74.043903)\n",
    "bbox_hoboken_low = (40.745411, 40.735486, -74.025857,-74.041479)\n",
    "bbox_hoboken_east = (40.748337, 40.734641,-74.022961,-74.031286)\n",
    "bbox_downtown = (40.718721, 40.714078, -73.996074, -74.002651)\n",
    "bbox_downtown_large = (40.7215, 40.710, -73.9935, -74.010)\n",
    "# 40.7060, -74.0140, 40.7205, -73.9935\n",
    "college_police = (40.743293077312465, -74.02670221027175)\n",
    "police_station = (40.73768931976651, -74.02990519431108)\n",
    "traffic_police = (40.7366602084371, -74.03449866349136)\n",
    "downtown_station = (40.71232433042349, -74.00187755238431)\n",
    "fifth_ave_station = (40.71637413934789, -73.9973285259067)\n",
    "fifth_precinct = (40.71625547686622, -73.99736909131171)\n",
    "booking_station = (40.716191530904815, -74.00102237385177)\n",
    "police_plaza = (40.71236124409745, -74.00173715463521)\n",
    "troop_nyc = (40.71657885026091, -74.00641139014367)\n",
    "first_precinct = (40.720411300417446, -74.0070247584372)\n",
    "\n",
    "sprmp_num_timesteps_li = []\n",
    "sprmp_num_defenders_li= []\n",
    "sprmp_gaps_li = []\n",
    "sprmp_interval_times_li = []\n",
    "sprmp_dts = []\n",
    "\n",
    "start = time.time()\n",
    "for num_timesteps in [7,8,9,10]:\n",
    "    for num_defenders in [1,2,3]:\n",
    "        for dt in [1,2]:\n",
    "            print(f\"starting {num_timesteps} timesteps, {num_defenders} defenders, {dt} dt. Time since start: {time.time()-start}\")\n",
    "            isg = InfraSecurityGame(df_combined, ny_blocks_gdf, INFRA_WEIGHTS, bbox=bbox_downtown_large)\n",
    "            isg.generate(num_attackers=1, num_defenders=num_defenders, home_base_assignments=[(fifth_precinct,booking_station, troop_nyc, first_precinct, police_plaza) for i in range(num_defenders)], num_timesteps=num_timesteps, generate_utility_matrix=True, generate_actions=False, normalize=True, force_return=False, defense_time_threshold=dt, **general_sum_kwargs, **schedule_form_kwargs)\n",
    "            D_d, U, gaps, interval_times = regret_matching(isg.schedule_form_dict[\"defender_utility_matrix\"], runtime=120, interval=5, iterations=10000, averaging=2, alternations=True, plus=True, predictive=True, verbose=False)\n",
    "            sprmp_num_timesteps_li.append(num_timesteps)\n",
    "            sprmp_num_defenders_li.append(num_defenders)\n",
    "            sprmp_dts.append(dt)\n",
    "            sprmp_gaps_li.append(gaps)\n",
    "            sprmp_interval_times_li.append(interval_times)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e7b1fcf6-4eec-41ab-93fc-dccb38405228",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "df = pd.DataFrame({\n",
    "    \"num_timesteps\": sprmp_num_timesteps_li,\n",
    "    \"num_attackers\": [1 for i in range(len(sprmp_num_timesteps_li))],\n",
    "    \"num_defenders\": sprmp_num_defenders_li,\n",
    "    \"defense_time_threshold\": sprmp_dts,\n",
    "    \"iteration_times\": sprmp_interval_times_li,\n",
    "    \"gaps\": sprmp_gaps_li\n",
    "})\n",
    "\n",
    "# Step 2: Explode list columns\n",
    "exploded_df = df.explode([\"iteration_times\", \"gaps\"], ignore_index=True)\n",
    "\n",
    "# Optional: Add a column for iteration number within each trial\n",
    "exploded_df[\"interval_number\"] = exploded_df.groupby([\"num_timesteps\",\"num_defenders\",\"defense_time_threshold\"]).cumcount()\n",
    "\n",
    "# Reorder if desired\n",
    "cols = [\"num_timesteps\", \"num_attackers\", \"num_defenders\", \"defense_time_threshold\", \"interval_number\", \"iteration_times\", \"gaps\"]\n",
    "exploded_df = exploded_df[cols]\n",
    "\n",
    "exploded_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f7ed9f8d-7f28-4bdb-96ea-130a49bcf06b",
   "metadata": {},
   "outputs": [],
   "source": [
    "exploded_df[\"interval_number\"] = exploded_df[\"interval_number\"]+1\n",
    "exploded_df[\"iteration_number\"] = exploded_df[\"interval_number\"]*5"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4c7d906c-1a7c-440c-9dcd-8dad63cb403d",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "exploded_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d8fbac49-42a6-4503-a3c3-0f28d447a610",
   "metadata": {},
   "outputs": [],
   "source": [
    "exploded_df.to_csv(\"ISG_SF_PRMP_FINAL.csv\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c5770a1e-317a-4c00-9ea1-d2d5ae97f849",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.12.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
