{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "65ce70ad-5aac-45e9-a37e-7d00030b5e1a",
   "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",
    "from solvers.simple_sse_lp import solve_sse_lp\n",
    "from solvers.nfg_sse_lp import solve_general_sum_normal_form\n",
    "\n",
    "from utils.random_utils import generate_random_utility_matrix_like, generate_random_target_utility_matrix_like, generate_random_schedule_mapping_like, generate_random_target_utility_matrix_like_v2\n",
    "\n",
    "import time\n",
    "from matplotlib import pyplot as plt\n",
    "from collections import defaultdict, Counter\n",
    "import copy\n",
    "from scipy import stats"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "280221a2-261a-4c69-9730-72120bdbf8ff",
   "metadata": {},
   "outputs": [],
   "source": [
    "seeds = [1,2,3,4,5,6,7,8,9,10]"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "55c89e5d-cb24-4aa8-a142-6ca4463db01b",
   "metadata": {},
   "source": [
    "# GSG"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "id": "157ba62c-2ea0-42ac-954c-89583908caf7",
   "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",
    "\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",
    "sangha_river = [(2.2837, 16.16283352464626),(2.053, 16.066212728001727)]"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "a88bfa3d-fd03-40bf-b8dd-54b0818af4cc",
   "metadata": {},
   "source": [
    "## Simple SSE LP - Random target values only"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "id": "d28fbe21-1b31-4891-b01e-887b1ea5fb1e",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "starting seed: 1\n",
      "[[-0.42163788 -0.72150105 -0.207799   -0.87863018 -0.15034536 -0.67185381\n",
      "  -0.41975612 -0.56054636 -0.39930519 -0.54075686]\n",
      " [-0.41947451 -0.68654374 -0.00432075 -0.30526756 -0.03147923 -0.09615699\n",
      "  -0.1896835  -0.34831386 -0.14400321 -0.20147496]\n",
      " [ 0.10213996  0.42354294  0.3163125   0.53512919  0.69317334  0.31839516\n",
      "   0.0888933   0.04309734  0.0224182   0.75119542]\n",
      " [ 0.80158281  0.96839509  0.95806668  0.69361697  0.87690917  0.89505004\n",
      "   0.68781977  0.83532138  0.17332282  0.87865514]]\n",
      "starting seed: 2\n",
      "[[-0.62272767 -0.53112292 -0.55155698 -0.51562443 -0.42280623 -0.78623821\n",
      "  -0.8545896  -0.62087264 -0.84720698 -0.26991163]\n",
      " [-0.43836759 -0.03002402 -0.13822064 -0.43769791 -0.18787081 -0.333152\n",
      "  -0.20799456 -0.49636451 -0.30260092 -0.08351727]\n",
      " [ 0.47002642  0.06921871  0.43052813  0.10033168  0.13083188  0.3894719\n",
      "   0.22926806  0.11070263  0.16582269  0.35256147]\n",
      " [ 0.50732745  0.20510138  0.64191948  0.48524449  0.50731812  0.59844174\n",
      "   0.79450559  0.58177104  0.22358626  0.70201124]]\n",
      "starting seed: 3\n",
      "[[-0.55268763 -0.7093756  -0.65062005 -0.51288548 -0.89339731 -0.89672937\n",
      "  -0.12926385 -0.56070992 -0.26236866 -0.44316227]\n",
      " [-0.03395738 -0.45911825 -0.2938878  -0.28152258 -0.67761685 -0.592584\n",
      "  -0.02808785 -0.21057789 -0.05545754 -0.41756178]\n",
      " [ 0.28653919  0.67376191  0.44280765  0.16041467  0.38061073  0.09603592\n",
      "   0.30928156  0.22523099  0.36425057  0.22831459]\n",
      " [ 0.97609641  0.69442884  0.90324287  0.84639977  0.54656461  0.78123895\n",
      "   0.65486895  0.55970086  0.39054597  0.93665127]]\n",
      "starting seed: 4\n",
      "[[-0.96716854 -0.54913698 -0.97279927 -0.98347051 -0.69900044 -0.5990279\n",
      "  -0.97637426 -0.38915189 -0.25612496 -0.95683532]\n",
      " [-0.78031103 -0.2010603  -0.8635696  -0.71601572 -0.16735983 -0.21938729\n",
      "  -0.01315515 -0.0104109  -0.04818114 -0.43716928]\n",
      " [ 0.4385187   0.93783421  0.52370828  0.11194508  0.16176464  0.07884014\n",
      "   0.52640484  0.1714724   0.40401326  0.41093245]\n",
      " [ 0.52989484  0.94919195  0.78720497  0.8668518   0.17664379  0.54711592\n",
      "   0.60242234  0.63913476  0.7345018   0.65127833]]\n",
      "starting seed: 5\n",
      "[[-0.22526613 -0.87127612 -0.44365955 -0.9189533  -0.88044212 -0.6133772\n",
      "  -0.76689265 -0.52044393 -0.63034954 -0.58160537]\n",
      " [-0.08460846 -0.73954064 -0.21005637 -0.16185074 -0.49056337 -0.27714027\n",
      "  -0.41669925 -0.29904122 -0.29975876 -0.19113837]\n",
      " [ 0.02841116  0.20790187  0.2876951   0.25672825  0.02704347  0.14776468\n",
      "   0.00584212  0.51751095  0.64131051  0.19182888]\n",
      " [ 0.60161224  0.26890771  0.70110633  0.78044214  0.33039279  0.57943957\n",
      "   0.16912301  0.96408227  0.96039404  0.98568488]]\n",
      "starting seed: 6\n",
      "[[-0.89331087 -0.73699321 -0.82198119 -0.58063028 -0.64684704 -0.9902654\n",
      "  -0.82061603 -0.42125242 -0.87678818 -0.82450085]\n",
      " [-0.44050508 -0.33479007 -0.52006396 -0.04572807 -0.11141064 -0.59675562\n",
      "  -0.53179535 -0.41566951 -0.33820369 -0.62410744]\n",
      " [ 0.0584522   0.71982089  0.25874558  0.67269219  0.60069284  0.54286807\n",
      "   0.12850591  0.35453661  0.25677395  0.22024533]\n",
      " [ 0.71846523  0.99423181  0.8030028   0.73751554  0.71035539  0.71852129\n",
      "   0.9376131   0.95782547  0.40576671  0.40498622]]\n",
      "starting seed: 7\n",
      "[[-0.68057943 -0.80456468 -0.44077176 -0.72462852 -0.97808211 -0.90997385\n",
      "  -0.50321918 -0.4544288  -0.93149543 -0.50198642]\n",
      " [-0.08019413 -0.78084464 -0.38354542 -0.06986582 -0.29114027 -0.54043735\n",
      "  -0.21669453 -0.07595488 -0.27151655 -0.02900133]\n",
      " [ 0.20819417  0.49290816  0.23354088  0.47959965  0.36855799  0.13681608\n",
      "   0.52541751  0.3168806   0.57442324  0.2790946 ]\n",
      " [ 0.60222935  0.9503393   0.37502498  0.55038936  0.90951066  0.83859985\n",
      "   0.76962077  0.75145985  0.67040565  0.46999195]]\n",
      "starting seed: 8\n",
      "[[-0.87396187 -0.96867301 -0.86974482 -0.71358457 -0.62128204 -0.42850612\n",
      "  -0.43286475 -0.97396523 -0.52468271 -0.48058613]\n",
      " [-0.55722702 -0.54530693 -0.76190145 -0.53282931 -0.23595613 -0.01555771\n",
      "  -0.29206579 -0.40486558 -0.33657676 -0.22208745]\n",
      " [ 0.03281803  0.3544121   0.1315247   0.32498249  0.07485125  0.22803122\n",
      "   0.3961858   0.27321613  0.34821516  0.63976068]\n",
      " [ 0.0697384   0.98294261  0.3835631   0.76515228  0.93906136  0.32255176\n",
      "   0.43486342  0.89658191  0.80189282  0.98481359]]\n",
      "starting seed: 9\n",
      "[[-0.1702816  -0.87906997 -0.95117032 -0.13747338 -0.7003732  -0.57455715\n",
      "  -0.89843619 -0.66830028 -0.54973996 -0.70367927]\n",
      " [-0.01453737 -0.50397013 -0.4978945  -0.04279222 -0.1457201  -0.22184609\n",
      "  -0.42095443 -0.2512643  -0.08791288 -0.34825203]\n",
      " [ 0.38905817  0.69572413  0.82560721  0.18896799  0.24629978  0.80456541\n",
      "   0.90667155  0.17312948  0.34964944  0.46579155]\n",
      " [ 0.6510148   0.86141738  0.97096866  0.46791633  0.94077461  0.87393343\n",
      "   0.98342925  0.75929488  0.52309944  0.94574662]]\n",
      "starting seed: 10\n",
      "[[-0.77228266 -0.95358941 -0.63518942 -0.74986063 -0.81340924 -0.61415611\n",
      "  -0.72292585 -0.76153812 -0.91812003 -0.71577652]\n",
      " [-0.68668346 -0.0248715  -0.00813851 -0.5142444  -0.50061672 -0.22805781\n",
      "  -0.2014365  -0.29485504 -0.17260627 -0.09217504]\n",
      " [ 0.54446882  0.14577881  0.37597702  0.32209996  0.09428565  0.30364191\n",
      "   0.1177117   0.5151864   0.05090589  0.60271732]\n",
      " [ 0.80604259  0.52365951  0.90903318  0.67550449  0.4441813   0.43639501\n",
      "   0.61937498  0.82940204  0.65186791  0.6278593 ]]\n"
     ]
    }
   ],
   "source": [
    "schedule_form_kwargs = {\n",
    "    \"schedule_form\": True,\n",
    "    \"simple\": True,\n",
    "    \"attacker_penalty_factor\": 5,\n",
    "    \"defender_penalty_factor\": 5,\n",
    "}\n",
    "\n",
    "general_sum_kwargs = {\n",
    "    \"general_sum\": True,\n",
    "    \"attacker_animal_value\":  2350, \n",
    "    \"defender_animal_value\": 22966, \n",
    "    \"defender_step_cost\": 0, \n",
    "}\n",
    "\n",
    "# general_sum_kwargs = {\n",
    "#     \"general_sum\": True,\n",
    "#     \"attacker_animal_value\":  1, \n",
    "#     \"defender_animal_value\": 1, \n",
    "#     \"defender_step_cost\": 0, \n",
    "# }\n",
    "\n",
    "\n",
    "\n",
    "supports=[]\n",
    "dus = []\n",
    "runtimes = []\n",
    "\n",
    "gsg = GreenSecurityGame(df, coordinate_rectangle, \"centroid\", num_clusters=10, num_rows=7, num_columns=7, escape_line_points=sangha_river)\n",
    "gsg.generate(num_attackers=1, \n",
    "             num_defenders=2, \n",
    "             home_base_assignments=[(kabo_djembe, bomassa, inner_post),(kabo_djembe, bomassa, inner_post)], \n",
    "             num_timesteps=8, \n",
    "             generate_utility_matrix=False, \n",
    "             defense_time_threshold=1, \n",
    "             force_return=True, \n",
    "             **schedule_form_kwargs,\n",
    "             **general_sum_kwargs)\n",
    "for seed in seeds:\n",
    "    print(f\"starting seed: {seed}\")\n",
    "    np.random.seed(seed)\n",
    "    sdict_copy = copy.deepcopy(gsg.schedule_form_dict)\n",
    "    sdict_copy[\"target_utilities\"] = generate_random_target_utility_matrix_like_v2(gsg.schedule_form_dict[\"target_utilities\"], general_sum=True, respect_sign_roles=True)\n",
    "    print(sdict_copy[\"target_utilities\"])\n",
    "    start = time.time()\n",
    "    _, coverage, du = solve_sse_lp(sdict_copy)\n",
    "    end=time.time()\n",
    "\n",
    "    support = sum([1 for t,p in coverage.items() if p!=0])\n",
    "    dus.append(du)\n",
    "    runtimes.append(end-start)\n",
    "    supports.append(support)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "id": "2a35c8b5-3f36-4c1a-9ddf-d0be5810d1ae",
   "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>seed</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>defender_utility</th>\n",
       "      <th>support</th>\n",
       "      <th>runtime</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>1</td>\n",
       "      <td>8</td>\n",
       "      <td>2</td>\n",
       "      <td>10</td>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.097629</td>\n",
       "      <td>7</td>\n",
       "      <td>0.012651</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>2</td>\n",
       "      <td>8</td>\n",
       "      <td>2</td>\n",
       "      <td>10</td>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.205678</td>\n",
       "      <td>5</td>\n",
       "      <td>0.013500</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>3</td>\n",
       "      <td>8</td>\n",
       "      <td>2</td>\n",
       "      <td>10</td>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.343018</td>\n",
       "      <td>6</td>\n",
       "      <td>0.014165</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>4</td>\n",
       "      <td>8</td>\n",
       "      <td>2</td>\n",
       "      <td>10</td>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.204440</td>\n",
       "      <td>1</td>\n",
       "      <td>0.012596</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>5</td>\n",
       "      <td>8</td>\n",
       "      <td>2</td>\n",
       "      <td>10</td>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.358472</td>\n",
       "      <td>5</td>\n",
       "      <td>0.013375</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>6</td>\n",
       "      <td>8</td>\n",
       "      <td>2</td>\n",
       "      <td>10</td>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.342275</td>\n",
       "      <td>5</td>\n",
       "      <td>0.013132</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>7</td>\n",
       "      <td>8</td>\n",
       "      <td>2</td>\n",
       "      <td>10</td>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.387901</td>\n",
       "      <td>6</td>\n",
       "      <td>0.013485</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>8</td>\n",
       "      <td>8</td>\n",
       "      <td>2</td>\n",
       "      <td>10</td>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.286917</td>\n",
       "      <td>6</td>\n",
       "      <td>0.014183</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>9</td>\n",
       "      <td>8</td>\n",
       "      <td>2</td>\n",
       "      <td>10</td>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.428047</td>\n",
       "      <td>4</td>\n",
       "      <td>0.013301</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>10</td>\n",
       "      <td>8</td>\n",
       "      <td>2</td>\n",
       "      <td>10</td>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.321545</td>\n",
       "      <td>5</td>\n",
       "      <td>0.013707</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   seed  num_timesteps  num_defenders  num_clusters  dims  \\\n",
       "0     1              8              2            10     7   \n",
       "1     2              8              2            10     7   \n",
       "2     3              8              2            10     7   \n",
       "3     4              8              2            10     7   \n",
       "4     5              8              2            10     7   \n",
       "5     6              8              2            10     7   \n",
       "6     7              8              2            10     7   \n",
       "7     8              8              2            10     7   \n",
       "8     9              8              2            10     7   \n",
       "9    10              8              2            10     7   \n",
       "\n",
       "   defense_time_threshold  defender_utility  support   runtime  \n",
       "0                       1         -0.097629        7  0.012651  \n",
       "1                       1         -0.205678        5  0.013500  \n",
       "2                       1         -0.343018        6  0.014165  \n",
       "3                       1         -0.204440        1  0.012596  \n",
       "4                       1         -0.358472        5  0.013375  \n",
       "5                       1         -0.342275        5  0.013132  \n",
       "6                       1         -0.387901        6  0.013485  \n",
       "7                       1         -0.286917        6  0.014183  \n",
       "8                       1         -0.428047        4  0.013301  \n",
       "9                       1         -0.321545        5  0.013707  "
      ]
     },
     "execution_count": 42,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df = pd.DataFrame()\n",
    "df[\"seed\"] = seeds\n",
    "df[\"num_timesteps\"] = [8 for i in range(len(seeds))]\n",
    "df[\"num_defenders\"] = [2 for i in range(len(seeds))]\n",
    "df[\"num_clusters\"] = [10 for i in range(len(seeds))]\n",
    "df[\"dims\"] = [7 for i in range(len(seeds))]\n",
    "df[\"defense_time_threshold\"] = [1 for i in range(len(seeds))]\n",
    "df[\"defender_utility\"] = dus\n",
    "df[\"support\"] = supports\n",
    "df[\"runtime\"] = runtimes\n",
    "df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 45,
   "id": "a9bbd6a2-4c2c-4f39-91e0-793ead22449e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "5.0"
      ]
     },
     "execution_count": 45,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.mean([round(x,4) for x in df.support])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "id": "e6c2669a-ccd8-4e24-ac49-503664b34557",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.5163977794943222"
      ]
     },
     "execution_count": 46,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "stats.sem([round(x,4) for x in df.support])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "id": "c78b18ba-1ccb-46c9-b0cf-1be3a0cce86d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.013420000000000001"
      ]
     },
     "execution_count": 47,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.mean([round(x,4) for x in df.runtime])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "id": "5bd17cc8-21a9-4cf8-959d-00d6377403c5",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.00017048949136725907"
      ]
     },
     "execution_count": 48,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "stats.sem([round(x,4) for x in df.runtime])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "id": "25b36f02-857b-4fae-9d19-e8d4bea5f82a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "-0.29758"
      ]
     },
     "execution_count": 49,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.mean([round(x,4) for x in df.defender_utility])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "id": "48c9b569-edf6-4b6d-95c2-8ac3df9e98bc",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.031753189866006636"
      ]
     },
     "execution_count": 50,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "stats.sem([round(x,4) for x in df.defender_utility])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "da8978e1-bdf2-40f6-90da-078d02047322",
   "metadata": {},
   "outputs": [],
   "source": [
    "df.to_csv(\"GSG_SIMPLE_SSE_RANDOM_TARGET_VALUES.csv\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ae6ac2a4-b0ca-4cef-9560-019caffcd283",
   "metadata": {},
   "source": [
    "## Simple SSE LP - Entirely Random schedules"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "21565de3-e2ab-49f3-bc64-eac440d968af",
   "metadata": {},
   "source": [
    "## General SSE LP - Random Matrix"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "eed8dc55-5ca6-4a76-9437-dcbd6a66b475",
   "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",
    "\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)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "6c327469-9576-4efb-955e-79d11040a2fc",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "starting seed: 1\n",
      "Value: -0.03473849135230922, Index: (1962, 4)\n",
      "Value: -0.034761957825537926, Index: (264, 5)\n",
      "Value: -0.034774759270366884, Index: (2413, 5)\n",
      "Value: -0.03480208289629427, Index: (1873, 1)\n",
      "Value: -0.03487628098427531, Index: (2423, 2)\n",
      "starting seed: 2\n",
      "Value: -0.03469714209329178, Index: (2295, 6)\n",
      "Value: -0.03471994157677516, Index: (900, 0)\n",
      "Value: -0.03481261092595267, Index: (1800, 4)\n",
      "Value: -0.034867032164570766, Index: (873, 7)\n",
      "Value: -0.034875096882631684, Index: (2334, 0)\n",
      "starting seed: 3\n",
      "Value: -0.03467006332057565, Index: (1552, 8)\n",
      "Value: -0.03469586513618794, Index: (2400, 0)\n",
      "Value: -0.03472037096567182, Index: (2164, 9)\n",
      "Value: -0.03476227863362247, Index: (1516, 6)\n",
      "Value: -0.03477490233847935, Index: (1632, 6)\n",
      "starting seed: 4\n",
      "Value: -0.03474445250649427, Index: (1032, 4)\n",
      "Value: -0.03474855746927863, Index: (2387, 1)\n",
      "Value: -0.03485181188842279, Index: (532, 4)\n",
      "Value: -0.03487952903171432, Index: (2136, 3)\n",
      "Value: -0.03489453444568691, Index: (1331, 6)\n",
      "starting seed: 5\n",
      "Value: -0.03466217755537604, Index: (431, 2)\n",
      "Value: -0.03466984004264517, Index: (1878, 1)\n",
      "Value: -0.03468352892233384, Index: (1738, 8)\n",
      "Value: -0.034698301407729004, Index: (1062, 7)\n",
      "Value: -0.03470053736251233, Index: (1363, 4)\n",
      "starting seed: 6\n",
      "Value: -0.03465514019253357, Index: (1703, 6)\n",
      "Value: -0.03468477429817329, Index: (539, 9)\n",
      "Value: -0.03471945912328889, Index: (2119, 3)\n",
      "Value: -0.03475061607972252, Index: (368, 4)\n",
      "Value: -0.03477153978271841, Index: (2272, 6)\n",
      "starting seed: 7\n",
      "Value: -0.034683466646793004, Index: (2453, 7)\n",
      "Value: -0.03469957937916146, Index: (1202, 8)\n",
      "Value: -0.034714380719933935, Index: (1259, 8)\n",
      "Value: -0.03471975863761678, Index: (1260, 3)\n",
      "Value: -0.03480032323260496, Index: (565, 1)\n",
      "starting seed: 8\n",
      "Value: -0.0346446743039881, Index: (701, 2)\n",
      "Value: -0.03471600700981892, Index: (582, 9)\n",
      "Value: -0.034773846271735076, Index: (74, 6)\n",
      "Value: -0.03477840149906675, Index: (1541, 1)\n",
      "Value: -0.034780750487446666, Index: (633, 7)\n",
      "starting seed: 9\n",
      "Value: -0.03466519649643096, Index: (1263, 8)\n",
      "Value: -0.03467578225449952, Index: (1028, 6)\n",
      "Value: -0.03474543556821019, Index: (2190, 2)\n",
      "Value: -0.03478790379266361, Index: (585, 1)\n",
      "Value: -0.03490687465912157, Index: (1380, 9)\n",
      "starting seed: 10\n",
      "Value: -0.03465188922736562, Index: (185, 0)\n",
      "Value: -0.034699226566278774, Index: (642, 2)\n",
      "Value: -0.03470638064985965, Index: (2091, 0)\n",
      "Value: -0.03474177987901628, Index: (2345, 4)\n",
      "Value: -0.03475165218734455, Index: (580, 8)\n"
     ]
    }
   ],
   "source": [
    "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\": True,\n",
    "    \"attacker_animal_value\":  2350, \n",
    "    \"defender_animal_value\": 22966, \n",
    "    \"defender_step_cost\": 1.17, \n",
    "}\n",
    "\n",
    "\n",
    "supports=[]\n",
    "dus = []\n",
    "runtimes = []\n",
    "\n",
    "gsg = GreenSecurityGame(df, coordinate_rectangle, \"centroid\", num_clusters=10, num_rows=7, num_columns=7, escape_line_points=sangha_river)\n",
    "gsg.generate(num_attackers=1, \n",
    "             num_defenders=2, \n",
    "             home_base_assignments=[(kabo_djembe, bomassa, inner_post),(kabo_djembe, bomassa, inner_post)], \n",
    "             num_timesteps=8, \n",
    "             generate_utility_matrix=True, \n",
    "             defense_time_threshold=1, \n",
    "             force_return=True, \n",
    "             **schedule_form_kwargs,\n",
    "             **general_sum_kwargs)\n",
    "for seed in seeds:\n",
    "    print(f\"starting seed: {seed}\")\n",
    "    np.random.seed(seed)\n",
    "    sdict_copy = copy.deepcopy(gsg.schedule_form_dict)\n",
    "    sdict_copy[\"defender_utility_matrix\"] = generate_random_utility_matrix_like(gsg.schedule_form_dict[\"defender_utility_matrix\"])\n",
    "    sdict_copy[\"attacker_utility_matrix\"] = generate_random_utility_matrix_like(gsg.schedule_form_dict[\"attacker_utility_matrix\"])\n",
    "\n",
    "    flat_indices = np.argpartition(sdict_copy[\"defender_utility_matrix\"].ravel(), -5)[-5:]\n",
    "    sorted_indices = flat_indices[np.argsort(sdict_copy[\"defender_utility_matrix\"].ravel()[flat_indices])[::-1]]\n",
    "    \n",
    "    for idx in sorted_indices:\n",
    "        row, col = np.unravel_index(idx, sdict_copy[\"defender_utility_matrix\"].shape)\n",
    "        print(f\"Value: {sdict_copy[\"defender_utility_matrix\"][row, col]}, Index: ({row}, {col})\")\n",
    "        \n",
    "    # print(sdict_copy[\"defender_utility_matrix\"])\n",
    "    # print(sdict_copy[\"attacker_utility_matrix\"])\n",
    "    start = time.time()\n",
    "    _, coverage, du = solve_general_sum_normal_form(sdict_copy[\"defender_utility_matrix\"],sdict_copy[\"attacker_utility_matrix\"])\n",
    "    end=time.time()\n",
    "\n",
    "    support = sum([1 for t,p in coverage.items() if p!=0])\n",
    "    dus.append(du)\n",
    "    runtimes.append(end-start)\n",
    "    supports.append(support)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "42ad73c1-1150-47d5-b182-4381b10bc83a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "-0.03464204837266125"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.max(gsg.schedule_form_dict[\"defender_utility_matrix\"])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "72cf63f1-05e6-472c-9c0e-3595cb0a7ddc",
   "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>seed</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>defender_utility</th>\n",
       "      <th>support</th>\n",
       "      <th>runtime</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>1</td>\n",
       "      <td>8</td>\n",
       "      <td>2</td>\n",
       "      <td>10</td>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.034781</td>\n",
       "      <td>2</td>\n",
       "      <td>0.519425</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>2</td>\n",
       "      <td>8</td>\n",
       "      <td>2</td>\n",
       "      <td>10</td>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.035010</td>\n",
       "      <td>3</td>\n",
       "      <td>0.436632</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>3</td>\n",
       "      <td>8</td>\n",
       "      <td>2</td>\n",
       "      <td>10</td>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.034768</td>\n",
       "      <td>2</td>\n",
       "      <td>0.601936</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>4</td>\n",
       "      <td>8</td>\n",
       "      <td>2</td>\n",
       "      <td>10</td>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.034802</td>\n",
       "      <td>2</td>\n",
       "      <td>0.567851</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>5</td>\n",
       "      <td>8</td>\n",
       "      <td>2</td>\n",
       "      <td>10</td>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.034800</td>\n",
       "      <td>2</td>\n",
       "      <td>0.451001</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>6</td>\n",
       "      <td>8</td>\n",
       "      <td>2</td>\n",
       "      <td>10</td>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.034754</td>\n",
       "      <td>2</td>\n",
       "      <td>0.502337</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>7</td>\n",
       "      <td>8</td>\n",
       "      <td>2</td>\n",
       "      <td>10</td>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.034720</td>\n",
       "      <td>1</td>\n",
       "      <td>0.499972</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>8</td>\n",
       "      <td>8</td>\n",
       "      <td>2</td>\n",
       "      <td>10</td>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.034861</td>\n",
       "      <td>2</td>\n",
       "      <td>0.481408</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>9</td>\n",
       "      <td>8</td>\n",
       "      <td>2</td>\n",
       "      <td>10</td>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.034830</td>\n",
       "      <td>2</td>\n",
       "      <td>0.619688</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>10</td>\n",
       "      <td>8</td>\n",
       "      <td>2</td>\n",
       "      <td>10</td>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.034765</td>\n",
       "      <td>2</td>\n",
       "      <td>0.478741</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   seed  num_timesteps  num_defenders  num_clusters  dims  \\\n",
       "0     1              8              2            10     7   \n",
       "1     2              8              2            10     7   \n",
       "2     3              8              2            10     7   \n",
       "3     4              8              2            10     7   \n",
       "4     5              8              2            10     7   \n",
       "5     6              8              2            10     7   \n",
       "6     7              8              2            10     7   \n",
       "7     8              8              2            10     7   \n",
       "8     9              8              2            10     7   \n",
       "9    10              8              2            10     7   \n",
       "\n",
       "   defense_time_threshold  defender_utility  support   runtime  \n",
       "0                       1         -0.034781        2  0.519425  \n",
       "1                       1         -0.035010        3  0.436632  \n",
       "2                       1         -0.034768        2  0.601936  \n",
       "3                       1         -0.034802        2  0.567851  \n",
       "4                       1         -0.034800        2  0.451001  \n",
       "5                       1         -0.034754        2  0.502337  \n",
       "6                       1         -0.034720        1  0.499972  \n",
       "7                       1         -0.034861        2  0.481408  \n",
       "8                       1         -0.034830        2  0.619688  \n",
       "9                       1         -0.034765        2  0.478741  "
      ]
     },
     "execution_count": 19,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df = pd.DataFrame()\n",
    "df[\"seed\"] = seeds\n",
    "df[\"num_timesteps\"] = [8 for i in range(len(seeds))]\n",
    "df[\"num_defenders\"] = [2 for i in range(len(seeds))]\n",
    "df[\"num_clusters\"] = [10 for i in range(len(seeds))]\n",
    "df[\"dims\"] = [7 for i in range(len(seeds))]\n",
    "df[\"defense_time_threshold\"] = [1 for i in range(len(seeds))]\n",
    "df[\"defender_utility\"] = dus\n",
    "df[\"support\"] = supports\n",
    "df[\"runtime\"] = runtimes\n",
    "df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "e91fa85f-2cc1-4c1f-a6e0-21672d86e461",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[0.5194, 0.4366, 0.6019, 0.5679, 0.451, 0.5023, 0.5, 0.4814, 0.6197, 0.4787]"
      ]
     },
     "execution_count": 22,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "[round(x,4) for x in df.runtime]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "c86e92f5-a620-48ec-926e-586c87f5372b",
   "metadata": {},
   "outputs": [],
   "source": [
    "df.to_csv(\"GSG_NFG_SSE_RANDOM_MATRIX.csv\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 62,
   "id": "cb0712dd-f527-4f5b-9c8d-4a9db02b440a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "starting seed: 1\n",
      "[[-0.42163788 -0.72150105 -0.207799   -0.87863018 -0.15034536 -0.67185381\n",
      "  -0.41975612 -0.56054636 -0.39930519 -0.54075686]\n",
      " [-0.41947451 -0.68654374 -0.00432075 -0.30526756 -0.03147923 -0.09615699\n",
      "  -0.1896835  -0.34831386 -0.14400321 -0.20147496]\n",
      " [ 0.10213996  0.42354294  0.3163125   0.53512919  0.69317334  0.31839516\n",
      "   0.0888933   0.04309734  0.0224182   0.75119542]\n",
      " [ 0.80158281  0.96839509  0.95806668  0.69361697  0.87690917  0.89505004\n",
      "   0.68781977  0.83532138  0.17332282  0.87865514]]\n",
      "starting seed: 2\n",
      "[[-0.62272767 -0.53112292 -0.55155698 -0.51562443 -0.42280623 -0.78623821\n",
      "  -0.8545896  -0.62087264 -0.84720698 -0.26991163]\n",
      " [-0.43836759 -0.03002402 -0.13822064 -0.43769791 -0.18787081 -0.333152\n",
      "  -0.20799456 -0.49636451 -0.30260092 -0.08351727]\n",
      " [ 0.47002642  0.06921871  0.43052813  0.10033168  0.13083188  0.3894719\n",
      "   0.22926806  0.11070263  0.16582269  0.35256147]\n",
      " [ 0.50732745  0.20510138  0.64191948  0.48524449  0.50731812  0.59844174\n",
      "   0.79450559  0.58177104  0.22358626  0.70201124]]\n",
      "starting seed: 3\n",
      "[[-0.55268763 -0.7093756  -0.65062005 -0.51288548 -0.89339731 -0.89672937\n",
      "  -0.12926385 -0.56070992 -0.26236866 -0.44316227]\n",
      " [-0.03395738 -0.45911825 -0.2938878  -0.28152258 -0.67761685 -0.592584\n",
      "  -0.02808785 -0.21057789 -0.05545754 -0.41756178]\n",
      " [ 0.28653919  0.67376191  0.44280765  0.16041467  0.38061073  0.09603592\n",
      "   0.30928156  0.22523099  0.36425057  0.22831459]\n",
      " [ 0.97609641  0.69442884  0.90324287  0.84639977  0.54656461  0.78123895\n",
      "   0.65486895  0.55970086  0.39054597  0.93665127]]\n",
      "starting seed: 4\n",
      "[[-0.96716854 -0.54913698 -0.97279927 -0.98347051 -0.69900044 -0.5990279\n",
      "  -0.97637426 -0.38915189 -0.25612496 -0.95683532]\n",
      " [-0.78031103 -0.2010603  -0.8635696  -0.71601572 -0.16735983 -0.21938729\n",
      "  -0.01315515 -0.0104109  -0.04818114 -0.43716928]\n",
      " [ 0.4385187   0.93783421  0.52370828  0.11194508  0.16176464  0.07884014\n",
      "   0.52640484  0.1714724   0.40401326  0.41093245]\n",
      " [ 0.52989484  0.94919195  0.78720497  0.8668518   0.17664379  0.54711592\n",
      "   0.60242234  0.63913476  0.7345018   0.65127833]]\n",
      "starting seed: 5\n",
      "[[-0.22526613 -0.87127612 -0.44365955 -0.9189533  -0.88044212 -0.6133772\n",
      "  -0.76689265 -0.52044393 -0.63034954 -0.58160537]\n",
      " [-0.08460846 -0.73954064 -0.21005637 -0.16185074 -0.49056337 -0.27714027\n",
      "  -0.41669925 -0.29904122 -0.29975876 -0.19113837]\n",
      " [ 0.02841116  0.20790187  0.2876951   0.25672825  0.02704347  0.14776468\n",
      "   0.00584212  0.51751095  0.64131051  0.19182888]\n",
      " [ 0.60161224  0.26890771  0.70110633  0.78044214  0.33039279  0.57943957\n",
      "   0.16912301  0.96408227  0.96039404  0.98568488]]\n",
      "starting seed: 6\n",
      "[[-0.89331087 -0.73699321 -0.82198119 -0.58063028 -0.64684704 -0.9902654\n",
      "  -0.82061603 -0.42125242 -0.87678818 -0.82450085]\n",
      " [-0.44050508 -0.33479007 -0.52006396 -0.04572807 -0.11141064 -0.59675562\n",
      "  -0.53179535 -0.41566951 -0.33820369 -0.62410744]\n",
      " [ 0.0584522   0.71982089  0.25874558  0.67269219  0.60069284  0.54286807\n",
      "   0.12850591  0.35453661  0.25677395  0.22024533]\n",
      " [ 0.71846523  0.99423181  0.8030028   0.73751554  0.71035539  0.71852129\n",
      "   0.9376131   0.95782547  0.40576671  0.40498622]]\n",
      "starting seed: 7\n",
      "[[-0.68057943 -0.80456468 -0.44077176 -0.72462852 -0.97808211 -0.90997385\n",
      "  -0.50321918 -0.4544288  -0.93149543 -0.50198642]\n",
      " [-0.08019413 -0.78084464 -0.38354542 -0.06986582 -0.29114027 -0.54043735\n",
      "  -0.21669453 -0.07595488 -0.27151655 -0.02900133]\n",
      " [ 0.20819417  0.49290816  0.23354088  0.47959965  0.36855799  0.13681608\n",
      "   0.52541751  0.3168806   0.57442324  0.2790946 ]\n",
      " [ 0.60222935  0.9503393   0.37502498  0.55038936  0.90951066  0.83859985\n",
      "   0.76962077  0.75145985  0.67040565  0.46999195]]\n",
      "starting seed: 8\n",
      "[[-0.87396187 -0.96867301 -0.86974482 -0.71358457 -0.62128204 -0.42850612\n",
      "  -0.43286475 -0.97396523 -0.52468271 -0.48058613]\n",
      " [-0.55722702 -0.54530693 -0.76190145 -0.53282931 -0.23595613 -0.01555771\n",
      "  -0.29206579 -0.40486558 -0.33657676 -0.22208745]\n",
      " [ 0.03281803  0.3544121   0.1315247   0.32498249  0.07485125  0.22803122\n",
      "   0.3961858   0.27321613  0.34821516  0.63976068]\n",
      " [ 0.0697384   0.98294261  0.3835631   0.76515228  0.93906136  0.32255176\n",
      "   0.43486342  0.89658191  0.80189282  0.98481359]]\n",
      "starting seed: 9\n",
      "[[-0.1702816  -0.87906997 -0.95117032 -0.13747338 -0.7003732  -0.57455715\n",
      "  -0.89843619 -0.66830028 -0.54973996 -0.70367927]\n",
      " [-0.01453737 -0.50397013 -0.4978945  -0.04279222 -0.1457201  -0.22184609\n",
      "  -0.42095443 -0.2512643  -0.08791288 -0.34825203]\n",
      " [ 0.38905817  0.69572413  0.82560721  0.18896799  0.24629978  0.80456541\n",
      "   0.90667155  0.17312948  0.34964944  0.46579155]\n",
      " [ 0.6510148   0.86141738  0.97096866  0.46791633  0.94077461  0.87393343\n",
      "   0.98342925  0.75929488  0.52309944  0.94574662]]\n",
      "starting seed: 10\n",
      "[[-0.77228266 -0.95358941 -0.63518942 -0.74986063 -0.81340924 -0.61415611\n",
      "  -0.72292585 -0.76153812 -0.91812003 -0.71577652]\n",
      " [-0.68668346 -0.0248715  -0.00813851 -0.5142444  -0.50061672 -0.22805781\n",
      "  -0.2014365  -0.29485504 -0.17260627 -0.09217504]\n",
      " [ 0.54446882  0.14577881  0.37597702  0.32209996  0.09428565  0.30364191\n",
      "   0.1177117   0.5151864   0.05090589  0.60271732]\n",
      " [ 0.80604259  0.52365951  0.90903318  0.67550449  0.4441813   0.43639501\n",
      "   0.61937498  0.82940204  0.65186791  0.6278593 ]]\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",
    "\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",
    "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\": True,\n",
    "    \"attacker_animal_value\":  2350, \n",
    "    \"defender_animal_value\": 22966, \n",
    "    \"defender_step_cost\": 1.17, \n",
    "}\n",
    "\n",
    "\n",
    "supports=[]\n",
    "dus = []\n",
    "runtimes = []\n",
    "\n",
    "gsg = GreenSecurityGame(df, coordinate_rectangle, \"centroid\", num_clusters=10, num_rows=7, num_columns=7, escape_line_points=sangha_river)\n",
    "gsg.generate(num_attackers=1, \n",
    "             num_defenders=2, \n",
    "             home_base_assignments=[(kabo_djembe, bomassa, inner_post),(kabo_djembe, bomassa, inner_post)], \n",
    "             num_timesteps=8, \n",
    "             generate_utility_matrix=True, \n",
    "             random_target_values=False,\n",
    "             defense_time_threshold=1, \n",
    "             force_return=True, \n",
    "             **schedule_form_kwargs,\n",
    "             **general_sum_kwargs)\n",
    "\n",
    "for seed in seeds:\n",
    "    print(f\"starting seed: {seed}\")\n",
    "    np.random.seed(seed)\n",
    "    defender_actions,defender_costs = generate_defender_actions_with_costs(gsg.schedule_form_dict[\"schedules\"])\n",
    "    attacker_actions = [0,1,2,3,4,5,6,7,8,9]\n",
    "    random_target_utilities = generate_random_target_utility_matrix_like_v2(gsg.schedule_form_dict[\"target_utilities\"], general_sum=True, respect_sign_roles=True)\n",
    "    print(random_target_utilities)\n",
    "    attacker_matrix, defender_matrix = generate_schedule_game_matrix(attacker_actions, defender_actions, defender_costs, random_target_utilities, general_sum=True)\n",
    "    start = time.time()\n",
    "    _, coverage, du = solve_general_sum_normal_form(defender_matrix,attacker_matrix)\n",
    "    end=time.time()\n",
    "\n",
    "    support = sum([1 for t,p in coverage.items() if p!=0])\n",
    "    dus.append(du)\n",
    "    runtimes.append(end-start)\n",
    "    supports.append(support)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "42d3ceea-217a-4b27-a6f0-87ea90e7b414",
   "metadata": {},
   "source": [
    "### new target randomization"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 63,
   "id": "eb1009f2-0efa-4506-93b2-5f579104b07d",
   "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>seed</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>defender_utility</th>\n",
       "      <th>support</th>\n",
       "      <th>runtime</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>1</td>\n",
       "      <td>8</td>\n",
       "      <td>2</td>\n",
       "      <td>10</td>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.249858</td>\n",
       "      <td>1</td>\n",
       "      <td>0.357311</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>2</td>\n",
       "      <td>8</td>\n",
       "      <td>2</td>\n",
       "      <td>10</td>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.257696</td>\n",
       "      <td>1</td>\n",
       "      <td>0.376930</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>3</td>\n",
       "      <td>8</td>\n",
       "      <td>2</td>\n",
       "      <td>10</td>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.252614</td>\n",
       "      <td>3</td>\n",
       "      <td>0.361606</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>4</td>\n",
       "      <td>8</td>\n",
       "      <td>2</td>\n",
       "      <td>10</td>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.249463</td>\n",
       "      <td>1</td>\n",
       "      <td>0.338337</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>5</td>\n",
       "      <td>8</td>\n",
       "      <td>2</td>\n",
       "      <td>10</td>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.253488</td>\n",
       "      <td>2</td>\n",
       "      <td>0.332397</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>6</td>\n",
       "      <td>8</td>\n",
       "      <td>2</td>\n",
       "      <td>10</td>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.252082</td>\n",
       "      <td>2</td>\n",
       "      <td>0.413847</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>7</td>\n",
       "      <td>8</td>\n",
       "      <td>2</td>\n",
       "      <td>10</td>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.256689</td>\n",
       "      <td>2</td>\n",
       "      <td>0.339143</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>8</td>\n",
       "      <td>8</td>\n",
       "      <td>2</td>\n",
       "      <td>10</td>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.252432</td>\n",
       "      <td>3</td>\n",
       "      <td>0.345470</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>9</td>\n",
       "      <td>8</td>\n",
       "      <td>2</td>\n",
       "      <td>10</td>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.257924</td>\n",
       "      <td>1</td>\n",
       "      <td>0.339115</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>10</td>\n",
       "      <td>8</td>\n",
       "      <td>2</td>\n",
       "      <td>10</td>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.254759</td>\n",
       "      <td>1</td>\n",
       "      <td>0.348098</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   seed  num_timesteps  num_defenders  num_clusters  dims  \\\n",
       "0     1              8              2            10     7   \n",
       "1     2              8              2            10     7   \n",
       "2     3              8              2            10     7   \n",
       "3     4              8              2            10     7   \n",
       "4     5              8              2            10     7   \n",
       "5     6              8              2            10     7   \n",
       "6     7              8              2            10     7   \n",
       "7     8              8              2            10     7   \n",
       "8     9              8              2            10     7   \n",
       "9    10              8              2            10     7   \n",
       "\n",
       "   defense_time_threshold  defender_utility  support   runtime  \n",
       "0                       1         -0.249858        1  0.357311  \n",
       "1                       1         -0.257696        1  0.376930  \n",
       "2                       1         -0.252614        3  0.361606  \n",
       "3                       1         -0.249463        1  0.338337  \n",
       "4                       1         -0.253488        2  0.332397  \n",
       "5                       1         -0.252082        2  0.413847  \n",
       "6                       1         -0.256689        2  0.339143  \n",
       "7                       1         -0.252432        3  0.345470  \n",
       "8                       1         -0.257924        1  0.339115  \n",
       "9                       1         -0.254759        1  0.348098  "
      ]
     },
     "execution_count": 63,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df = pd.DataFrame()\n",
    "df[\"seed\"] = seeds\n",
    "df[\"num_timesteps\"] = [8 for i in range(len(seeds))]\n",
    "df[\"num_defenders\"] = [2 for i in range(len(seeds))]\n",
    "df[\"num_clusters\"] = [10 for i in range(len(seeds))]\n",
    "df[\"dims\"] = [7 for i in range(len(seeds))]\n",
    "df[\"defense_time_threshold\"] = [1 for i in range(len(seeds))]\n",
    "df[\"defender_utility\"] = dus\n",
    "df[\"support\"] = supports\n",
    "df[\"runtime\"] = runtimes\n",
    "df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bd29df63-a09d-46cd-a85b-90fe1e2c85e1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 64,
   "id": "15acf8b7-cc66-479e-bd22-2083de59a3a0",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "1.7"
      ]
     },
     "execution_count": 64,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.mean([round(x,4) for x in df.support])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 65,
   "id": "cc5d1124-5b31-483e-b283-eb573c6dca63",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.2603416558635552"
      ]
     },
     "execution_count": 65,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "stats.sem([round(x,4) for x in df.support])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 66,
   "id": "f211e674-9bd8-4568-b787-316220cac5cb",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.35521"
      ]
     },
     "execution_count": 66,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.mean([round(x,4) for x in df.runtime])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 67,
   "id": "8f4659b0-3ada-49e3-8ff5-33507efbc74f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.007759287624804512"
      ]
     },
     "execution_count": 67,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "stats.sem([round(x,4) for x in df.runtime])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 68,
   "id": "ece6cbbd-88a1-4786-9ad3-75c27bd77a61",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "-0.25371"
      ]
     },
     "execution_count": 68,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.mean([round(x,4) for x in df.defender_utility])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 69,
   "id": "04fb5057-8402-4790-8efe-9364b77abcb4",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.0009511922343389194"
      ]
     },
     "execution_count": 69,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "stats.sem([round(x,4) for x in df.defender_utility])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "a8dcf80e-f5f2-434e-82df-f452d5391191",
   "metadata": {},
   "outputs": [],
   "source": [
    "df.to_csv(\"GSG_NFG_SSE_RANDOM_TARGET_VALUES.csv\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "23dd112b-02b4-446b-a870-8bc5f604c0af",
   "metadata": {},
   "outputs": [],
   "source": [
    "    def generate_defender_actions_with_costs(schedule_dict):\n",
    "        \"\"\"\n",
    "        Generates all possible joint defender actions from a dictionary mapping\n",
    "        each defender to their list of (schedule, cost) tuples.\n",
    "\n",
    "        Defenders with no schedules are assigned an empty set with 0 cost as a placeholder.\n",
    "\n",
    "        Returns:\n",
    "            defender_actions: list of lists of sets (each inner list is one full defender action)\n",
    "            defender_costs: list of floats representing the total cost for each joint action\n",
    "        \"\"\"\n",
    "        sorted_defenders = sorted(schedule_dict.keys())\n",
    "        # print(schedule_dict)\n",
    "        # Replace empty schedule lists with a dummy no-op schedule\n",
    "        schedule_lists = [\n",
    "            schedule_dict[d] if schedule_dict[d] else [({}, 0)]\n",
    "            for d in sorted_defenders\n",
    "        ]\n",
    "        # print(schedule_lists)\n",
    "        all_combinations = list(itertools.product(*schedule_lists))\n",
    "\n",
    "        defender_actions = []\n",
    "        defender_costs = []\n",
    "\n",
    "        for combo in all_combinations:\n",
    "            schedules = [item[0] for item in combo]\n",
    "            # print(combo)\n",
    "            total_cost = sum(item[1] for item in combo)\n",
    "            defender_actions.append(schedules)\n",
    "            defender_costs.append(total_cost)\n",
    "\n",
    "        return defender_actions, defender_costs\n",
    "\n",
    "    def generate_schedule_game_matrix(attacker_actions, defender_actions, defender_costs, target_utility_matrix, general_sum):\n",
    "        \"\"\"\n",
    "        Builds utility matrices for all combinations of defender and attacker actions,\n",
    "        then normalizes both matrices together based on the largest absolute value.\n",
    "\n",
    "        Parameters:\n",
    "            attacker_actions (list[int]): List of target nodes (attacker action).\n",
    "            defender_actions (list[list[set]]): Each outer list is one defender action;\n",
    "                inner list is per-defender selected schedule (a set of targets).\n",
    "            defender_costs (list[float]): Cost associated with each defender action.\n",
    "            target_utility_matrix (np.ndarray): 4 x num_targets array:\n",
    "                [0]: defender utility if uncovered\n",
    "                [1]: defender utility if covered\n",
    "                [2]: attacker utility if covered\n",
    "                [3]: attacker utility if uncovered\n",
    "\n",
    "        Returns:\n",
    "            tuple:\n",
    "                - attacker_util_matrix (np.ndarray): shape (len(defender_actions), len(attacker_actions))\n",
    "                - defender_util_matrix (np.ndarray): same shape\n",
    "        \"\"\"\n",
    "        num_defender_actions = len(defender_actions)\n",
    "        num_attacker_actions = len(attacker_actions)\n",
    "\n",
    "        defender_util_matrix = np.zeros((num_defender_actions, num_attacker_actions))\n",
    "        attacker_util_matrix = np.zeros((num_defender_actions, num_attacker_actions))\n",
    "\n",
    "        for i, d_action in enumerate(defender_actions):\n",
    "            target_coverage_count = {}\n",
    "            for schedule in d_action:\n",
    "                for t in schedule:\n",
    "                    target_coverage_count[t] = target_coverage_count.get(t, 0) + 1\n",
    "\n",
    "            for j, atk_target in enumerate(attacker_actions):\n",
    "                num_covers = target_coverage_count.get(atk_target, 0)\n",
    "\n",
    "                if num_covers == 0:\n",
    "                    defender_util = target_utility_matrix[0][j]  # uncovered\n",
    "                    attacker_util = target_utility_matrix[3][j]  # uncovered\n",
    "                else:\n",
    "                    defender_util = target_utility_matrix[1][j]  # covered\n",
    "                    attacker_util = target_utility_matrix[2][j]  # covered\n",
    "\n",
    "                defender_util_matrix[i, j] = defender_util - defender_costs[i]\n",
    "                # defender_util_matrix[i, j] = defender_util\n",
    "                attacker_util_matrix[i, j] = attacker_util\n",
    "\n",
    "        # if general_sum:\n",
    "            # Normalize attacker and defender matrices together\n",
    "        max_abs_value = max(\n",
    "            np.abs(defender_util_matrix).max(),\n",
    "            np.abs(attacker_util_matrix).max()\n",
    "        )\n",
    "\n",
    "        if max_abs_value > 0:\n",
    "            defender_util_matrix = defender_util_matrix / max_abs_value\n",
    "            attacker_util_matrix = attacker_util_matrix / max_abs_value\n",
    "\n",
    "        return attacker_util_matrix, defender_util_matrix"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 79,
   "id": "e6e4fda0-73a7-4b71-875c-95dbee23f548",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "starting seed: 1\n",
      "starting seed: 2\n",
      "starting seed: 3\n",
      "starting seed: 4\n",
      "starting seed: 5\n",
      "starting seed: 6\n",
      "starting seed: 7\n",
      "starting seed: 8\n",
      "starting seed: 9\n",
      "starting seed: 10\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",
    "\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",
    "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\": True,\n",
    "    \"attacker_animal_value\":  2350, \n",
    "    \"defender_animal_value\": 22966, \n",
    "    \"defender_step_cost\": 1.17, \n",
    "}\n",
    "\n",
    "\n",
    "supports=[]\n",
    "dus = []\n",
    "runtimes = []\n",
    "\n",
    "gsg = GreenSecurityGame(df, coordinate_rectangle, \"centroid\", num_clusters=10, num_rows=7, num_columns=7, escape_line_points=sangha_river)\n",
    "gsg.generate(num_attackers=1, \n",
    "             num_defenders=2, \n",
    "             home_base_assignments=[(kabo_djembe, bomassa, inner_post),(kabo_djembe, bomassa, inner_post)], \n",
    "             num_timesteps=8, \n",
    "             generate_utility_matrix=False, \n",
    "             random_target_values=False,\n",
    "             defense_time_threshold=1, \n",
    "             force_return=True, \n",
    "             **schedule_form_kwargs,\n",
    "             **general_sum_kwargs)\n",
    "\n",
    "for seed in seeds:\n",
    "    print(f\"starting seed: {seed}\")\n",
    "    np.random.seed(seed)\n",
    "\n",
    "    random_schedules = generate_random_schedule_mapping_like(gsg.schedule_form_dict[\"schedules\"],48)\n",
    "    defender_actions, defender_costs = generate_defender_actions_with_costs(random_schedules)\n",
    "    attacker_actions = [0,1,2,3,4,5,6,7,8,9]\n",
    "    random_target_utilities = generate_random_target_utility_matrix_like_v2(gsg.schedule_form_dict[\"target_utilities\"], general_sum=True, respect_sign_roles=True)\n",
    "    attacker_matrix, defender_matrix = generate_schedule_game_matrix(attacker_actions, defender_actions, defender_costs, random_target_utilities, general_sum=True)\n",
    "    start = time.time()\n",
    "    _, coverage, du = solve_general_sum_normal_form(defender_matrix,attacker_matrix)\n",
    "    end=time.time()\n",
    "\n",
    "    support = sum([1 for t,p in coverage.items() if p!=0])\n",
    "    dus.append(du)\n",
    "    runtimes.append(end-start)\n",
    "    supports.append(support)\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "cb923683-129a-43cd-8b26-00ff22e27bb5",
   "metadata": {},
   "source": [
    "### new randomization logic"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 80,
   "id": "4cbbb2ac-ec4e-4aef-99f6-9247256e05b3",
   "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>seed</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>defender_utility</th>\n",
       "      <th>support</th>\n",
       "      <th>runtime</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>1</td>\n",
       "      <td>8</td>\n",
       "      <td>2</td>\n",
       "      <td>10</td>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.257217</td>\n",
       "      <td>1</td>\n",
       "      <td>0.348460</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>2</td>\n",
       "      <td>8</td>\n",
       "      <td>2</td>\n",
       "      <td>10</td>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.285653</td>\n",
       "      <td>1</td>\n",
       "      <td>0.510406</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>3</td>\n",
       "      <td>8</td>\n",
       "      <td>2</td>\n",
       "      <td>10</td>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.275671</td>\n",
       "      <td>2</td>\n",
       "      <td>0.427433</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>4</td>\n",
       "      <td>8</td>\n",
       "      <td>2</td>\n",
       "      <td>10</td>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.259953</td>\n",
       "      <td>1</td>\n",
       "      <td>0.473227</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>5</td>\n",
       "      <td>8</td>\n",
       "      <td>2</td>\n",
       "      <td>10</td>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.258675</td>\n",
       "      <td>1</td>\n",
       "      <td>0.401918</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>6</td>\n",
       "      <td>8</td>\n",
       "      <td>2</td>\n",
       "      <td>10</td>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.289263</td>\n",
       "      <td>1</td>\n",
       "      <td>0.382147</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>7</td>\n",
       "      <td>8</td>\n",
       "      <td>2</td>\n",
       "      <td>10</td>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.278246</td>\n",
       "      <td>2</td>\n",
       "      <td>0.457276</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>8</td>\n",
       "      <td>8</td>\n",
       "      <td>2</td>\n",
       "      <td>10</td>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.265214</td>\n",
       "      <td>2</td>\n",
       "      <td>0.410036</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>9</td>\n",
       "      <td>8</td>\n",
       "      <td>2</td>\n",
       "      <td>10</td>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.261432</td>\n",
       "      <td>1</td>\n",
       "      <td>0.436831</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>10</td>\n",
       "      <td>8</td>\n",
       "      <td>2</td>\n",
       "      <td>10</td>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.268206</td>\n",
       "      <td>2</td>\n",
       "      <td>0.640203</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   seed  num_timesteps  num_defenders  num_clusters  dims  \\\n",
       "0     1              8              2            10     7   \n",
       "1     2              8              2            10     7   \n",
       "2     3              8              2            10     7   \n",
       "3     4              8              2            10     7   \n",
       "4     5              8              2            10     7   \n",
       "5     6              8              2            10     7   \n",
       "6     7              8              2            10     7   \n",
       "7     8              8              2            10     7   \n",
       "8     9              8              2            10     7   \n",
       "9    10              8              2            10     7   \n",
       "\n",
       "   defense_time_threshold  defender_utility  support   runtime  \n",
       "0                       1         -0.257217        1  0.348460  \n",
       "1                       1         -0.285653        1  0.510406  \n",
       "2                       1         -0.275671        2  0.427433  \n",
       "3                       1         -0.259953        1  0.473227  \n",
       "4                       1         -0.258675        1  0.401918  \n",
       "5                       1         -0.289263        1  0.382147  \n",
       "6                       1         -0.278246        2  0.457276  \n",
       "7                       1         -0.265214        2  0.410036  \n",
       "8                       1         -0.261432        1  0.436831  \n",
       "9                       1         -0.268206        2  0.640203  "
      ]
     },
     "execution_count": 80,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df = pd.DataFrame()\n",
    "df[\"seed\"] = seeds\n",
    "df[\"num_timesteps\"] = [8 for i in range(len(seeds))]\n",
    "df[\"num_defenders\"] = [2 for i in range(len(seeds))]\n",
    "df[\"num_clusters\"] = [10 for i in range(len(seeds))]\n",
    "df[\"dims\"] = [7 for i in range(len(seeds))]\n",
    "df[\"defense_time_threshold\"] = [1 for i in range(len(seeds))]\n",
    "df[\"defender_utility\"] = dus\n",
    "df[\"support\"] = supports\n",
    "df[\"runtime\"] = runtimes\n",
    "df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 81,
   "id": "6b96472d-8d0c-42fa-bc15-6c4282b4a855",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "1.4"
      ]
     },
     "execution_count": 81,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.mean([round(x,4) for x in df.support])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 82,
   "id": "8384dd50-9bf0-4355-820b-e3ee3100cf02",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.16329931618554522"
      ]
     },
     "execution_count": 82,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "stats.sem([round(x,4) for x in df.support])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 83,
   "id": "dc9478ba-35b8-48a4-8190-623e073f6a31",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.44878"
      ]
     },
     "execution_count": 83,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.mean([round(x,4) for x in df.runtime])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 84,
   "id": "d776519b-f081-4570-9421-734477b84b3a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.025800972419228265"
      ]
     },
     "execution_count": 84,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "stats.sem([round(x,4) for x in df.runtime])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 85,
   "id": "37581fa1-898e-42a1-9389-9ee7f93bce60",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "-0.26996000000000003"
      ]
     },
     "execution_count": 85,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.mean([round(x,4) for x in df.defender_utility])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 86,
   "id": "424aa82d-cac2-452e-8650-dfd49851ccd9",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.003667369629584671"
      ]
     },
     "execution_count": 86,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "stats.sem([round(x,4) for x in df.defender_utility])"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "2b6c0ad2-0705-4935-8d4f-5252476d33da",
   "metadata": {},
   "source": [
    "### old randomizaton logic"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "15ccb73a-026d-4396-8c69-26a0ebfe9c01",
   "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>seed</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>defender_utility</th>\n",
       "      <th>support</th>\n",
       "      <th>runtime</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>1</td>\n",
       "      <td>8</td>\n",
       "      <td>2</td>\n",
       "      <td>10</td>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.364794</td>\n",
       "      <td>2</td>\n",
       "      <td>0.433395</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>2</td>\n",
       "      <td>8</td>\n",
       "      <td>2</td>\n",
       "      <td>10</td>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.041760</td>\n",
       "      <td>1</td>\n",
       "      <td>0.437731</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>3</td>\n",
       "      <td>8</td>\n",
       "      <td>2</td>\n",
       "      <td>10</td>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.335759</td>\n",
       "      <td>3</td>\n",
       "      <td>0.362280</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>4</td>\n",
       "      <td>8</td>\n",
       "      <td>2</td>\n",
       "      <td>10</td>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.137561</td>\n",
       "      <td>2</td>\n",
       "      <td>0.341587</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>5</td>\n",
       "      <td>8</td>\n",
       "      <td>2</td>\n",
       "      <td>10</td>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.262375</td>\n",
       "      <td>2</td>\n",
       "      <td>0.380102</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>6</td>\n",
       "      <td>8</td>\n",
       "      <td>2</td>\n",
       "      <td>10</td>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.069592</td>\n",
       "      <td>3</td>\n",
       "      <td>0.350575</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>7</td>\n",
       "      <td>8</td>\n",
       "      <td>2</td>\n",
       "      <td>10</td>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.077671</td>\n",
       "      <td>1</td>\n",
       "      <td>0.364267</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>8</td>\n",
       "      <td>8</td>\n",
       "      <td>2</td>\n",
       "      <td>10</td>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.295773</td>\n",
       "      <td>3</td>\n",
       "      <td>0.501500</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>9</td>\n",
       "      <td>8</td>\n",
       "      <td>2</td>\n",
       "      <td>10</td>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.237512</td>\n",
       "      <td>2</td>\n",
       "      <td>0.391941</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>10</td>\n",
       "      <td>8</td>\n",
       "      <td>2</td>\n",
       "      <td>10</td>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.133573</td>\n",
       "      <td>4</td>\n",
       "      <td>0.385948</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   seed  num_timesteps  num_defenders  num_clusters  dims  \\\n",
       "0     1              8              2            10     7   \n",
       "1     2              8              2            10     7   \n",
       "2     3              8              2            10     7   \n",
       "3     4              8              2            10     7   \n",
       "4     5              8              2            10     7   \n",
       "5     6              8              2            10     7   \n",
       "6     7              8              2            10     7   \n",
       "7     8              8              2            10     7   \n",
       "8     9              8              2            10     7   \n",
       "9    10              8              2            10     7   \n",
       "\n",
       "   defense_time_threshold  defender_utility  support   runtime  \n",
       "0                       1         -0.364794        2  0.433395  \n",
       "1                       1         -0.041760        1  0.437731  \n",
       "2                       1         -0.335759        3  0.362280  \n",
       "3                       1         -0.137561        2  0.341587  \n",
       "4                       1         -0.262375        2  0.380102  \n",
       "5                       1         -0.069592        3  0.350575  \n",
       "6                       1         -0.077671        1  0.364267  \n",
       "7                       1         -0.295773        3  0.501500  \n",
       "8                       1         -0.237512        2  0.391941  \n",
       "9                       1         -0.133573        4  0.385948  "
      ]
     },
     "execution_count": 30,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df = pd.DataFrame()\n",
    "df[\"seed\"] = seeds\n",
    "df[\"num_timesteps\"] = [8 for i in range(len(seeds))]\n",
    "df[\"num_defenders\"] = [2 for i in range(len(seeds))]\n",
    "df[\"num_clusters\"] = [10 for i in range(len(seeds))]\n",
    "df[\"dims\"] = [7 for i in range(len(seeds))]\n",
    "df[\"defense_time_threshold\"] = [1 for i in range(len(seeds))]\n",
    "df[\"defender_utility\"] = dus\n",
    "df[\"support\"] = supports\n",
    "df[\"runtime\"] = runtimes\n",
    "df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "id": "8bbf3663-eec3-4a23-8c25-ba097c6a0587",
   "metadata": {},
   "outputs": [],
   "source": [
    "df.to_csv(\"GSG_NFG_SSE_RANDOM_SCHEDULES_AND_TARGET_VALUES.csv\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "2284cb9e-67cd-4010-8bc6-efb7c8ba31fb",
   "metadata": {},
   "source": [
    "# ISG"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "0cf7ea8d-5ea0-402d-908b-2e76288e48c7",
   "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": "2dd7181b-0ff9-409e-a538-37eb19ea3771",
   "metadata": {},
   "source": [
    "## ISG Simple SSE LP"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 54,
   "id": "ea0e04a7-9030-43ee-86ae-6a7293977738",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "starting seed: 1\n",
      "starting seed: 2\n",
      "starting seed: 3\n",
      "starting seed: 4\n",
      "starting seed: 5\n",
      "starting seed: 6\n",
      "starting seed: 7\n",
      "starting seed: 8\n",
      "starting seed: 9\n",
      "starting seed: 10\n"
     ]
    }
   ],
   "source": [
    "import warnings\n",
    "warnings.filterwarnings('ignore', category=FutureWarning)\n",
    "\n",
    "schedule_form_kwargs = {\n",
    "    \"schedule_form\": True,\n",
    "    \"simple\": True,\n",
    "    \"attacker_penalty_factor\": 3,\n",
    "    \"defender_penalty_factor\": 3\n",
    "}\n",
    "\n",
    "general_sum_kwargs = {\n",
    "    \"general_sum\": True,\n",
    "    \"attacker_feature_value\":  1, \n",
    "    \"defender_feature_value\": 100, \n",
    "    \"defender_step_cost\": 0,\n",
    "    \"alpha\":.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",
    "\n",
    "dus = []\n",
    "runtimes = []\n",
    "i=0\n",
    "\n",
    "isg = InfraSecurityGame(df_combined, ny_blocks_gdf, INFRA_WEIGHTS, bbox=bbox_downtown_large)\n",
    "isg.generate(num_attackers=1, \n",
    "             num_defenders=3, \n",
    "             home_base_assignments=[(fifth_precinct,booking_station, troop_nyc, first_precinct, police_plaza),(fifth_precinct,booking_station, troop_nyc, first_precinct, police_plaza),(fifth_precinct,booking_station, troop_nyc, first_precinct, police_plaza)], \n",
    "             num_timesteps=8, \n",
    "             generate_utility_matrix=False, \n",
    "             generate_actions=False, \n",
    "             force_return=True, \n",
    "             defense_time_threshold=1, \n",
    "             **schedule_form_kwargs,\n",
    "             **general_sum_kwargs, \n",
    "            )\n",
    "for seed in seeds:\n",
    "    print(f\"starting seed: {seed}\")\n",
    "    np.random.seed(seed)\n",
    "    sdict_copy = copy.deepcopy(isg.schedule_form_dict)\n",
    "    sdict_copy[\"target_utilities\"] = generate_random_target_utility_matrix_like_v2(isg.schedule_form_dict[\"target_utilities\"], general_sum=True, respect_sign_roles=True)\n",
    "    \n",
    "    start = time.time()\n",
    "    _, coverage, du = solve_sse_lp(sdict_copy)\n",
    "    end=time.time()\n",
    "\n",
    "    support = sum([1 for t,p in coverage.items() if p!=0])\n",
    "    dus.append(du)\n",
    "    runtimes.append(end-start)\n",
    "    supports.append(support)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 55,
   "id": "3c9accd4-7862-47d1-ac42-cfcaf4692f1c",
   "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>seed</th>\n",
       "      <th>num_timesteps</th>\n",
       "      <th>num_defenders</th>\n",
       "      <th>defense_time_threshold</th>\n",
       "      <th>defender_utility</th>\n",
       "      <th>support</th>\n",
       "      <th>runtime</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>1</td>\n",
       "      <td>8</td>\n",
       "      <td>3</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.317088</td>\n",
       "      <td>2</td>\n",
       "      <td>0.027678</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>2</td>\n",
       "      <td>8</td>\n",
       "      <td>3</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.112543</td>\n",
       "      <td>12</td>\n",
       "      <td>0.040828</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>3</td>\n",
       "      <td>8</td>\n",
       "      <td>3</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.297338</td>\n",
       "      <td>13</td>\n",
       "      <td>0.041553</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>4</td>\n",
       "      <td>8</td>\n",
       "      <td>3</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.074156</td>\n",
       "      <td>9</td>\n",
       "      <td>0.051275</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>5</td>\n",
       "      <td>8</td>\n",
       "      <td>3</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.082098</td>\n",
       "      <td>4</td>\n",
       "      <td>0.059753</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>6</td>\n",
       "      <td>8</td>\n",
       "      <td>3</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.123084</td>\n",
       "      <td>10</td>\n",
       "      <td>0.030066</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>7</td>\n",
       "      <td>8</td>\n",
       "      <td>3</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.307583</td>\n",
       "      <td>6</td>\n",
       "      <td>0.028065</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>8</td>\n",
       "      <td>8</td>\n",
       "      <td>3</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.549742</td>\n",
       "      <td>4</td>\n",
       "      <td>0.027598</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>9</td>\n",
       "      <td>8</td>\n",
       "      <td>3</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.182052</td>\n",
       "      <td>10</td>\n",
       "      <td>0.030777</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>10</td>\n",
       "      <td>8</td>\n",
       "      <td>3</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.089624</td>\n",
       "      <td>5</td>\n",
       "      <td>0.028890</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   seed  num_timesteps  num_defenders  defense_time_threshold  \\\n",
       "0     1              8              3                       1   \n",
       "1     2              8              3                       1   \n",
       "2     3              8              3                       1   \n",
       "3     4              8              3                       1   \n",
       "4     5              8              3                       1   \n",
       "5     6              8              3                       1   \n",
       "6     7              8              3                       1   \n",
       "7     8              8              3                       1   \n",
       "8     9              8              3                       1   \n",
       "9    10              8              3                       1   \n",
       "\n",
       "   defender_utility  support   runtime  \n",
       "0         -0.317088        2  0.027678  \n",
       "1         -0.112543       12  0.040828  \n",
       "2         -0.297338       13  0.041553  \n",
       "3         -0.074156        9  0.051275  \n",
       "4         -0.082098        4  0.059753  \n",
       "5         -0.123084       10  0.030066  \n",
       "6         -0.307583        6  0.028065  \n",
       "7         -0.549742        4  0.027598  \n",
       "8         -0.182052       10  0.030777  \n",
       "9         -0.089624        5  0.028890  "
      ]
     },
     "execution_count": 55,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df = pd.DataFrame()\n",
    "df[\"seed\"] = seeds\n",
    "df[\"num_timesteps\"] = [8 for i in range(len(seeds))]\n",
    "df[\"num_defenders\"] = [3 for i in range(len(seeds))]\n",
    "df[\"defense_time_threshold\"] = [1 for i in range(len(seeds))]\n",
    "df[\"defender_utility\"] = dus\n",
    "df[\"support\"] = supports\n",
    "df[\"runtime\"] = runtimes\n",
    "df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "1d4624df-eb75-469a-9c08-7da710ee71c5",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[2, 2, 1, 1, 1, 4, 2, 1, 5, 1]"
      ]
     },
     "execution_count": 16,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "[round(x,4) for x in df.support]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 56,
   "id": "ffa685bf-6de5-4561-a758-eb59721957d8",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "7.5"
      ]
     },
     "execution_count": 56,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.mean([round(x,4) for x in df.support])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 57,
   "id": "afb7fb65-d93b-483c-a70f-f4a3ba573e9f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "1.194896555262328"
      ]
     },
     "execution_count": 57,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "stats.sem([round(x,4) for x in df.support])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 58,
   "id": "63c68266-055e-4e92-9575-27910ca8bc2b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.036669999999999994"
      ]
     },
     "execution_count": 58,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.mean([round(x,4) for x in df.runtime])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 59,
   "id": "36e14e91-f7ad-4088-8533-2338ee23ca3e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.0035971609175385337"
      ]
     },
     "execution_count": 59,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "stats.sem([round(x,4) for x in df.runtime])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 60,
   "id": "c5bddeef-9f48-4fee-bcf2-314095fb446a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "-0.21353"
      ]
     },
     "execution_count": 60,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.mean([round(x,4) for x in df.defender_utility])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 61,
   "id": "389ec64f-55e6-4596-86f7-50c7cef299b0",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.04842192122949641"
      ]
     },
     "execution_count": 61,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "stats.sem([round(x,4) for x in df.defender_utility])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "adb9a0ba-32c7-4ab9-b462-14cf5ae45510",
   "metadata": {},
   "outputs": [],
   "source": [
    "df.to_csv(\"ISG_SIMPLE_SSE_RANDOM_TARGET_VALUES.csv\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a32c2eae-cb30-4258-984b-f7d983bf6088",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "starting seed: 1\n",
      "[[-0.59169758 -0.2947369  -0.99988802 ... -0.21599834 -0.05198398\n",
      "  -0.69312926]\n",
      " [-0.32215328 -0.14193542 -0.12409883 ... -0.22722385 -0.89893236\n",
      "  -0.56147156]\n",
      " [-0.11040248 -0.71252508 -0.71824181 ... -0.35008476 -0.4958768\n",
      "  -0.07515594]\n",
      " ...\n",
      " [-0.62150302 -0.07923594 -0.22096152 ... -0.34961872 -0.33088097\n",
      "  -0.92943706]\n",
      " [-0.81947367 -0.43827116 -0.51085942 ... -0.81773173 -0.65734987\n",
      "  -0.53180536]\n",
      " [-0.09006962 -0.92660242 -0.53653057 ... -0.14301337 -0.96011702\n",
      "  -0.42188867]]\n",
      "[[0.00270674 0.00285909 0.00902488 ... 0.00370563 0.00952263 0.00672378]\n",
      " [0.00855286 0.0079319  0.00828676 ... 0.00071188 0.00067955 0.0012529 ]\n",
      " [0.00306844 0.00713365 0.00960149 ... 0.00160479 0.00218471 0.00463471]\n",
      " ...\n",
      " [0.00350636 0.00487196 0.00447379 ... 0.00628288 0.00880423 0.00918377]\n",
      " [0.00524711 0.00264302 0.00951103 ... 0.00617418 0.00084619 0.00446367]\n",
      " [0.00929346 0.00667294 0.00887731 ... 0.00376071 0.00107242 0.00782623]]\n",
      "starting seed: 2\n",
      "[[-0.57312139 -0.97461586 -0.46183051 ... -0.50531819 -0.93607858\n",
      "  -0.58082936]\n",
      " [-0.90548747 -0.87549884 -0.41573215 ... -0.66552921 -0.44471439\n",
      "  -0.58139367]\n",
      " [-0.57238476 -0.23967803 -0.47559487 ... -0.65083244 -0.95527614\n",
      "  -0.03740349]\n",
      " ...\n",
      " [-0.96959124 -0.1800813  -0.46870795 ... -0.26723673 -0.61119897\n",
      "  -0.21261514]\n",
      " [-0.13564647 -0.4976924  -0.06390531 ... -0.8039566  -0.72957557\n",
      "  -0.36618183]\n",
      " [-0.9773278  -0.72602614 -0.50244115 ... -0.79349121 -0.54399443\n",
      "  -0.21463786]]\n",
      "[[0.00165475 0.00601517 0.00534553 ... 0.00659599 0.00533557 0.00804683]\n",
      " [0.00119073 0.00456809 0.00901028 ... 0.00028696 0.00296292 0.00609298]\n",
      " [0.00890557 0.00084024 0.00074561 ... 0.00058822 0.00357019 0.00339898]\n",
      " ...\n",
      " [0.00775708 0.0073373  0.0027145  ... 0.00168326 0.00854277 0.00719603]\n",
      " [0.00702582 0.00821432 0.00919454 ... 0.00226945 0.00681225 0.00896635]\n",
      " [0.00819474 0.00735792 0.00204746 ... 0.00108198 0.00064179 0.00609318]]\n",
      "starting seed: 3\n",
      "[[-0.46071883 -0.30665897 -0.71517784 ... -0.72240319 -0.32135503\n",
      "  -0.56875581]\n",
      " [-0.84641224 -0.46673915 -0.23600098 ... -0.71430837 -0.55188345\n",
      "  -0.15745914]\n",
      " [-0.42600516 -0.72243964 -0.72783477 ... -0.93975759 -0.76239872\n",
      "  -0.04871281]\n",
      " ...\n",
      " [-0.91404443 -0.75682461 -0.19010444 ... -0.09145168 -0.7552527\n",
      "  -0.02170675]\n",
      " [-0.36413793 -0.75332994 -0.60604352 ... -0.32589075 -0.05162961\n",
      "  -0.24272537]\n",
      " [-0.04803035 -0.8053761  -0.24906209 ... -0.9725132  -0.37541782\n",
      "  -0.06321001]]\n",
      "[[0.00198021 0.00607643 0.00827275 ... 0.00497335 0.0067917  0.00535331]\n",
      " [0.0063741  0.00095261 0.00496225 ... 0.00978005 0.0076154  0.00273694]\n",
      " [0.00073169 0.00096742 0.00978717 ... 0.00583145 0.00249789 0.00959338]\n",
      " ...\n",
      " [0.00032855 0.00495569 0.00856716 ... 0.00580596 0.00103771 0.00141513]\n",
      " [0.0018872  0.00468307 0.00339558 ... 0.00943162 0.00430918 0.00621086]\n",
      " [0.00969953 0.00265396 0.00525666 ... 0.00454453 0.001741   0.00105196]]\n",
      "starting seed: 4\n",
      "[[-0.05318996 -0.46420993 -0.04765367 ... -0.57297282 -0.07086503\n",
      "  -0.23013503]\n",
      " [-0.1518241  -0.83045533 -0.92661853 ... -0.82476829 -0.63227721\n",
      "  -0.50797449]\n",
      " [-0.32769056 -0.75162458 -0.45685831 ... -0.41676723 -0.91710859\n",
      "  -0.41522175]\n",
      " ...\n",
      " [-0.24768248 -0.63209792 -0.55026638 ... -0.66722638 -0.35346826\n",
      "  -0.65852356]\n",
      " [-0.86099908 -0.4208631  -0.92339279 ... -0.78815701 -0.59543975\n",
      "  -0.89420753]\n",
      " [-0.90775136 -0.95627145 -0.23683334 ... -0.576985   -0.06084532\n",
      "  -0.46335831]]\n",
      "[[0.00243931 0.00292654 0.00160906 ... 0.00536441 0.00958295 0.00089534]\n",
      " [0.00418351 0.00642815 0.00064291 ... 0.00225739 0.00941824 0.0071201 ]\n",
      " [0.0053331  0.00509875 0.0061168  ... 0.00898933 0.00655516 0.00059434]\n",
      " ...\n",
      " [0.00720965 0.00720695 0.00574972 ... 0.00863833 0.00972189 0.00851236]\n",
      " [0.00587306 0.00111457 0.00844356 ... 0.00579587 0.00794888 0.00078715]\n",
      " [0.00561762 0.00755065 0.00801546 ... 0.00770073 0.00079388 0.0009325 ]]\n",
      "starting seed: 5\n",
      "[[-0.78264852 -0.14747399 -0.79760317 ... -0.41261483 -0.73973894\n",
      "  -0.72126667]\n",
      " [-0.75171412 -0.67928515 -0.85885006 ... -0.09654432 -0.99783208\n",
      "  -0.54032824]\n",
      " [-0.03905297 -0.6093968  -0.203282   ... -0.64650081 -0.96523343\n",
      "  -0.46506556]\n",
      " ...\n",
      " [-0.40958365 -0.99536811 -0.58965044 ... -0.65361469 -0.07694276\n",
      "  -0.56841916]\n",
      " [-0.88204446 -0.38886322 -0.87874872 ... -0.34110817 -0.61979108\n",
      "  -0.59449447]\n",
      " [-0.06088712 -0.61991355 -0.99911752 ... -0.11847255 -0.77947634\n",
      "  -0.75567867]]\n",
      "[[0.0011492  0.00091923 0.00366296 ... 0.00334566 0.0070222  0.00625612]\n",
      " [0.00031222 0.00037287 0.00342255 ... 0.00465437 0.00189002 0.00095836]\n",
      " [0.00524031 0.00700591 0.00643256 ... 0.00089167 0.00277915 0.00430966]\n",
      " ...\n",
      " [0.0069608  0.00260347 0.00306822 ... 0.00462174 0.00407097 0.00716891]\n",
      " [0.00519179 0.00724961 0.009563   ... 0.00953378 0.00046672 0.0016989 ]\n",
      " [0.00818098 0.00884488 0.00540787 ... 0.00122305 0.00693752 0.00167314]]\n",
      "starting seed: 6\n",
      "[[-0.12580882 -0.67496162 -0.1959421  ... -0.94666451 -0.29638888\n",
      "  -0.21460216]\n",
      " [-0.27899101 -0.30569561 -0.47037369 ... -0.03130727 -0.55892029\n",
      "  -0.63400759]\n",
      " [-0.30520914 -0.91926559 -0.60995673 ... -0.60429393 -0.27362849\n",
      "  -0.1913363 ]\n",
      " ...\n",
      " [-0.04565474 -0.20791237 -0.85126952 ... -0.16358693 -0.61793688\n",
      "  -0.15391412]\n",
      " [-0.29669013 -0.83520138 -0.56354013 ... -0.58035061 -0.44657409\n",
      "  -0.81440215]\n",
      " [-0.90216801 -0.43459217 -0.53370711 ... -0.16759774 -0.92760681\n",
      "  -0.72276635]]\n",
      "[[0.00653655 0.00551154 0.004282   ... 0.00412345 0.00272467 0.00913974]\n",
      " [0.00277265 0.00656658 0.0067235  ... 0.00755389 0.00502552 0.00799651]\n",
      " [0.00454435 0.00350402 0.00659179 ... 0.00109191 0.0093238  0.00136641]\n",
      " ...\n",
      " [0.00312836 0.00377225 0.00064772 ... 0.0043244  0.00635469 0.00740301]\n",
      " [0.00892828 0.00724322 0.00876976 ... 0.00628023 0.00149957 0.00967413]\n",
      " [0.00683109 0.00976395 0.0039412  ... 0.00943705 0.00925089 0.00580046]]\n",
      "starting seed: 7\n",
      "[[-0.92528725 -0.23638867 -0.57075755 ... -0.41200807 -0.06973693\n",
      "  -0.77451256]\n",
      " [-0.46297855 -0.10988075 -0.86961502 ... -0.63739265 -0.55050628\n",
      "  -0.29571635]\n",
      " [-0.59564349 -0.1125293  -0.82332148 ... -0.05520575 -0.07471196\n",
      "  -0.16933848]\n",
      " ...\n",
      " [-0.44816258 -0.62010336 -0.37040596 ... -0.98284067 -0.43668295\n",
      "  -0.60235207]\n",
      " [-0.68784084 -0.73506195 -0.9628862  ... -0.35465223 -0.15642214\n",
      "  -0.27496797]\n",
      " [-0.66110687 -0.70471546 -0.05641454 ... -0.72578191 -0.47997113\n",
      "  -0.52076289]]\n",
      "[[0.00570782 0.00130708 0.00421493 ... 0.00981919 0.00794229 0.00732639]\n",
      " [0.00772155 0.00761834 0.00384347 ... 0.00075971 0.00175808 0.00508243]\n",
      " [0.00200879 0.00561163 0.00450056 ... 0.004361   0.00611667 0.00794456]\n",
      " ...\n",
      " [0.00105363 0.00021024 0.00727178 ... 0.00710106 0.00490087 0.00044537]\n",
      " [0.00477218 0.00431397 0.00839746 ... 0.00967826 0.00526512 0.00142194]\n",
      " [0.00562519 0.00838975 0.0097113  ... 0.00988491 0.00598184 0.00814394]]\n",
      "starting seed: 8\n",
      "[[-0.14483329 -0.05171073 -0.1489796  ... -0.93556761 -0.03768047\n",
      "  -0.87481764]\n",
      " [-0.6846047  -0.93054051 -0.77992982 ... -0.96866111 -0.55407522\n",
      "  -0.22634932]\n",
      " [-0.03207422 -0.42824568 -0.96190133 ... -0.57427542 -0.57752855\n",
      "  -0.81800299]\n",
      " ...\n",
      " [-0.8208535  -0.40467423 -0.05548356 ... -0.5284239  -0.52186533\n",
      "  -0.26543056]\n",
      " [-0.87612973 -0.30131602 -0.73285299 ... -0.03342318 -0.74326684\n",
      "  -0.39613723]\n",
      " [-0.37728512 -0.45690214 -0.43763601 ... -0.61907828 -0.32474544\n",
      "  -0.61184551]]\n",
      "[[0.00208245 0.00119712 0.00854601 ... 0.0045182  0.00082388 0.00772184]\n",
      " [0.00073591 0.00496772 0.00577816 ... 0.00377511 0.00126115 0.00489584]\n",
      " [0.00615984 0.00802341 0.00294322 ... 0.00410033 0.00197606 0.00151145]\n",
      " ...\n",
      " [0.00670425 0.00534988 0.00138602 ... 0.00306516 0.00699512 0.00379118]\n",
      " [0.00118373 0.00517331 0.00290036 ... 0.00026599 0.00671922 0.0080211 ]\n",
      " [0.00220408 0.00706749 0.00880294 ... 0.00188321 0.00394798 0.00899614]]\n",
      "starting seed: 9\n",
      "[[-0.98984276 -0.50861919 -0.51459292 ... -0.62160375 -0.32008146\n",
      "  -0.1923769 ]\n",
      " [-0.54406827 -0.07914118 -0.21306577 ... -0.57355164 -0.14779123\n",
      "  -0.81655887]\n",
      " [-0.32670461 -0.31118104 -0.0941451  ... -0.63272075 -0.80454084\n",
      "  -0.66436255]\n",
      " ...\n",
      " [-0.99031499 -0.54769128 -0.3623329  ... -0.61614025 -0.53755098\n",
      "  -0.74824345]\n",
      " [-0.63708167 -0.96571458 -0.34607635 ... -0.3137245  -0.92919373\n",
      "  -0.80704336]\n",
      " [-0.14035302 -0.86606406 -0.44975982 ... -0.95883821 -0.46672476\n",
      "  -0.39754004]]\n",
      "[[0.00204799 0.00838815 0.00787336 ... 0.00301137 0.00428464 0.00142533]\n",
      " [0.00946657 0.00438708 0.00906602 ... 0.00285524 0.00583723 0.00198999]\n",
      " [0.00973138 0.00605546 0.00135357 ... 0.00931635 0.00947723 0.00116222]\n",
      " ...\n",
      " [0.00365385 0.00978597 0.00354142 ... 0.00743711 0.0033104  0.00852009]\n",
      " [0.00959886 0.00455805 0.00723863 ... 0.0067836  0.00611213 0.00387977]\n",
      " [0.00104868 0.00428973 0.00950777 ... 0.00037608 0.00790398 0.00259748]]\n",
      "starting seed: 10\n",
      "[[-0.24480704 -0.97968196 -0.37960083 ... -0.46879979 -0.86080261\n",
      "  -0.63446549]\n",
      " [-0.33996196 -0.56740519 -0.57506088 ... -0.16106573 -0.65570013\n",
      "  -0.26113137]\n",
      " [-0.71022661 -0.13454591 -0.68129454 ... -0.92205155 -0.700927\n",
      "  -0.67619576]\n",
      " ...\n",
      " [-0.65511006 -0.31082977 -0.46845803 ... -0.18451733 -0.94399034\n",
      "  -0.27832138]\n",
      " [-0.36221276 -0.7604287  -0.16787133 ... -0.77294931 -0.8030812\n",
      "  -0.11190419]\n",
      " [-0.76251293 -0.22065669 -0.54830924 ... -0.35675613 -0.57390068\n",
      "  -0.7682766 ]]\n",
      "[[0.00276409 0.00785656 0.00514162 ... 0.00267714 0.00593031 0.00383032]\n",
      " [0.00822528 0.00021808 0.00337145 ... 0.00428467 0.00480311 0.00363347]\n",
      " [0.0030167  0.0056539  0.00361927 ... 0.00391984 0.00528107 0.00126391]\n",
      " ...\n",
      " [0.00120003 0.00486143 0.00721412 ... 0.00366611 0.00431159 0.0080813 ]\n",
      " [0.00190227 0.00197842 0.0039091  ... 0.0060658  0.00218606 0.00183329]\n",
      " [0.00029889 0.00970062 0.00603681 ... 0.00439654 0.00181577 0.00539484]]\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\": True,\n",
    "    \"attacker_feature_value\":  1, \n",
    "    \"defender_feature_value\": 100, \n",
    "    \"defender_step_cost\": 1,\n",
    "    \"alpha\":.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",
    "supports=[]\n",
    "dts = []\n",
    "\n",
    "dus = []\n",
    "runtimes = []\n",
    "\n",
    "isg = InfraSecurityGame(df_combined, ny_blocks_gdf, INFRA_WEIGHTS, bbox=bbox_downtown_large)\n",
    "isg.generate(num_attackers=1, \n",
    "             num_defenders=3, \n",
    "             home_base_assignments=[(fifth_precinct,booking_station, troop_nyc, first_precinct, police_plaza),(fifth_precinct,booking_station, troop_nyc, first_precinct, police_plaza)], \n",
    "             num_timesteps=8, \n",
    "             generate_utility_matrix=True, \n",
    "             generate_actions=False, \n",
    "             force_return=True, \n",
    "             defense_time_threshold=1, \n",
    "             **schedule_form_kwargs,\n",
    "             **general_sum_kwargs, \n",
    "            )\n",
    "for seed in seeds:\n",
    "    print(f\"starting seed: {seed}\")\n",
    "    np.random.seed(seed)\n",
    "    sdict_copy = copy.deepcopy(isg.schedule_form_dict)\n",
    "    sdict_copy[\"defender_utility_matrix\"] = generate_random_utility_matrix_like(isg.schedule_form_dict[\"defender_utility_matrix\"])\n",
    "    sdict_copy[\"attacker_utility_matrix\"] = generate_random_utility_matrix_like(isg.schedule_form_dict[\"attacker_utility_matrix\"])\n",
    "    print(sdict_copy[\"defender_utility_matrix\"])\n",
    "    print(sdict_copy[\"attacker_utility_matrix\"])\n",
    "    start = time.time()\n",
    "    _, coverage, du = solve_general_sum_normal_form(sdict_copy[\"defender_utility_matrix\"],sdict_copy[\"attacker_utility_matrix\"])\n",
    "    end=time.time()\n",
    "\n",
    "    support = sum([1 for t,p in coverage.items() if p!=0])\n",
    "    dus.append(du)\n",
    "    runtimes.append(end-start)\n",
    "    supports.append(support)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "id": "5011d822-aaaa-47ed-9e53-7e87db393920",
   "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>seed</th>\n",
       "      <th>num_timesteps</th>\n",
       "      <th>num_defenders</th>\n",
       "      <th>defense_time_threshold</th>\n",
       "      <th>defender_utility</th>\n",
       "      <th>support</th>\n",
       "      <th>runtime</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>1</td>\n",
       "      <td>8</td>\n",
       "      <td>3</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.020930</td>\n",
       "      <td>2</td>\n",
       "      <td>2.130541</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>2</td>\n",
       "      <td>8</td>\n",
       "      <td>3</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.021068</td>\n",
       "      <td>2</td>\n",
       "      <td>2.216249</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>3</td>\n",
       "      <td>8</td>\n",
       "      <td>3</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.021014</td>\n",
       "      <td>1</td>\n",
       "      <td>2.185663</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>4</td>\n",
       "      <td>8</td>\n",
       "      <td>3</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.021333</td>\n",
       "      <td>3</td>\n",
       "      <td>2.403166</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>5</td>\n",
       "      <td>8</td>\n",
       "      <td>3</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.020914</td>\n",
       "      <td>1</td>\n",
       "      <td>1.997962</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>6</td>\n",
       "      <td>8</td>\n",
       "      <td>3</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.020962</td>\n",
       "      <td>1</td>\n",
       "      <td>2.882317</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>7</td>\n",
       "      <td>8</td>\n",
       "      <td>3</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.021171</td>\n",
       "      <td>1</td>\n",
       "      <td>2.685996</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>8</td>\n",
       "      <td>8</td>\n",
       "      <td>3</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.021207</td>\n",
       "      <td>4</td>\n",
       "      <td>2.930520</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>9</td>\n",
       "      <td>8</td>\n",
       "      <td>3</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.020962</td>\n",
       "      <td>1</td>\n",
       "      <td>2.315993</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>10</td>\n",
       "      <td>8</td>\n",
       "      <td>3</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.020994</td>\n",
       "      <td>2</td>\n",
       "      <td>1.839676</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   seed  num_timesteps  num_defenders  defense_time_threshold  \\\n",
       "0     1              8              3                       1   \n",
       "1     2              8              3                       1   \n",
       "2     3              8              3                       1   \n",
       "3     4              8              3                       1   \n",
       "4     5              8              3                       1   \n",
       "5     6              8              3                       1   \n",
       "6     7              8              3                       1   \n",
       "7     8              8              3                       1   \n",
       "8     9              8              3                       1   \n",
       "9    10              8              3                       1   \n",
       "\n",
       "   defender_utility  support   runtime  \n",
       "0         -0.020930        2  2.130541  \n",
       "1         -0.021068        2  2.216249  \n",
       "2         -0.021014        1  2.185663  \n",
       "3         -0.021333        3  2.403166  \n",
       "4         -0.020914        1  1.997962  \n",
       "5         -0.020962        1  2.882317  \n",
       "6         -0.021171        1  2.685996  \n",
       "7         -0.021207        4  2.930520  \n",
       "8         -0.020962        1  2.315993  \n",
       "9         -0.020994        2  1.839676  "
      ]
     },
     "execution_count": 34,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df = pd.DataFrame()\n",
    "df[\"seed\"] = seeds\n",
    "df[\"num_timesteps\"] = [8 for i in range(len(seeds))]\n",
    "df[\"num_defenders\"] = [3 for i in range(len(seeds))]\n",
    "df[\"defense_time_threshold\"] = [1 for i in range(len(seeds))]\n",
    "df[\"defender_utility\"] = dus\n",
    "df[\"support\"] = supports\n",
    "df[\"runtime\"] = runtimes\n",
    "df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "id": "6622c656-d9b5-4691-b04e-53a1ae84f108",
   "metadata": {},
   "outputs": [],
   "source": [
    "df.to_csv(\"ISG_NFG_SSE_RANDOM_MATRIX.csv\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b5dc85e5-6499-4a02-9278-efb441fb6c3a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4e7863d0-d29d-4731-ad57-0957516776dd",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "starting seed: 1\n",
      "[[-6.92381775e-01 -8.76412920e-01 -8.94626928e-01 -3.02466718e-01\n",
      "  -1.46919949e-01 -1.69990042e-01 -8.78165934e-01 -3.45686560e-01\n",
      "  -4.21218932e-01 -9.57897627e-01 -5.33255046e-01 -6.91936359e-01\n",
      "  -3.15647241e-01 -8.78140872e-01 -8.34657469e-01 -6.70530871e-01\n",
      "  -7.50192356e-01 -9.88863231e-01 -7.48214076e-01 -2.80582346e-01\n",
      "  -8.00782881e-01 -9.68267678e-01 -4.47999683e-01]\n",
      " [-4.17134098e-01 -7.20378268e-01 -3.06629178e-04 -8.52201357e-02\n",
      "  -3.92395503e-02 -9.25131166e-02 -1.86416674e-01 -9.85202004e-02\n",
      "  -3.96883462e-01 -5.38905409e-01 -4.19306190e-01 -6.85280025e-01\n",
      "  -2.04605215e-01 -6.86561206e-01 -2.75746036e-02 -1.84770373e-02\n",
      "  -4.17416841e-01 -5.58774682e-01 -1.40552222e-01 -1.98255675e-01\n",
      "  -7.89319845e-01 -1.03398435e-01 -3.13556190e-01]\n",
      " [ 5.86634536e-01  2.93749970e-01  1.37640547e-01  1.30195847e-01\n",
      "   1.95555104e-02  3.97792649e-01  1.65514680e-01  2.65687877e-01\n",
      "   3.47891269e-01  5.35445611e-02  5.74199493e-01  1.46892639e-01\n",
      "   5.89384504e-01  6.99816089e-01  1.02507029e-01  2.70068267e-01\n",
      "   6.94458917e-01  4.14291909e-01  5.01361304e-02  5.35985642e-01\n",
      "   6.21768459e-01  1.14916186e-01  9.44605409e-01]\n",
      " [ 9.08613078e-01  9.03420489e-01  2.87912283e-01  1.39441844e-01\n",
      "   8.07428323e-01  6.78897285e-01  2.11779701e-01  9.27522519e-01\n",
      "   4.91670918e-01  7.50860016e-01  7.26050669e-01  8.83328529e-01\n",
      "   6.23744566e-01  7.50990322e-01  3.49023533e-01  4.14168651e-01\n",
      "   8.95906237e-01  4.28201154e-01  9.64846808e-01  6.63506210e-01\n",
      "   6.63859290e-01  5.14982387e-01  9.49498971e-01]]\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[13], line 81\u001b[0m\n\u001b[0;32m     79\u001b[0m attacker_matrix, defender_matrix \u001b[38;5;241m=\u001b[39m generate_schedule_game_matrix(attacker_actions, defender_actions, defender_costs, random_target_utilities, general_sum\u001b[38;5;241m=\u001b[39m\u001b[38;5;28;01mTrue\u001b[39;00m)\n\u001b[0;32m     80\u001b[0m start \u001b[38;5;241m=\u001b[39m time\u001b[38;5;241m.\u001b[39mtime()\n\u001b[1;32m---> 81\u001b[0m _, coverage, du \u001b[38;5;241m=\u001b[39m \u001b[43msolve_general_sum_normal_form\u001b[49m\u001b[43m(\u001b[49m\u001b[43mdefender_matrix\u001b[49m\u001b[43m,\u001b[49m\u001b[43mattacker_matrix\u001b[49m\u001b[43m)\u001b[49m\n\u001b[0;32m     82\u001b[0m end\u001b[38;5;241m=\u001b[39mtime\u001b[38;5;241m.\u001b[39mtime()\n\u001b[0;32m     84\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 t,p \u001b[38;5;129;01min\u001b[39;00m coverage\u001b[38;5;241m.\u001b[39mitems() \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\\..\\solvers\\nfg_sse_lp.py:42\u001b[0m, in \u001b[0;36msolve_general_sum_normal_form\u001b[1;34m(defender_matrix, attacker_matrix)\u001b[0m\n\u001b[0;32m     40\u001b[0m \u001b[38;5;28;01mfor\u001b[39;00m t_prime \u001b[38;5;129;01min\u001b[39;00m \u001b[38;5;28mrange\u001b[39m(num_attacker_strategies):\n\u001b[0;32m     41\u001b[0m     lhs \u001b[38;5;241m=\u001b[39m gp\u001b[38;5;241m.\u001b[39mquicksum(p[s] \u001b[38;5;241m*\u001b[39m attacker_matrix[s, t] \u001b[38;5;28;01mfor\u001b[39;00m s \u001b[38;5;129;01min\u001b[39;00m \u001b[38;5;28mrange\u001b[39m(num_defender_strategies))\n\u001b[1;32m---> 42\u001b[0m     rhs \u001b[38;5;241m=\u001b[39m \u001b[43mgp\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mquicksum\u001b[49m\u001b[43m(\u001b[49m\u001b[43mp\u001b[49m\u001b[43m[\u001b[49m\u001b[43ms\u001b[49m\u001b[43m]\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43m \u001b[49m\u001b[43mattacker_matrix\u001b[49m\u001b[43m[\u001b[49m\u001b[43ms\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mt_prime\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[43ms\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_defender_strategies\u001b[49m\u001b[43m)\u001b[49m\u001b[43m)\u001b[49m\n\u001b[0;32m     43\u001b[0m     model\u001b[38;5;241m.\u001b[39maddConstr(lhs \u001b[38;5;241m>\u001b[39m\u001b[38;5;241m=\u001b[39m rhs, name\u001b[38;5;241m=\u001b[39m\u001b[38;5;124mf\u001b[39m\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mbr_t_\u001b[39m\u001b[38;5;132;01m{\u001b[39;00mt_prime\u001b[38;5;132;01m}\u001b[39;00m\u001b[38;5;124m\"\u001b[39m)\n\u001b[0;32m     45\u001b[0m model\u001b[38;5;241m.\u001b[39moptimize()\n",
      "File \u001b[1;32msrc\\\\gurobipy\\\\_helpers.pyx:41\u001b[0m, in \u001b[0;36mgurobipy._helpers.quicksum\u001b[1;34m()\u001b[0m\n",
      "File \u001b[1;32m~\\GameGenerators\\notebooks\\..\\solvers\\nfg_sse_lp.py:42\u001b[0m, in \u001b[0;36m<genexpr>\u001b[1;34m(.0)\u001b[0m\n\u001b[0;32m     40\u001b[0m \u001b[38;5;28;01mfor\u001b[39;00m t_prime \u001b[38;5;129;01min\u001b[39;00m \u001b[38;5;28mrange\u001b[39m(num_attacker_strategies):\n\u001b[0;32m     41\u001b[0m     lhs \u001b[38;5;241m=\u001b[39m gp\u001b[38;5;241m.\u001b[39mquicksum(p[s] \u001b[38;5;241m*\u001b[39m attacker_matrix[s, t] \u001b[38;5;28;01mfor\u001b[39;00m s \u001b[38;5;129;01min\u001b[39;00m \u001b[38;5;28mrange\u001b[39m(num_defender_strategies))\n\u001b[1;32m---> 42\u001b[0m     rhs \u001b[38;5;241m=\u001b[39m gp\u001b[38;5;241m.\u001b[39mquicksum(p[s] \u001b[38;5;241m*\u001b[39m attacker_matrix[s, t_prime] \u001b[38;5;28;01mfor\u001b[39;00m s \u001b[38;5;129;01min\u001b[39;00m \u001b[38;5;28mrange\u001b[39m(num_defender_strategies))\n\u001b[0;32m     43\u001b[0m     model\u001b[38;5;241m.\u001b[39maddConstr(lhs \u001b[38;5;241m>\u001b[39m\u001b[38;5;241m=\u001b[39m rhs, name\u001b[38;5;241m=\u001b[39m\u001b[38;5;124mf\u001b[39m\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mbr_t_\u001b[39m\u001b[38;5;132;01m{\u001b[39;00mt_prime\u001b[38;5;132;01m}\u001b[39;00m\u001b[38;5;124m\"\u001b[39m)\n\u001b[0;32m     45\u001b[0m model\u001b[38;5;241m.\u001b[39moptimize()\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",
    "}\n",
    "\n",
    "general_sum_kwargs = {\n",
    "    \"general_sum\": True,\n",
    "    \"attacker_feature_value\":  1, \n",
    "    \"defender_feature_value\": 100, \n",
    "    \"defender_step_cost\": 1,\n",
    "    \"alpha\":.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",
    "supports=[]\n",
    "dts = []\n",
    "\n",
    "dus = []\n",
    "runtimes = []\n",
    "\n",
    "isg = InfraSecurityGame(df_combined, ny_blocks_gdf, INFRA_WEIGHTS, bbox=bbox_downtown_large)\n",
    "isg.generate(num_attackers=1, \n",
    "             num_defenders=3, \n",
    "             home_base_assignments=[(fifth_precinct,booking_station, troop_nyc, first_precinct, police_plaza),(fifth_precinct,booking_station, troop_nyc, first_precinct, police_plaza),(fifth_precinct,booking_station, troop_nyc, first_precinct, police_plaza)], \n",
    "             num_timesteps=8, \n",
    "             generate_utility_matrix=False, \n",
    "             random_target_values=False,\n",
    "             randomize_target_utility_matrix=False,\n",
    "             generate_actions=False, \n",
    "             force_return=True, \n",
    "             defense_time_threshold=1, \n",
    "             **schedule_form_kwargs,\n",
    "             **general_sum_kwargs, \n",
    "            )\n",
    "\n",
    "# for seed in seeds:\n",
    "#     print(f\"starting seed: {seed}\")\n",
    "#     np.random.seed(seed)\n",
    "    \n",
    "#     print(isg.schedule_form_dict[\"target_utilities\"])\n",
    "#     start = time.time()\n",
    "#     _, coverage, du = solve_general_sum_normal_form(isg.schedule_form_dict[\"defender_utility_matrix\"],isg.schedule_form_dict[\"attacker_utility_matrix\"])\n",
    "#     end=time.time()\n",
    "\n",
    "#     support = sum([1 for t,p in coverage.items() if p!=0])\n",
    "#     dus.append(du)\n",
    "#     runtimes.append(end-start)\n",
    "#     supports.append(support)\n",
    "\n",
    "for seed in seeds:\n",
    "    print(f\"starting seed: {seed}\")\n",
    "    np.random.seed(seed)\n",
    "    defender_actions,defender_costs = generate_defender_actions_with_costs(isg.schedule_form_dict[\"schedules\"])\n",
    "    attacker_actions = [0,1,2,3,4,5,6,7,8,9]\n",
    "    random_target_utilities = generate_random_target_utility_matrix_like_v2(isg.schedule_form_dict[\"target_utilities\"], general_sum=True, respect_sign_roles=True)\n",
    "    print(random_target_utilities)\n",
    "    attacker_matrix, defender_matrix = generate_schedule_game_matrix(attacker_actions, defender_actions, defender_costs, random_target_utilities, general_sum=True)\n",
    "    start = time.time()\n",
    "    _, coverage, du = solve_general_sum_normal_form(defender_matrix,attacker_matrix)\n",
    "    end=time.time()\n",
    "\n",
    "    support = sum([1 for t,p in coverage.items() if p!=0])\n",
    "    dus.append(du)\n",
    "    runtimes.append(end-start)\n",
    "    supports.append(support)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "458da184-88a2-4346-8f7f-bee91ed38f2d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "636056"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(defender_actions)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "d5963917-4ca1-4cab-ba61-9a8bc91c8949",
   "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>seed</th>\n",
       "      <th>num_timesteps</th>\n",
       "      <th>num_defenders</th>\n",
       "      <th>defense_time_threshold</th>\n",
       "      <th>defender_utility</th>\n",
       "      <th>support</th>\n",
       "      <th>runtime</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>1</td>\n",
       "      <td>8</td>\n",
       "      <td>3</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.007061</td>\n",
       "      <td>1</td>\n",
       "      <td>111.553856</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>2</td>\n",
       "      <td>8</td>\n",
       "      <td>3</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.008952</td>\n",
       "      <td>1</td>\n",
       "      <td>126.751138</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>3</td>\n",
       "      <td>8</td>\n",
       "      <td>3</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.010432</td>\n",
       "      <td>1</td>\n",
       "      <td>114.891145</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>4</td>\n",
       "      <td>8</td>\n",
       "      <td>3</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.014247</td>\n",
       "      <td>1</td>\n",
       "      <td>112.728036</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>5</td>\n",
       "      <td>8</td>\n",
       "      <td>3</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.005182</td>\n",
       "      <td>1</td>\n",
       "      <td>117.559772</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>6</td>\n",
       "      <td>8</td>\n",
       "      <td>3</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.012147</td>\n",
       "      <td>1</td>\n",
       "      <td>111.024647</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>7</td>\n",
       "      <td>8</td>\n",
       "      <td>3</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.018562</td>\n",
       "      <td>1</td>\n",
       "      <td>112.103105</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>8</td>\n",
       "      <td>8</td>\n",
       "      <td>3</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.017831</td>\n",
       "      <td>1</td>\n",
       "      <td>113.998473</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>9</td>\n",
       "      <td>8</td>\n",
       "      <td>3</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.016409</td>\n",
       "      <td>1</td>\n",
       "      <td>126.918250</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>10</td>\n",
       "      <td>8</td>\n",
       "      <td>3</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.018579</td>\n",
       "      <td>1</td>\n",
       "      <td>114.693679</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   seed  num_timesteps  num_defenders  defense_time_threshold  \\\n",
       "0     1              8              3                       1   \n",
       "1     2              8              3                       1   \n",
       "2     3              8              3                       1   \n",
       "3     4              8              3                       1   \n",
       "4     5              8              3                       1   \n",
       "5     6              8              3                       1   \n",
       "6     7              8              3                       1   \n",
       "7     8              8              3                       1   \n",
       "8     9              8              3                       1   \n",
       "9    10              8              3                       1   \n",
       "\n",
       "   defender_utility  support     runtime  \n",
       "0         -0.007061        1  111.553856  \n",
       "1         -0.008952        1  126.751138  \n",
       "2         -0.010432        1  114.891145  \n",
       "3         -0.014247        1  112.728036  \n",
       "4         -0.005182        1  117.559772  \n",
       "5         -0.012147        1  111.024647  \n",
       "6         -0.018562        1  112.103105  \n",
       "7         -0.017831        1  113.998473  \n",
       "8         -0.016409        1  126.918250  \n",
       "9         -0.018579        1  114.693679  "
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df = pd.DataFrame()\n",
    "df[\"seed\"] = seeds\n",
    "df[\"num_timesteps\"] = [8 for i in range(len(seeds))]\n",
    "df[\"num_defenders\"] = [3 for i in range(len(seeds))]\n",
    "df[\"defense_time_threshold\"] = [1 for i in range(len(seeds))]\n",
    "df[\"defender_utility\"] = dus\n",
    "df[\"support\"] = supports\n",
    "df[\"runtime\"] = runtimes\n",
    "df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "d345cb65-6596-43ce-91f1-35a841fbdf21",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "1.0"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.mean([round(x,4) for x in df.support])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "2ea3ad34-b871-42ef-8f0d-f9b001b73de4",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.0"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "stats.sem([round(x,4) for x in df.support])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "a564e909-f450-44d8-aa33-7e94abfd40fe",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "116.22221000000002"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.mean([round(x,4) for x in df.runtime])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "0ba71eae-cfdc-4e56-80b7-e1398c7f77ac",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "1.868127209649635"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "stats.sem([round(x,4) for x in df.runtime])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "33ca69d7-66c3-4e20-b6a4-3904bf1b04fe",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "-0.012939999999999998"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.mean([round(x,4) for x in df.defender_utility])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "1b82eac4-ac51-447c-994c-faaae3e2d5cc",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.0015561490931141526"
      ]
     },
     "execution_count": 14,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "stats.sem([round(x,4) for x in df.defender_utility])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "87a94d4b-a614-420c-a479-93f04cded0d6",
   "metadata": {},
   "outputs": [],
   "source": [
    "df.to_csv(\"ISG_NFG_SSE_RANDOM_TARGET_VALUES.csv\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "1386a043-5dff-44df-b122-f011f4ad9c34",
   "metadata": {},
   "source": [
    "# Random target vals and schedules"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ee957b97-2f07-4a0a-937d-62a9b76294f0",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "starting seed: 1\n",
      "starting seed: 2\n",
      "starting seed: 3\n",
      "starting seed: 4\n",
      "starting seed: 5\n",
      "starting seed: 6\n",
      "starting seed: 7\n",
      "starting seed: 8\n",
      "starting seed: 9\n",
      "starting seed: 10\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\": True,\n",
    "    \"attacker_feature_value\":  1, \n",
    "    \"defender_feature_value\": 100, \n",
    "    \"defender_step_cost\": 1,\n",
    "    \"alpha\":.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",
    "supports=[]\n",
    "dts = []\n",
    "\n",
    "dus = []\n",
    "runtimes = []\n",
    "\n",
    "isg = InfraSecurityGame(df_combined, ny_blocks_gdf, INFRA_WEIGHTS, bbox=bbox_downtown_large)\n",
    "isg.generate(num_attackers=1, \n",
    "             num_defenders=3, \n",
    "             home_base_assignments=[(fifth_precinct,booking_station, troop_nyc, first_precinct, police_plaza),(fifth_precinct,booking_station, troop_nyc, first_precinct, police_plaza),(fifth_precinct,booking_station, troop_nyc, first_precinct, police_plaza)], \n",
    "             num_timesteps=8, \n",
    "             generate_utility_matrix=False, \n",
    "             random_target_values=False,\n",
    "             randomize_target_utility_matrix=False,\n",
    "             generate_actions=False, \n",
    "             force_return=True, \n",
    "             defense_time_threshold=1, \n",
    "             **schedule_form_kwargs,\n",
    "             **general_sum_kwargs, \n",
    "            )\n",
    "\n",
    "# for seed in seeds:\n",
    "#     print(f\"starting seed: {seed}\")\n",
    "#     np.random.seed(seed)\n",
    "    \n",
    "#     print(isg.schedule_form_dict[\"target_utilities\"])\n",
    "#     start = time.time()\n",
    "#     _, coverage, du = solve_general_sum_normal_form(isg.schedule_form_dict[\"defender_utility_matrix\"],isg.schedule_form_dict[\"attacker_utility_matrix\"])\n",
    "#     end=time.time()\n",
    "\n",
    "#     support = sum([1 for t,p in coverage.items() if p!=0])\n",
    "#     dus.append(du)\n",
    "#     runtimes.append(end-start)\n",
    "#     supports.append(support)\n",
    "\n",
    "for seed in seeds:\n",
    "    print(f\"starting seed: {seed}\")\n",
    "    np.random.seed(seed)\n",
    "    random_schedules = generate_random_schedule_mapping_like(isg.schedule_form_dict[\"schedules\"],86)\n",
    "    defender_actions, defender_costs = generate_defender_actions_with_costs(random_schedules)\n",
    "    attacker_actions = [0,1,2,3,4,5,6,7,8,9]\n",
    "    random_target_utilities = generate_random_target_utility_matrix_like_v2(isg.schedule_form_dict[\"target_utilities\"], general_sum=True, respect_sign_roles=True)\n",
    "    attacker_matrix, defender_matrix = generate_schedule_game_matrix(attacker_actions, defender_actions, defender_costs, random_target_utilities, general_sum=True)\n",
    "    start = time.time()\n",
    "    _, coverage, du = solve_general_sum_normal_form(defender_matrix,attacker_matrix)\n",
    "    end=time.time()\n",
    "\n",
    "    support = sum([1 for t,p in coverage.items() if p!=0])\n",
    "    dus.append(du)\n",
    "    runtimes.append(end-start)\n",
    "    supports.append(support)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "c6eb905e-d4ab-4794-aa2a-e7f1aabb62bf",
   "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>seed</th>\n",
       "      <th>num_timesteps</th>\n",
       "      <th>num_defenders</th>\n",
       "      <th>defense_time_threshold</th>\n",
       "      <th>defender_utility</th>\n",
       "      <th>support</th>\n",
       "      <th>runtime</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>1</td>\n",
       "      <td>8</td>\n",
       "      <td>3</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.028684</td>\n",
       "      <td>1</td>\n",
       "      <td>1.514182</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>2</td>\n",
       "      <td>8</td>\n",
       "      <td>3</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.031275</td>\n",
       "      <td>1</td>\n",
       "      <td>1.626506</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>3</td>\n",
       "      <td>8</td>\n",
       "      <td>3</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.038951</td>\n",
       "      <td>1</td>\n",
       "      <td>1.443529</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>4</td>\n",
       "      <td>8</td>\n",
       "      <td>3</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.021896</td>\n",
       "      <td>1</td>\n",
       "      <td>1.630756</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>5</td>\n",
       "      <td>8</td>\n",
       "      <td>3</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.025304</td>\n",
       "      <td>1</td>\n",
       "      <td>1.670459</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>6</td>\n",
       "      <td>8</td>\n",
       "      <td>3</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.055399</td>\n",
       "      <td>1</td>\n",
       "      <td>1.541387</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>7</td>\n",
       "      <td>8</td>\n",
       "      <td>3</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.022354</td>\n",
       "      <td>1</td>\n",
       "      <td>1.698927</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>8</td>\n",
       "      <td>8</td>\n",
       "      <td>3</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.030878</td>\n",
       "      <td>1</td>\n",
       "      <td>1.776669</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>9</td>\n",
       "      <td>8</td>\n",
       "      <td>3</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.026281</td>\n",
       "      <td>1</td>\n",
       "      <td>1.302374</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>10</td>\n",
       "      <td>8</td>\n",
       "      <td>3</td>\n",
       "      <td>1</td>\n",
       "      <td>-0.033919</td>\n",
       "      <td>1</td>\n",
       "      <td>1.534827</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   seed  num_timesteps  num_defenders  defense_time_threshold  \\\n",
       "0     1              8              3                       1   \n",
       "1     2              8              3                       1   \n",
       "2     3              8              3                       1   \n",
       "3     4              8              3                       1   \n",
       "4     5              8              3                       1   \n",
       "5     6              8              3                       1   \n",
       "6     7              8              3                       1   \n",
       "7     8              8              3                       1   \n",
       "8     9              8              3                       1   \n",
       "9    10              8              3                       1   \n",
       "\n",
       "   defender_utility  support   runtime  \n",
       "0         -0.028684        1  1.514182  \n",
       "1         -0.031275        1  1.626506  \n",
       "2         -0.038951        1  1.443529  \n",
       "3         -0.021896        1  1.630756  \n",
       "4         -0.025304        1  1.670459  \n",
       "5         -0.055399        1  1.541387  \n",
       "6         -0.022354        1  1.698927  \n",
       "7         -0.030878        1  1.776669  \n",
       "8         -0.026281        1  1.302374  \n",
       "9         -0.033919        1  1.534827  "
      ]
     },
     "execution_count": 16,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df = pd.DataFrame()\n",
    "df[\"seed\"] = seeds\n",
    "df[\"num_timesteps\"] = [8 for i in range(len(seeds))]\n",
    "df[\"num_defenders\"] = [3 for i in range(len(seeds))]\n",
    "df[\"defense_time_threshold\"] = [1 for i in range(len(seeds))]\n",
    "df[\"defender_utility\"] = dus\n",
    "df[\"support\"] = supports\n",
    "df[\"runtime\"] = runtimes\n",
    "df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "efaac283-332f-4554-8b52-3dc0d5520953",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "1.0"
      ]
     },
     "execution_count": 17,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.mean([round(x,4) for x in df.support])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "a5a13215-84ef-4af2-8cf1-366889b5856f",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.0"
      ]
     },
     "execution_count": 18,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "stats.sem([round(x,4) for x in df.support])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "a7d81e69-bead-49c0-9340-ec884ab2993c",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "1.57397"
      ]
     },
     "execution_count": 19,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.mean([round(x,4) for x in df.runtime])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "56333dca-5c88-4acf-9a1b-c727978f0281",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.04332747152660641"
      ]
     },
     "execution_count": 20,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "stats.sem([round(x,4) for x in df.runtime])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "96e5f03d-45bb-4489-afbc-8de0129b6a0a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "-0.031509999999999996"
      ]
     },
     "execution_count": 21,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.mean([round(x,4) for x in df.defender_utility])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "3c9a1739-1cf5-4717-94d7-0a52b20f5e85",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.0031303336705356005"
      ]
     },
     "execution_count": 22,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "stats.sem([round(x,4) for x in df.defender_utility])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "e7902d70-ad23-4d0c-b738-bc9384b25922",
   "metadata": {},
   "outputs": [],
   "source": [
    "df.to_csv(\"ISG_NFG_SSE_RANDOM_SCHEDULES_AND_TARGET_VALUES.csv\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "1c84b0d2-752e-48f6-90e9-36da761d6436",
   "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>id</th>\n",
       "      <th>name</th>\n",
       "      <th>type</th>\n",
       "      <th>x</th>\n",
       "      <th>y</th>\n",
       "      <th>population</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>node/357579732</td>\n",
       "      <td>Public School 23</td>\n",
       "      <td>school</td>\n",
       "      <td>-73.998750</td>\n",
       "      <td>40.716214</td>\n",
       "      <td>419.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>node/357610557</td>\n",
       "      <td>Public School 124</td>\n",
       "      <td>school</td>\n",
       "      <td>-73.997500</td>\n",
       "      <td>40.714444</td>\n",
       "      <td>92.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>node/357621626</td>\n",
       "      <td>Public School 130</td>\n",
       "      <td>school</td>\n",
       "      <td>-73.998489</td>\n",
       "      <td>40.718536</td>\n",
       "      <td>376.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>node/368045750</td>\n",
       "      <td>New York City Criminal Courts Building</td>\n",
       "      <td>courthouse</td>\n",
       "      <td>-74.000806</td>\n",
       "      <td>40.715986</td>\n",
       "      <td>173.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>node/368045773</td>\n",
       "      <td>New York City Supreme Court</td>\n",
       "      <td>courthouse</td>\n",
       "      <td>-74.007640</td>\n",
       "      <td>40.717324</td>\n",
       "      <td>0.0</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",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>59</th>\n",
       "      <td>way/891074473</td>\n",
       "      <td>Pace University</td>\n",
       "      <td>university</td>\n",
       "      <td>-74.004840</td>\n",
       "      <td>40.711193</td>\n",
       "      <td>340.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>60</th>\n",
       "      <td>way/1082129088</td>\n",
       "      <td>None</td>\n",
       "      <td>solar_generator</td>\n",
       "      <td>-73.994953</td>\n",
       "      <td>40.712414</td>\n",
       "      <td>1443.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>61</th>\n",
       "      <td>way/1365373854</td>\n",
       "      <td>Stuyvesant High School</td>\n",
       "      <td>school</td>\n",
       "      <td>-74.013826</td>\n",
       "      <td>40.718015</td>\n",
       "      <td>753.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>62</th>\n",
       "      <td>way/1157729510</td>\n",
       "      <td>Weill Medical College of Cornell University</td>\n",
       "      <td>university</td>\n",
       "      <td>-74.004956</td>\n",
       "      <td>40.710307</td>\n",
       "      <td>16.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>63</th>\n",
       "      <td>way/1221207875</td>\n",
       "      <td>Hudson - Farragut</td>\n",
       "      <td>cable</td>\n",
       "      <td>-74.028076</td>\n",
       "      <td>40.726900</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>64 rows × 6 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "                id                                         name  \\\n",
       "0   node/357579732                             Public School 23   \n",
       "1   node/357610557                            Public School 124   \n",
       "2   node/357621626                            Public School 130   \n",
       "3   node/368045750       New York City Criminal Courts Building   \n",
       "4   node/368045773                  New York City Supreme Court   \n",
       "..             ...                                          ...   \n",
       "59   way/891074473                              Pace University   \n",
       "60  way/1082129088                                         None   \n",
       "61  way/1365373854                       Stuyvesant High School   \n",
       "62  way/1157729510  Weill Medical College of Cornell University   \n",
       "63  way/1221207875                            Hudson - Farragut   \n",
       "\n",
       "               type          x          y  population  \n",
       "0            school -73.998750  40.716214       419.0  \n",
       "1            school -73.997500  40.714444        92.0  \n",
       "2            school -73.998489  40.718536       376.0  \n",
       "3        courthouse -74.000806  40.715986       173.0  \n",
       "4        courthouse -74.007640  40.717324         0.0  \n",
       "..              ...        ...        ...         ...  \n",
       "59       university -74.004840  40.711193       340.0  \n",
       "60  solar_generator -73.994953  40.712414      1443.0  \n",
       "61           school -74.013826  40.718015       753.0  \n",
       "62       university -74.004956  40.710307        16.0  \n",
       "63            cable -74.028076  40.726900         NaN  \n",
       "\n",
       "[64 rows x 6 columns]"
      ]
     },
     "execution_count": 27,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_combined"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "812b5833-fb84-40f2-b667-6dd5d3824934",
   "metadata": {},
   "outputs": [],
   "source": [
    "gdf = None"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "e58e4810-6cfb-43a6-bacd-894928ed3401",
   "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>id</th>\n",
       "      <th>@id</th>\n",
       "      <th>NY_mta:propcode</th>\n",
       "      <th>access</th>\n",
       "      <th>addr:city</th>\n",
       "      <th>addr:country</th>\n",
       "      <th>addr:flats</th>\n",
       "      <th>addr:floor</th>\n",
       "      <th>addr:housename</th>\n",
       "      <th>addr:housenumber</th>\n",
       "      <th>...</th>\n",
       "      <th>website:en</th>\n",
       "      <th>website_archive</th>\n",
       "      <th>wheelchair</th>\n",
       "      <th>wikidata</th>\n",
       "      <th>wikimedia_commons</th>\n",
       "      <th>wikipedia</th>\n",
       "      <th>@relations</th>\n",
       "      <th>wires</th>\n",
       "      <th>year_of_construction</th>\n",
       "      <th>geometry</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>relation/3105305</td>\n",
       "      <td>relation/3105305</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>...</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>Q1048851</td>\n",
       "      <td>None</td>\n",
       "      <td>en:Yeshiva University</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>MULTIPOLYGON (((-73.92917 40.85230, -73.92894 ...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>relation/3262857</td>\n",
       "      <td>relation/3262857</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>...</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>POLYGON ((-73.98941 40.68964, -73.98944 40.689...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>relation/3262986</td>\n",
       "      <td>relation/3262986</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>Brooklyn</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>301</td>\n",
       "      <td>...</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>Q5440041</td>\n",
       "      <td>None</td>\n",
       "      <td>en:Federal Building and Post Office (Brooklyn)</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>POLYGON ((-73.98910 40.69548, -73.98910 40.695...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>relation/3336423</td>\n",
       "      <td>relation/3336423</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>5404</td>\n",
       "      <td>...</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>POLYGON ((-73.92524 40.64756, -73.92532 40.648...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>relation/3351361</td>\n",
       "      <td>relation/3351361</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>...</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>POLYGON ((-73.99197 40.63115, -73.99203 40.631...</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",
       "      <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>23602</th>\n",
       "      <td>node/12736543648</td>\n",
       "      <td>node/12736543648</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>Newark</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>189</td>\n",
       "      <td>...</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>POINT (-74.17123 40.73550)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>23603</th>\n",
       "      <td>node/12754254335</td>\n",
       "      <td>node/12754254335</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>...</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>POINT (-74.12037 40.74476)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>23604</th>\n",
       "      <td>node/12754254336</td>\n",
       "      <td>node/12754254336</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>...</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>POINT (-74.12048 40.74485)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>23605</th>\n",
       "      <td>node/12762992538</td>\n",
       "      <td>node/12762992538</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>Bronx</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>1118</td>\n",
       "      <td>...</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>yes</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>POINT (-73.91899 40.83230)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>23606</th>\n",
       "      <td>node/12766117165</td>\n",
       "      <td>node/12766117165</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>...</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "      <td>POINT (-74.01171 40.65558)</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>23607 rows × 305 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "                     id               @id NY_mta:propcode access addr:city  \\\n",
       "0      relation/3105305  relation/3105305            None   None      None   \n",
       "1      relation/3262857  relation/3262857            None   None      None   \n",
       "2      relation/3262986  relation/3262986            None   None  Brooklyn   \n",
       "3      relation/3336423  relation/3336423            None   None      None   \n",
       "4      relation/3351361  relation/3351361            None   None      None   \n",
       "...                 ...               ...             ...    ...       ...   \n",
       "23602  node/12736543648  node/12736543648            None   None    Newark   \n",
       "23603  node/12754254335  node/12754254335            None   None      None   \n",
       "23604  node/12754254336  node/12754254336            None   None      None   \n",
       "23605  node/12762992538  node/12762992538            None   None     Bronx   \n",
       "23606  node/12766117165  node/12766117165            None   None      None   \n",
       "\n",
       "      addr:country addr:flats addr:floor addr:housename addr:housenumber  ...  \\\n",
       "0             None       None       None           None             None  ...   \n",
       "1             None       None       None           None             None  ...   \n",
       "2             None       None       None           None              301  ...   \n",
       "3             None       None       None           None             5404  ...   \n",
       "4             None       None       None           None             None  ...   \n",
       "...            ...        ...        ...            ...              ...  ...   \n",
       "23602         None       None       None           None              189  ...   \n",
       "23603         None       None       None           None             None  ...   \n",
       "23604         None       None       None           None             None  ...   \n",
       "23605         None       None       None           None             1118  ...   \n",
       "23606         None       None       None           None             None  ...   \n",
       "\n",
       "      website:en website_archive wheelchair  wikidata wikimedia_commons  \\\n",
       "0           None            None       None  Q1048851              None   \n",
       "1           None            None       None      None              None   \n",
       "2           None            None       None  Q5440041              None   \n",
       "3           None            None       None      None              None   \n",
       "4           None            None       None      None              None   \n",
       "...          ...             ...        ...       ...               ...   \n",
       "23602       None            None       None      None              None   \n",
       "23603       None            None       None      None              None   \n",
       "23604       None            None       None      None              None   \n",
       "23605       None            None        yes      None              None   \n",
       "23606       None            None       None      None              None   \n",
       "\n",
       "                                            wikipedia @relations wires  \\\n",
       "0                               en:Yeshiva University       None  None   \n",
       "1                                                None       None  None   \n",
       "2      en:Federal Building and Post Office (Brooklyn)       None  None   \n",
       "3                                                None       None  None   \n",
       "4                                                None       None  None   \n",
       "...                                               ...        ...   ...   \n",
       "23602                                            None       None  None   \n",
       "23603                                            None       None  None   \n",
       "23604                                            None       None  None   \n",
       "23605                                            None       None  None   \n",
       "23606                                            None       None  None   \n",
       "\n",
       "      year_of_construction                                           geometry  \n",
       "0                     None  MULTIPOLYGON (((-73.92917 40.85230, -73.92894 ...  \n",
       "1                     None  POLYGON ((-73.98941 40.68964, -73.98944 40.689...  \n",
       "2                     None  POLYGON ((-73.98910 40.69548, -73.98910 40.695...  \n",
       "3                     None  POLYGON ((-73.92524 40.64756, -73.92532 40.648...  \n",
       "4                     None  POLYGON ((-73.99197 40.63115, -73.99203 40.631...  \n",
       "...                    ...                                                ...  \n",
       "23602                 None                         POINT (-74.17123 40.73550)  \n",
       "23603                 None                         POINT (-74.12037 40.74476)  \n",
       "23604                 None                         POINT (-74.12048 40.74485)  \n",
       "23605                 None                         POINT (-73.91899 40.83230)  \n",
       "23606                 None                         POINT (-74.01171 40.65558)  \n",
       "\n",
       "[23607 rows x 305 columns]"
      ]
     },
     "execution_count": 29,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "gdf"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cedcf342-2336-498f-b5a7-cd549777be0e",
   "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
}
