{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "d48825af-9f6a-4108-8198-ba7fb36cd39e",
   "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",
    "\n",
    "from utils.random_utils import generate_random_utility_matrix_like, generate_random_target_utility_matrix_like, generate_random_schedule_mapping_like\n",
    "\n",
    "import time\n",
    "from matplotlib import pyplot as plt\n",
    "from collections import defaultdict, Counter"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "b22bb265-32db-4e90-b833-5f43ca056465",
   "metadata": {},
   "outputs": [],
   "source": [
    "seeds = [1,2,3,4,5,6,7,8,9,10]"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "6de6ec39-621b-47c6-92c9-2d00070519b3",
   "metadata": {},
   "source": [
    "# GSG"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "967b76b6-93ec-440e-b67d-5aa9582816f9",
   "metadata": {},
   "source": [
    "## NFG"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "74564a76-0afc-46a8-ab98-f247e3a13d9d",
   "metadata": {},
   "outputs": [],
   "source": [
    "df = pd.read_csv(\"lobeke.csv\")\n",
    "df.dropna(inplace=True)\n",
    "\n",
    "lat_min, lon_min = 2.0530, 15.8790\n",
    "lat_max, lon_max = 2.2837, 16.2038\n",
    "\n",
    "coordinate_rectangle = [lat_min, lat_max, lon_min, lon_max]\n",
    "\n",
    "schedule_form_kwargs = {\n",
    "    \"schedule_form\": False,\n",
    "    \"simple\": False,\n",
    "    \"attacker_penalty_factor\": 5,\n",
    "    \"defender_penalty_factor\": 5,\n",
    "}\n",
    "\n",
    "general_sum_kwargs = {\n",
    "    \"general_sum\": False,\n",
    "    \"attacker_feature_value\":  42, \n",
    "    \"defender_feature_value\": 69, \n",
    "    \"defender_step_cost\": 32.5, \n",
    "}\n",
    "\n",
    "boulou_camp = (2.2,15.9)\n",
    "# lobeke_camp = (2.25,15.75)\n",
    "kabo_djembe = (2.0532352380408088, 16.085709866529694)\n",
    "bomassa = (2.2037280296158355, 16.187056364164913)\n",
    "inner_post = (2.2,15.98)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "47cc8ed6-1759-4d8b-88d6-b8f64ddcf212",
   "metadata": {},
   "outputs": [],
   "source": [
    "gsg = GreenSecurityGame(df, coordinate_rectangle, \"centroid\", num_clusters=10, num_rows=7, num_columns=7)\n",
    "gsg.generate(num_attackers=1, \n",
    "             num_defenders=1, \n",
    "             home_base_assignments=[(kabo_djembe, bomassa, inner_post)], \n",
    "             num_timesteps=8, \n",
    "             generate_utility_matrix=True, \n",
    "             defense_time_threshold=1, \n",
    "             generate_actions=False, \n",
    "             force_return=False, \n",
    "             general_sum=False, \n",
    "             **schedule_form_kwargs)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "9b3f86b4-fc56-490b-bfdd-5ff82d0e7300",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(9075, 11)"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "gsg.utility_matrix.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "f1a3b4e8-baa2-4526-9886-f4704665ee09",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "starting seed 1\n",
      "Set parameter WLSAccessID\n",
      "Set parameter WLSSecret\n",
      "Set parameter LicenseID to value 2455389\n",
      "Academic license 2455389 - for non-commercial use only - registered to jc___@columbia.edu\n",
      "11 -0.227270952250271\n",
      "starting i=1 at time 1747361495.6637871\n",
      "finished i=1 in 7.759728670120239 seconds with u=-0.4082772904959904\n",
      "starting i=2 at time 1747361503.4245207\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[8], line 29\u001b[0m\n\u001b[0;32m     27\u001b[0m start \u001b[38;5;241m=\u001b[39m time\u001b[38;5;241m.\u001b[39mtime()\n\u001b[0;32m     28\u001b[0m \u001b[38;5;28mprint\u001b[39m(\u001b[38;5;124mf\u001b[39m\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mstarting i=\u001b[39m\u001b[38;5;132;01m{\u001b[39;00mi\u001b[38;5;132;01m}\u001b[39;00m\u001b[38;5;124m at time \u001b[39m\u001b[38;5;132;01m{\u001b[39;00mstart\u001b[38;5;132;01m}\u001b[39;00m\u001b[38;5;124m\"\u001b[39m)\n\u001b[1;32m---> 29\u001b[0m mu, mD_d \u001b[38;5;241m=\u001b[39m \u001b[43mmip\u001b[49m\u001b[43m(\u001b[49m\u001b[43mrandom_matrix\u001b[49m\u001b[43m,\u001b[49m\u001b[43mi\u001b[49m\u001b[43m)\u001b[49m\n\u001b[0;32m     30\u001b[0m end \u001b[38;5;241m=\u001b[39m time\u001b[38;5;241m.\u001b[39mtime()\n\u001b[0;32m     31\u001b[0m \u001b[38;5;28mprint\u001b[39m(\u001b[38;5;124mf\u001b[39m\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mfinished i=\u001b[39m\u001b[38;5;132;01m{\u001b[39;00mi\u001b[38;5;132;01m}\u001b[39;00m\u001b[38;5;124m in \u001b[39m\u001b[38;5;132;01m{\u001b[39;00mend\u001b[38;5;241m-\u001b[39mstart\u001b[38;5;132;01m}\u001b[39;00m\u001b[38;5;124m seconds with u=\u001b[39m\u001b[38;5;132;01m{\u001b[39;00mmu\u001b[38;5;132;01m}\u001b[39;00m\u001b[38;5;124m\"\u001b[39m)\n",
      "File \u001b[1;32m~\\GameGenerators\\notebooks\\..\\solvers\\mip.py:45\u001b[0m, in \u001b[0;36mmip\u001b[1;34m(utility_matrix, support_bound)\u001b[0m\n\u001b[0;32m     42\u001b[0m m\u001b[38;5;241m.\u001b[39maddConstr(\u001b[38;5;28msum\u001b[39m(x) \u001b[38;5;241m==\u001b[39m \u001b[38;5;241m1\u001b[39m, \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mprob_dist\u001b[39m\u001b[38;5;124m\"\u001b[39m)\n\u001b[0;32m     43\u001b[0m m\u001b[38;5;241m.\u001b[39maddConstr(\u001b[38;5;28msum\u001b[39m(indicator_x) \u001b[38;5;241m<\u001b[39m\u001b[38;5;241m=\u001b[39m support_bound, \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124msupport_bound\u001b[39m\u001b[38;5;124m\"\u001b[39m)\n\u001b[1;32m---> 45\u001b[0m \u001b[43mm\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43moptimize\u001b[49m\u001b[43m(\u001b[49m\u001b[43m)\u001b[49m\n\u001b[0;32m     47\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m m\u001b[38;5;241m.\u001b[39mStatus \u001b[38;5;241m!=\u001b[39m GRB\u001b[38;5;241m.\u001b[39mOPTIMAL:\n\u001b[0;32m     48\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[38;5;28;01mNone\u001b[39;00m, \u001b[38;5;28;01mNone\u001b[39;00m\n",
      "\u001b[1;31mKeyboardInterrupt\u001b[0m: "
     ]
    }
   ],
   "source": [
    "nruntimes = []\n",
    "nsupports = []\n",
    "nus = []\n",
    "mip_us_per_seed = []\n",
    "mip_supports_per_seed = []\n",
    "mip_runtimes_per_seed = []\n",
    "\n",
    "for seed in seeds:\n",
    "    print(f\"starting seed {seed}\")\n",
    "    np.random.seed(seed)\n",
    "    random_matrix = generate_random_utility_matrix_like(gsg.utility_matrix)\n",
    "    start = time.time()\n",
    "    nD_a, nD_d, nu = nash(random_matrix)\n",
    "    end = time.time()\n",
    "    nruntime = end-start\n",
    "    nsupport = sum([1 for p in nD_d if p!=0])\n",
    "    nus.append(nu)\n",
    "    print(nsupport,nu)\n",
    "    nruntimes.append(nruntime)\n",
    "    nsupports.append(nsupport)\n",
    "    \n",
    "    mip_us = []\n",
    "    mip_supports = []\n",
    "    mip_runtimes = []\n",
    "    \n",
    "    for i in range(1,60):\n",
    "        start = time.time()\n",
    "        print(f\"starting i={i} at time {start}\")\n",
    "        mu, mD_d = mip(random_matrix,i)\n",
    "        end = time.time()\n",
    "        print(f\"finished i={i} in {end-start} seconds with u={mu}\")\n",
    "        msupport = sum([1 for p in mD_d if p!=0])\n",
    "        mip_us.append(mu)\n",
    "        mip_supports.append(i)\n",
    "        mip_runtimes.append(end-start)\n",
    "        if abs(mu-nu) <= 1e-12:\n",
    "            mip_us_per_seed.append(mip_us)\n",
    "            mip_supports_per_seed.append(mip_supports)\n",
    "            mip_runtimes_per_seed.append(mip_runtimes)\n",
    "            break"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "f17d7198-c2c2-432a-94f6-daa995faf692",
   "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_attackers</th>\n",
       "      <th>num_defenders</th>\n",
       "      <th>num_clusters</th>\n",
       "      <th>dims</th>\n",
       "      <th>defense_time_threshold</th>\n",
       "      <th>force_return</th>\n",
       "      <th>num_defender_actions</th>\n",
       "      <th>nash_value</th>\n",
       "      <th>nash_support</th>\n",
       "      <th>nash_runtime</th>\n",
       "      <th>mip_value</th>\n",
       "      <th>mip_support</th>\n",
       "      <th>mip_runtime</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>1</td>\n",
       "      <td>9</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>10</td>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>False</td>\n",
       "      <td>41479</td>\n",
       "      <td>-0.187592</td>\n",
       "      <td>11</td>\n",
       "      <td>3.220002</td>\n",
       "      <td>[-0.33049861334842967, -0.21206488911779517, -...</td>\n",
       "      <td>[1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11]</td>\n",
       "      <td>[32.253100633621216, 34.95654082298279, 263.79...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>2</td>\n",
       "      <td>9</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>10</td>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>False</td>\n",
       "      <td>41479</td>\n",
       "      <td>-0.198526</td>\n",
       "      <td>11</td>\n",
       "      <td>3.397532</td>\n",
       "      <td>[-0.4201333011262066, -0.2679993774682173, -0....</td>\n",
       "      <td>[1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11]</td>\n",
       "      <td>[25.359724283218384, 757.6126692295074, 120.91...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>3</td>\n",
       "      <td>9</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>10</td>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>False</td>\n",
       "      <td>41479</td>\n",
       "      <td>-0.191004</td>\n",
       "      <td>11</td>\n",
       "      <td>3.038714</td>\n",
       "      <td>[-0.3475327050726812, -0.2580880780591269, -0....</td>\n",
       "      <td>[1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11]</td>\n",
       "      <td>[30.28805661201477, 4684.116407871246, 245.474...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>4</td>\n",
       "      <td>9</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>10</td>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>False</td>\n",
       "      <td>41479</td>\n",
       "      <td>-0.187622</td>\n",
       "      <td>11</td>\n",
       "      <td>2.983597</td>\n",
       "      <td>[-0.38593971907107893, -0.26684074604678143, -...</td>\n",
       "      <td>[1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11]</td>\n",
       "      <td>[56.12270784378052, 878.412425994873, 67.96332...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>5</td>\n",
       "      <td>9</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>10</td>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>False</td>\n",
       "      <td>41479</td>\n",
       "      <td>-0.176030</td>\n",
       "      <td>10</td>\n",
       "      <td>2.995340</td>\n",
       "      <td>[-0.2906412128056464, -0.21102580904812476, -0...</td>\n",
       "      <td>[1, 2, 3, 4, 5, 6, 7, 8, 9, 10]</td>\n",
       "      <td>[12.671159029006958, 741.9412114620209, 109.17...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>6</td>\n",
       "      <td>9</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>10</td>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>False</td>\n",
       "      <td>41479</td>\n",
       "      <td>-0.176390</td>\n",
       "      <td>11</td>\n",
       "      <td>3.037144</td>\n",
       "      <td>[-0.33458244851934105, -0.22352023104467122, -...</td>\n",
       "      <td>[1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11]</td>\n",
       "      <td>[23.87569284439087, 534.5615437030792, 49.8034...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>7</td>\n",
       "      <td>9</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>10</td>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>False</td>\n",
       "      <td>41479</td>\n",
       "      <td>-0.180118</td>\n",
       "      <td>11</td>\n",
       "      <td>3.040523</td>\n",
       "      <td>[-0.3367153020684932, -0.22492398547957598, -0...</td>\n",
       "      <td>[1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11]</td>\n",
       "      <td>[23.55077338218689, 1304.2784504890442, 294.91...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>8</td>\n",
       "      <td>9</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>10</td>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>False</td>\n",
       "      <td>41479</td>\n",
       "      <td>-0.203662</td>\n",
       "      <td>11</td>\n",
       "      <td>3.031541</td>\n",
       "      <td>[-0.3847404347260328, -0.25670419923314197, -0...</td>\n",
       "      <td>[1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11]</td>\n",
       "      <td>[54.090611934661865, 708.6245937347412, 428.12...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>9</td>\n",
       "      <td>9</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>10</td>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>False</td>\n",
       "      <td>41479</td>\n",
       "      <td>-0.196674</td>\n",
       "      <td>11</td>\n",
       "      <td>3.044220</td>\n",
       "      <td>[-0.43179747045488504, -0.27416749950096725, -...</td>\n",
       "      <td>[1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11]</td>\n",
       "      <td>[1393.2623889446259, 2182.9206199645996, 243.2...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>10</td>\n",
       "      <td>9</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>10</td>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>False</td>\n",
       "      <td>41479</td>\n",
       "      <td>-0.195059</td>\n",
       "      <td>11</td>\n",
       "      <td>3.066049</td>\n",
       "      <td>[-0.34436445322944637, -0.24031442702318015, -...</td>\n",
       "      <td>[1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11]</td>\n",
       "      <td>[29.169074296951294, 1596.7552001476288, 367.2...</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   seed  num_timesteps  num_attackers  num_defenders  num_clusters  dims  \\\n",
       "0     1              9              1              1            10     7   \n",
       "1     2              9              1              1            10     7   \n",
       "2     3              9              1              1            10     7   \n",
       "3     4              9              1              1            10     7   \n",
       "4     5              9              1              1            10     7   \n",
       "5     6              9              1              1            10     7   \n",
       "6     7              9              1              1            10     7   \n",
       "7     8              9              1              1            10     7   \n",
       "8     9              9              1              1            10     7   \n",
       "9    10              9              1              1            10     7   \n",
       "\n",
       "   defense_time_threshold  force_return  num_defender_actions  nash_value  \\\n",
       "0                       1         False                 41479   -0.187592   \n",
       "1                       1         False                 41479   -0.198526   \n",
       "2                       1         False                 41479   -0.191004   \n",
       "3                       1         False                 41479   -0.187622   \n",
       "4                       1         False                 41479   -0.176030   \n",
       "5                       1         False                 41479   -0.176390   \n",
       "6                       1         False                 41479   -0.180118   \n",
       "7                       1         False                 41479   -0.203662   \n",
       "8                       1         False                 41479   -0.196674   \n",
       "9                       1         False                 41479   -0.195059   \n",
       "\n",
       "   nash_support  nash_runtime  \\\n",
       "0            11      3.220002   \n",
       "1            11      3.397532   \n",
       "2            11      3.038714   \n",
       "3            11      2.983597   \n",
       "4            10      2.995340   \n",
       "5            11      3.037144   \n",
       "6            11      3.040523   \n",
       "7            11      3.031541   \n",
       "8            11      3.044220   \n",
       "9            11      3.066049   \n",
       "\n",
       "                                           mip_value  \\\n",
       "0  [-0.33049861334842967, -0.21206488911779517, -...   \n",
       "1  [-0.4201333011262066, -0.2679993774682173, -0....   \n",
       "2  [-0.3475327050726812, -0.2580880780591269, -0....   \n",
       "3  [-0.38593971907107893, -0.26684074604678143, -...   \n",
       "4  [-0.2906412128056464, -0.21102580904812476, -0...   \n",
       "5  [-0.33458244851934105, -0.22352023104467122, -...   \n",
       "6  [-0.3367153020684932, -0.22492398547957598, -0...   \n",
       "7  [-0.3847404347260328, -0.25670419923314197, -0...   \n",
       "8  [-0.43179747045488504, -0.27416749950096725, -...   \n",
       "9  [-0.34436445322944637, -0.24031442702318015, -...   \n",
       "\n",
       "                           mip_support  \\\n",
       "0  [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11]   \n",
       "1  [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11]   \n",
       "2  [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11]   \n",
       "3  [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11]   \n",
       "4      [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]   \n",
       "5  [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11]   \n",
       "6  [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11]   \n",
       "7  [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11]   \n",
       "8  [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11]   \n",
       "9  [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11]   \n",
       "\n",
       "                                         mip_runtime  \n",
       "0  [32.253100633621216, 34.95654082298279, 263.79...  \n",
       "1  [25.359724283218384, 757.6126692295074, 120.91...  \n",
       "2  [30.28805661201477, 4684.116407871246, 245.474...  \n",
       "3  [56.12270784378052, 878.412425994873, 67.96332...  \n",
       "4  [12.671159029006958, 741.9412114620209, 109.17...  \n",
       "5  [23.87569284439087, 534.5615437030792, 49.8034...  \n",
       "6  [23.55077338218689, 1304.2784504890442, 294.91...  \n",
       "7  [54.090611934661865, 708.6245937347412, 428.12...  \n",
       "8  [1393.2623889446259, 2182.9206199645996, 243.2...  \n",
       "9  [29.169074296951294, 1596.7552001476288, 367.2...  "
      ]
     },
     "execution_count": 20,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df = pd.DataFrame({\n",
    "    \"seed\":seeds,\n",
    "    \"num_timesteps\":[9 for i in range(len(seeds))],\n",
    "    \"num_attackers\":[1 for i in range(len(seeds))],\n",
    "    \"num_defenders\":[1 for i in range(len(seeds))],\n",
    "    \"num_clusters\":[10 for i in range(len(seeds))],\n",
    "    \"dims\":[7 for i in range(len(seeds))],\n",
    "    \"defense_time_threshold\":[1 for i in range(len(seeds))],\n",
    "    \"force_return\":[False for i in range(len(seeds))],\n",
    "    \"num_defender_actions\": [len(gsg.defender_actions) for i in range(len(seeds))],\n",
    "    \"nash_value\":nus,\n",
    "    \"nash_support\":nsupports,\n",
    "    \"nash_runtime\":nruntimes,\n",
    "    \"mip_value\":mip_us_per_seed,\n",
    "    \"mip_support\":mip_supports_per_seed,\n",
    "    \"mip_runtime\":mip_runtimes_per_seed,\n",
    "})\n",
    "df\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "37f997b1-4d1a-42af-b8db-d438ac280b32",
   "metadata": {},
   "outputs": [],
   "source": [
    "df.to_csv(\"GSG_NFG_T9_1D1A_SPARSITY_RANDOM_MATRIX.csv\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "3098669b-4220-4550-a191-48216e5c1007",
   "metadata": {},
   "source": [
    "### SF"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "a4a9b3d4-d591-4734-8e3d-8fd8325f1211",
   "metadata": {},
   "outputs": [],
   "source": [
    "df = pd.read_csv(\"lobeke.csv\")\n",
    "df.dropna(inplace=True)\n",
    "\n",
    "lat_min, lon_min = 2.0530, 15.8790\n",
    "lat_max, lon_max = 2.2837, 16.2038\n",
    "\n",
    "coordinate_rectangle = [lat_min, lat_max, lon_min, lon_max]\n",
    "\n",
    "schedule_form_kwargs = {\n",
    "    \"schedule_form\": True,\n",
    "    \"simple\": False,\n",
    "    \"attacker_penalty_factor\": 5,\n",
    "    \"defender_penalty_factor\": 5,\n",
    "}\n",
    "\n",
    "general_sum_kwargs = {\n",
    "    \"general_sum\": False,\n",
    "    \"attacker_feature_value\":  42, \n",
    "    \"defender_feature_value\": 69, \n",
    "    \"defender_step_cost\": 32.5, \n",
    "}\n",
    "\n",
    "boulou_camp = (2.2,15.9)\n",
    "# lobeke_camp = (2.25,15.75)\n",
    "kabo_djembe = (2.0532352380408088, 16.085709866529694)\n",
    "bomassa = (2.2037280296158355, 16.187056364164913)\n",
    "inner_post = (2.2,15.98)\n",
    "\n",
    "gsg = GreenSecurityGame(df, coordinate_rectangle, \"centroid\", num_clusters=10, num_rows=7, num_columns=7)\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=10, \n",
    "             generate_utility_matrix=True, \n",
    "             defense_time_threshold=2, \n",
    "             generate_actions=False, \n",
    "             force_return=False, \n",
    "             general_sum=False, \n",
    "             **schedule_form_kwargs)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "58394c22-dede-473b-b146-5e12cdb34e3e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(2401, 10)"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "gsg.schedule_form_dict[\"defender_utility_matrix\"].shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "6e92a6b8-5004-4738-8995-0739d83e4385",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Set parameter WLSAccessID\n",
      "Set parameter WLSSecret\n",
      "Set parameter LicenseID to value 2455389\n",
      "Academic license 2455389 - for non-commercial use only - registered to jc___@columbia.edu\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "(8, -0.2892405920467004)"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "start = time.time()\n",
    "nD_a, nD_d, nu = nash(gsg.schedule_form_dict[\"defender_utility_matrix\"])\n",
    "end = time.time()\n",
    "nruntime = end-start\n",
    "nsupport = sum([1 for p in nD_d if p!=0])\n",
    "nsupport,nu"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "d3c6b8cb-fbae-40cb-a363-320d1792bb61",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "starting seed 1\n",
      "(2401, 10)\n",
      "8 -0.25360478726289115\n",
      "starting i=1 at time 1746419677.8438423\n",
      "finished i=1 in 0.7710902690887451 seconds with u=-0.40068249102802195\n",
      "starting i=2 at time 1746419678.6149325\n",
      "finished i=2 in 4.629194021224976 seconds with u=-0.3176999753081526\n",
      "starting i=3 at time 1746419683.2441266\n",
      "finished i=3 in 2.6587727069854736 seconds with u=-0.28974976960374516\n",
      "starting i=4 at time 1746419685.9028993\n",
      "finished i=4 in 1.2794559001922607 seconds with u=-0.27217254489644127\n",
      "starting i=5 at time 1746419687.1823552\n",
      "finished i=5 in 1.3438737392425537 seconds with u=-0.26462832555160387\n",
      "starting i=6 at time 1746419688.526229\n",
      "finished i=6 in 0.3175954818725586 seconds with u=-0.25544713252285756\n",
      "starting i=7 at time 1746419688.8448899\n",
      "finished i=7 in 0.5570852756500244 seconds with u=-0.2540559665539354\n",
      "starting i=8 at time 1746419689.4029977\n",
      "finished i=8 in 0.26291918754577637 seconds with u=-0.25360478726289104\n",
      "starting seed 2\n",
      "(2401, 10)\n",
      "9 -0.2631362649722988\n",
      "starting i=1 at time 1746419689.839782\n",
      "finished i=1 in 0.5698845386505127 seconds with u=-0.44987933261671675\n",
      "starting i=2 at time 1746419690.4096665\n",
      "finished i=2 in 10.735763549804688 seconds with u=-0.34632841673516046\n",
      "starting i=3 at time 1746419701.1464262\n",
      "finished i=3 in 5.367239475250244 seconds with u=-0.3042734422751945\n",
      "starting i=4 at time 1746419706.5136657\n",
      "finished i=4 in 1.5653932094573975 seconds with u=-0.28005588874879345\n",
      "starting i=5 at time 1746419708.079059\n",
      "finished i=5 in 1.0370416641235352 seconds with u=-0.2713812411752375\n",
      "starting i=6 at time 1746419709.1161005\n",
      "finished i=6 in 0.7829244136810303 seconds with u=-0.26652327315291896\n",
      "starting i=7 at time 1746419709.899025\n",
      "finished i=7 in 0.6856377124786377 seconds with u=-0.26456859061629023\n",
      "starting i=8 at time 1746419710.5846627\n",
      "finished i=8 in 0.3615739345550537 seconds with u=-0.2634688843617009\n",
      "starting i=9 at time 1746419710.9462366\n",
      "finished i=9 in 0.2400190830230713 seconds with u=-0.2631362649722988\n",
      "starting seed 3\n",
      "(2401, 10)\n",
      "10 -0.27076294980155863\n",
      "starting i=1 at time 1746419711.3588438\n",
      "finished i=1 in 0.6406888961791992 seconds with u=-0.4811407822614249\n",
      "starting i=2 at time 1746419711.9995327\n",
      "finished i=2 in 3.4138107299804688 seconds with u=-0.3309055233967805\n",
      "starting i=3 at time 1746419715.4133434\n",
      "finished i=3 in 2.3372457027435303 seconds with u=-0.2972040809890757\n",
      "starting i=4 at time 1746419717.7505891\n",
      "finished i=4 in 1.031358003616333 seconds with u=-0.28277266127289824\n",
      "starting i=5 at time 1746419718.7819471\n",
      "finished i=5 in 1.0299732685089111 seconds with u=-0.27796615861938845\n",
      "starting i=6 at time 1746419719.8119204\n",
      "finished i=6 in 1.1412649154663086 seconds with u=-0.2751337084774713\n",
      "starting i=7 at time 1746419720.9531853\n",
      "finished i=7 in 0.9120974540710449 seconds with u=-0.27245230323797387\n",
      "starting i=8 at time 1746419721.8652828\n",
      "finished i=8 in 0.8171696662902832 seconds with u=-0.271647208884786\n",
      "starting i=9 at time 1746419722.6824524\n",
      "finished i=9 in 0.5229897499084473 seconds with u=-0.2710106820211467\n",
      "starting i=10 at time 1746419723.2054422\n",
      "finished i=10 in 0.2665374279022217 seconds with u=-0.2707629498015586\n",
      "starting seed 4\n",
      "(2401, 10)\n",
      "10 -0.2803832123405833\n",
      "starting i=1 at time 1746419723.6451836\n",
      "finished i=1 in 0.6343221664428711 seconds with u=-0.46118024995065876\n",
      "starting i=2 at time 1746419724.2805562\n",
      "finished i=2 in 1.2823545932769775 seconds with u=-0.3426789214769698\n",
      "starting i=3 at time 1746419725.5629108\n",
      "finished i=3 in 5.4802000522613525 seconds with u=-0.3232073516232221\n",
      "starting i=4 at time 1746419731.0431108\n",
      "finished i=4 in 2.9540319442749023 seconds with u=-0.3000054612883472\n",
      "starting i=5 at time 1746419733.9971428\n",
      "finished i=5 in 1.6006827354431152 seconds with u=-0.2917335742081456\n",
      "starting i=6 at time 1746419735.5988274\n",
      "finished i=6 in 1.152747631072998 seconds with u=-0.2850043658189463\n",
      "starting i=7 at time 1746419736.751575\n",
      "finished i=7 in 1.1233751773834229 seconds with u=-0.28276818011584604\n",
      "starting i=8 at time 1746419737.8749502\n",
      "finished i=8 in 0.3754000663757324 seconds with u=-0.2807384977489899\n",
      "starting i=9 at time 1746419738.2503502\n",
      "finished i=9 in 0.38336873054504395 seconds with u=-0.2805328560986138\n",
      "starting i=10 at time 1746419738.633719\n",
      "finished i=10 in 0.25189876556396484 seconds with u=-0.2803832123405833\n",
      "starting seed 5\n",
      "(2401, 10)\n",
      "10 -0.2488906341365553\n",
      "starting i=1 at time 1746419739.0589354\n",
      "finished i=1 in 0.7090640068054199 seconds with u=-0.4965335556086801\n",
      "starting i=2 at time 1746419739.7679994\n",
      "finished i=2 in 0.9008779525756836 seconds with u=-0.2926772833478436\n",
      "starting i=3 at time 1746419740.6698804\n",
      "finished i=3 in 0.8533716201782227 seconds with u=-0.26695950168062726\n",
      "starting i=4 at time 1746419741.523252\n",
      "finished i=4 in 0.981365442276001 seconds with u=-0.2623035617778565\n",
      "starting i=5 at time 1746419742.5046175\n",
      "finished i=5 in 0.8981635570526123 seconds with u=-0.2571180733012578\n",
      "starting i=6 at time 1746419743.402781\n",
      "finished i=6 in 0.7469024658203125 seconds with u=-0.2527697395580563\n",
      "starting i=7 at time 1746419744.1496835\n",
      "finished i=7 in 0.34047698974609375 seconds with u=-0.2495384947357468\n",
      "starting i=8 at time 1746419744.4901605\n",
      "finished i=8 in 0.40129613876342773 seconds with u=-0.2492621740328053\n",
      "starting i=9 at time 1746419744.8914566\n",
      "finished i=9 in 0.39477086067199707 seconds with u=-0.24908275747020514\n",
      "starting i=10 at time 1746419745.2875738\n",
      "finished i=10 in 0.23463654518127441 seconds with u=-0.2488906341365553\n",
      "starting seed 6\n",
      "(2401, 10)\n",
      "9 -0.2526632881921577\n",
      "starting i=1 at time 1746419745.7020013\n",
      "finished i=1 in 1.2646329402923584 seconds with u=-0.468225517657905\n",
      "starting i=2 at time 1746419746.9666343\n",
      "finished i=2 in 2.888512372970581 seconds with u=-0.31069253834598015\n",
      "starting i=3 at time 1746419749.8551466\n",
      "finished i=3 in 3.867436170578003 seconds with u=-0.27769033514644803\n",
      "starting i=4 at time 1746419753.7225828\n",
      "finished i=4 in 1.3778088092803955 seconds with u=-0.26280811854000335\n",
      "starting i=5 at time 1746419755.1003916\n",
      "finished i=5 in 1.0185589790344238 seconds with u=-0.2567220126254787\n",
      "starting i=6 at time 1746419756.1199608\n",
      "finished i=6 in 0.8728044033050537 seconds with u=-0.25483576208738185\n",
      "starting i=7 at time 1746419756.9927652\n",
      "finished i=7 in 0.9310190677642822 seconds with u=-0.25349585583144907\n",
      "starting i=8 at time 1746419757.9237843\n",
      "finished i=8 in 0.3735947608947754 seconds with u=-0.2526885816835415\n",
      "starting i=9 at time 1746419758.297379\n",
      "finished i=9 in 0.2523188591003418 seconds with u=-0.2526632881921576\n",
      "starting seed 7\n",
      "(2401, 10)\n",
      "10 -0.27581842968900966\n",
      "starting i=1 at time 1746419758.7281404\n",
      "finished i=1 in 1.1114680767059326 seconds with u=-0.5542275947385978\n",
      "starting i=2 at time 1746419759.8406146\n",
      "finished i=2 in 15.565851211547852 seconds with u=-0.3617897167056349\n",
      "starting i=3 at time 1746419775.4064658\n",
      "finished i=3 in 8.417242050170898 seconds with u=-0.3135426967476911\n",
      "starting i=4 at time 1746419783.8237078\n",
      "finished i=4 in 2.8729419708251953 seconds with u=-0.2966784461140175\n",
      "starting i=5 at time 1746419786.6977153\n",
      "finished i=5 in 1.6059050559997559 seconds with u=-0.2862352741381885\n",
      "starting i=6 at time 1746419788.3036203\n",
      "finished i=6 in 1.2526402473449707 seconds with u=-0.2802854424888904\n",
      "starting i=7 at time 1746419789.5562606\n",
      "finished i=7 in 0.9188294410705566 seconds with u=-0.27764832668129186\n",
      "starting i=8 at time 1746419790.47509\n",
      "finished i=8 in 0.5274171829223633 seconds with u=-0.2765563970104806\n",
      "starting i=9 at time 1746419791.003879\n",
      "finished i=9 in 0.47595739364624023 seconds with u=-0.27635721835485105\n",
      "starting i=10 at time 1746419791.4798365\n",
      "finished i=10 in 0.2720506191253662 seconds with u=-0.27581842968900966\n",
      "starting seed 8\n",
      "(2401, 10)\n",
      "10 -0.2790115391126209\n",
      "starting i=1 at time 1746419791.9364989\n",
      "finished i=1 in 0.7301604747772217 seconds with u=-0.4691986366535408\n",
      "starting i=2 at time 1746419792.6666594\n",
      "finished i=2 in 4.078875541687012 seconds with u=-0.3380366030038281\n",
      "starting i=3 at time 1746419796.745535\n",
      "finished i=3 in 5.497236251831055 seconds with u=-0.3186770808656679\n",
      "starting i=4 at time 1746419802.2427711\n",
      "finished i=4 in 5.926674127578735 seconds with u=-0.303073091083326\n",
      "starting i=5 at time 1746419808.1694453\n",
      "finished i=5 in 2.674673080444336 seconds with u=-0.2908481715990843\n",
      "starting i=6 at time 1746419810.8441184\n",
      "finished i=6 in 1.3293232917785645 seconds with u=-0.28605435679116614\n",
      "starting i=7 at time 1746419812.1744506\n",
      "finished i=7 in 0.9735293388366699 seconds with u=-0.28323113808376965\n",
      "starting i=8 at time 1746419813.14798\n",
      "finished i=8 in 0.7237510681152344 seconds with u=-0.281309639195794\n",
      "starting i=9 at time 1746419813.871731\n",
      "finished i=9 in 0.576554536819458 seconds with u=-0.2795539978574386\n",
      "starting i=10 at time 1746419814.4482856\n",
      "finished i=10 in 0.2836930751800537 seconds with u=-0.2790115391126209\n",
      "starting seed 9\n",
      "(2401, 10)\n",
      "9 -0.24723811950336894\n",
      "starting i=1 at time 1746419814.9766014\n",
      "finished i=1 in 2.8923544883728027 seconds with u=-0.37689756841129995\n",
      "starting i=2 at time 1746419817.8689559\n",
      "finished i=2 in 1.7235264778137207 seconds with u=-0.30072469786632616\n",
      "starting i=3 at time 1746419819.5924823\n",
      "finished i=3 in 0.8227708339691162 seconds with u=-0.26509648795699997\n",
      "starting i=4 at time 1746419820.4152532\n",
      "finished i=4 in 0.5088160037994385 seconds with u=-0.2535193712320194\n",
      "starting i=5 at time 1746419820.9240692\n",
      "finished i=5 in 0.9476785659790039 seconds with u=-0.2499744343893755\n",
      "starting i=6 at time 1746419821.8717477\n",
      "finished i=6 in 1.3135008811950684 seconds with u=-0.24888801857195747\n",
      "starting i=7 at time 1746419823.1852486\n",
      "finished i=7 in 0.35724735260009766 seconds with u=-0.24767881913393255\n",
      "starting i=8 at time 1746419823.542496\n",
      "finished i=8 in 0.3139312267303467 seconds with u=-0.24725021860285276\n",
      "starting i=9 at time 1746419823.8564272\n",
      "finished i=9 in 0.23041200637817383 seconds with u=-0.24723811950336888\n",
      "starting seed 10\n",
      "(2401, 10)\n",
      "10 -0.26595639490697387\n",
      "starting i=1 at time 1746419824.298493\n",
      "finished i=1 in 0.8763759136199951 seconds with u=-0.44210547472802414\n",
      "starting i=2 at time 1746419825.1748688\n",
      "finished i=2 in 4.857979774475098 seconds with u=-0.3388184199335233\n",
      "starting i=3 at time 1746419830.0328486\n",
      "finished i=3 in 2.6047306060791016 seconds with u=-0.2994555037905349\n",
      "starting i=4 at time 1746419832.6375792\n",
      "finished i=4 in 1.8648781776428223 seconds with u=-0.2898995405632164\n",
      "starting i=5 at time 1746419834.5024574\n",
      "finished i=5 in 1.1498377323150635 seconds with u=-0.27381709087042067\n",
      "starting i=6 at time 1746419835.652295\n",
      "finished i=6 in 0.8671245574951172 seconds with u=-0.27039476746381536\n",
      "starting i=7 at time 1746419836.5194197\n",
      "finished i=7 in 1.0314853191375732 seconds with u=-0.26872406090278533\n",
      "starting i=8 at time 1746419837.550905\n",
      "finished i=8 in 0.7645611763000488 seconds with u=-0.2674781860946349\n",
      "starting i=9 at time 1746419838.3154662\n",
      "finished i=9 in 0.5763189792633057 seconds with u=-0.2662097856951945\n",
      "starting i=10 at time 1746419838.8917851\n",
      "finished i=10 in 0.2645864486694336 seconds with u=-0.26595639490697387\n"
     ]
    }
   ],
   "source": [
    "nruntimes = []\n",
    "nsupports = []\n",
    "nus = []\n",
    "mip_us_per_seed = []\n",
    "mip_supports_per_seed = []\n",
    "mip_runtimes_per_seed = []\n",
    "\n",
    "for seed in seeds:\n",
    "    print(f\"starting seed {seed}\")\n",
    "    random_matrix = generate_random_utility_matrix_like(gsg.schedule_form_dict[\"defender_utility_matrix\"])\n",
    "    print(random_matrix.shape)\n",
    "    start = time.time()\n",
    "    nD_a, nD_d, nu = nash(random_matrix)\n",
    "    end = time.time()\n",
    "    nruntime = end-start\n",
    "    nsupport = sum([1 for p in nD_d if p!=0])\n",
    "    nus.append(nu)\n",
    "    print(nsupport,nu)\n",
    "    nruntimes.append(nruntime)\n",
    "    nsupports.append(nsupport)\n",
    "    \n",
    "    mip_us = []\n",
    "    mip_supports = []\n",
    "    mip_runtimes = []\n",
    "    \n",
    "    for i in range(1,60):\n",
    "        start = time.time()\n",
    "        print(f\"starting i={i} at time {start}\")\n",
    "        mu, mD_d = mip(random_matrix,i)\n",
    "        end = time.time()\n",
    "        print(f\"finished i={i} in {end-start} seconds with u={mu}\")\n",
    "        msupport = sum([1 for p in mD_d if p!=0])\n",
    "        mip_us.append(mu)\n",
    "        mip_supports.append(i)\n",
    "        mip_runtimes.append(end-start)\n",
    "        if abs(mu-nu) <= 1e-12:\n",
    "            mip_us_per_seed.append(mip_us)\n",
    "            mip_supports_per_seed.append(mip_supports)\n",
    "            mip_runtimes_per_seed.append(mip_runtimes)\n",
    "            break"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "78b67aeb-aace-4349-9bb9-8401a90fa425",
   "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_attackers</th>\n",
       "      <th>num_defenders</th>\n",
       "      <th>num_clusters</th>\n",
       "      <th>dims</th>\n",
       "      <th>defense_time_threshold</th>\n",
       "      <th>force_return</th>\n",
       "      <th>num_defender_actions</th>\n",
       "      <th>nash_value</th>\n",
       "      <th>nash_support</th>\n",
       "      <th>nash_runtime</th>\n",
       "      <th>mip_value</th>\n",
       "      <th>mip_support</th>\n",
       "      <th>mip_runtime</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>1</td>\n",
       "      <td>10</td>\n",
       "      <td>1</td>\n",
       "      <td>2</td>\n",
       "      <td>10</td>\n",
       "      <td>7</td>\n",
       "      <td>2</td>\n",
       "      <td>False</td>\n",
       "      <td>2401</td>\n",
       "      <td>-0.253605</td>\n",
       "      <td>8</td>\n",
       "      <td>0.236281</td>\n",
       "      <td>[-0.40068249102802195, -0.3176999753081526, -0...</td>\n",
       "      <td>[1, 2, 3, 4, 5, 6, 7, 8]</td>\n",
       "      <td>[0.7710902690887451, 4.629194021224976, 2.6587...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>2</td>\n",
       "      <td>10</td>\n",
       "      <td>1</td>\n",
       "      <td>2</td>\n",
       "      <td>10</td>\n",
       "      <td>7</td>\n",
       "      <td>2</td>\n",
       "      <td>False</td>\n",
       "      <td>2401</td>\n",
       "      <td>-0.263136</td>\n",
       "      <td>9</td>\n",
       "      <td>0.173865</td>\n",
       "      <td>[-0.44987933261671675, -0.34632841673516046, -...</td>\n",
       "      <td>[1, 2, 3, 4, 5, 6, 7, 8, 9]</td>\n",
       "      <td>[0.5698845386505127, 10.735763549804688, 5.367...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>3</td>\n",
       "      <td>10</td>\n",
       "      <td>1</td>\n",
       "      <td>2</td>\n",
       "      <td>10</td>\n",
       "      <td>7</td>\n",
       "      <td>2</td>\n",
       "      <td>False</td>\n",
       "      <td>2401</td>\n",
       "      <td>-0.270763</td>\n",
       "      <td>10</td>\n",
       "      <td>0.171223</td>\n",
       "      <td>[-0.4811407822614249, -0.3309055233967805, -0....</td>\n",
       "      <td>[1, 2, 3, 4, 5, 6, 7, 8, 9, 10]</td>\n",
       "      <td>[0.6406888961791992, 3.4138107299804688, 2.337...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>4</td>\n",
       "      <td>10</td>\n",
       "      <td>1</td>\n",
       "      <td>2</td>\n",
       "      <td>10</td>\n",
       "      <td>7</td>\n",
       "      <td>2</td>\n",
       "      <td>False</td>\n",
       "      <td>2401</td>\n",
       "      <td>-0.280383</td>\n",
       "      <td>10</td>\n",
       "      <td>0.172195</td>\n",
       "      <td>[-0.46118024995065876, -0.3426789214769698, -0...</td>\n",
       "      <td>[1, 2, 3, 4, 5, 6, 7, 8, 9, 10]</td>\n",
       "      <td>[0.6343221664428711, 1.2823545932769775, 5.480...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>5</td>\n",
       "      <td>10</td>\n",
       "      <td>1</td>\n",
       "      <td>2</td>\n",
       "      <td>10</td>\n",
       "      <td>7</td>\n",
       "      <td>2</td>\n",
       "      <td>False</td>\n",
       "      <td>2401</td>\n",
       "      <td>-0.248891</td>\n",
       "      <td>10</td>\n",
       "      <td>0.172318</td>\n",
       "      <td>[-0.4965335556086801, -0.2926772833478436, -0....</td>\n",
       "      <td>[1, 2, 3, 4, 5, 6, 7, 8, 9, 10]</td>\n",
       "      <td>[0.7090640068054199, 0.9008779525756836, 0.853...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>6</td>\n",
       "      <td>10</td>\n",
       "      <td>1</td>\n",
       "      <td>2</td>\n",
       "      <td>10</td>\n",
       "      <td>7</td>\n",
       "      <td>2</td>\n",
       "      <td>False</td>\n",
       "      <td>2401</td>\n",
       "      <td>-0.252663</td>\n",
       "      <td>9</td>\n",
       "      <td>0.179286</td>\n",
       "      <td>[-0.468225517657905, -0.31069253834598015, -0....</td>\n",
       "      <td>[1, 2, 3, 4, 5, 6, 7, 8, 9]</td>\n",
       "      <td>[1.2646329402923584, 2.888512372970581, 3.8674...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>7</td>\n",
       "      <td>10</td>\n",
       "      <td>1</td>\n",
       "      <td>2</td>\n",
       "      <td>10</td>\n",
       "      <td>7</td>\n",
       "      <td>2</td>\n",
       "      <td>False</td>\n",
       "      <td>2401</td>\n",
       "      <td>-0.275818</td>\n",
       "      <td>10</td>\n",
       "      <td>0.177366</td>\n",
       "      <td>[-0.5542275947385978, -0.3617897167056349, -0....</td>\n",
       "      <td>[1, 2, 3, 4, 5, 6, 7, 8, 9, 10]</td>\n",
       "      <td>[1.1114680767059326, 15.565851211547852, 8.417...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>8</td>\n",
       "      <td>10</td>\n",
       "      <td>1</td>\n",
       "      <td>2</td>\n",
       "      <td>10</td>\n",
       "      <td>7</td>\n",
       "      <td>2</td>\n",
       "      <td>False</td>\n",
       "      <td>2401</td>\n",
       "      <td>-0.279012</td>\n",
       "      <td>10</td>\n",
       "      <td>0.184612</td>\n",
       "      <td>[-0.4691986366535408, -0.3380366030038281, -0....</td>\n",
       "      <td>[1, 2, 3, 4, 5, 6, 7, 8, 9, 10]</td>\n",
       "      <td>[0.7301604747772217, 4.078875541687012, 5.4972...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>9</td>\n",
       "      <td>10</td>\n",
       "      <td>1</td>\n",
       "      <td>2</td>\n",
       "      <td>10</td>\n",
       "      <td>7</td>\n",
       "      <td>2</td>\n",
       "      <td>False</td>\n",
       "      <td>2401</td>\n",
       "      <td>-0.247238</td>\n",
       "      <td>9</td>\n",
       "      <td>0.244623</td>\n",
       "      <td>[-0.37689756841129995, -0.30072469786632616, -...</td>\n",
       "      <td>[1, 2, 3, 4, 5, 6, 7, 8, 9]</td>\n",
       "      <td>[2.8923544883728027, 1.7235264778137207, 0.822...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>10</td>\n",
       "      <td>10</td>\n",
       "      <td>1</td>\n",
       "      <td>2</td>\n",
       "      <td>10</td>\n",
       "      <td>7</td>\n",
       "      <td>2</td>\n",
       "      <td>False</td>\n",
       "      <td>2401</td>\n",
       "      <td>-0.265956</td>\n",
       "      <td>10</td>\n",
       "      <td>0.210652</td>\n",
       "      <td>[-0.44210547472802414, -0.3388184199335233, -0...</td>\n",
       "      <td>[1, 2, 3, 4, 5, 6, 7, 8, 9, 10]</td>\n",
       "      <td>[0.8763759136199951, 4.857979774475098, 2.6047...</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   seed  num_timesteps  num_attackers  num_defenders  num_clusters  dims  \\\n",
       "0     1             10              1              2            10     7   \n",
       "1     2             10              1              2            10     7   \n",
       "2     3             10              1              2            10     7   \n",
       "3     4             10              1              2            10     7   \n",
       "4     5             10              1              2            10     7   \n",
       "5     6             10              1              2            10     7   \n",
       "6     7             10              1              2            10     7   \n",
       "7     8             10              1              2            10     7   \n",
       "8     9             10              1              2            10     7   \n",
       "9    10             10              1              2            10     7   \n",
       "\n",
       "   defense_time_threshold  force_return  num_defender_actions  nash_value  \\\n",
       "0                       2         False                  2401   -0.253605   \n",
       "1                       2         False                  2401   -0.263136   \n",
       "2                       2         False                  2401   -0.270763   \n",
       "3                       2         False                  2401   -0.280383   \n",
       "4                       2         False                  2401   -0.248891   \n",
       "5                       2         False                  2401   -0.252663   \n",
       "6                       2         False                  2401   -0.275818   \n",
       "7                       2         False                  2401   -0.279012   \n",
       "8                       2         False                  2401   -0.247238   \n",
       "9                       2         False                  2401   -0.265956   \n",
       "\n",
       "   nash_support  nash_runtime  \\\n",
       "0             8      0.236281   \n",
       "1             9      0.173865   \n",
       "2            10      0.171223   \n",
       "3            10      0.172195   \n",
       "4            10      0.172318   \n",
       "5             9      0.179286   \n",
       "6            10      0.177366   \n",
       "7            10      0.184612   \n",
       "8             9      0.244623   \n",
       "9            10      0.210652   \n",
       "\n",
       "                                           mip_value  \\\n",
       "0  [-0.40068249102802195, -0.3176999753081526, -0...   \n",
       "1  [-0.44987933261671675, -0.34632841673516046, -...   \n",
       "2  [-0.4811407822614249, -0.3309055233967805, -0....   \n",
       "3  [-0.46118024995065876, -0.3426789214769698, -0...   \n",
       "4  [-0.4965335556086801, -0.2926772833478436, -0....   \n",
       "5  [-0.468225517657905, -0.31069253834598015, -0....   \n",
       "6  [-0.5542275947385978, -0.3617897167056349, -0....   \n",
       "7  [-0.4691986366535408, -0.3380366030038281, -0....   \n",
       "8  [-0.37689756841129995, -0.30072469786632616, -...   \n",
       "9  [-0.44210547472802414, -0.3388184199335233, -0...   \n",
       "\n",
       "                       mip_support  \\\n",
       "0         [1, 2, 3, 4, 5, 6, 7, 8]   \n",
       "1      [1, 2, 3, 4, 5, 6, 7, 8, 9]   \n",
       "2  [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]   \n",
       "3  [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]   \n",
       "4  [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]   \n",
       "5      [1, 2, 3, 4, 5, 6, 7, 8, 9]   \n",
       "6  [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]   \n",
       "7  [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]   \n",
       "8      [1, 2, 3, 4, 5, 6, 7, 8, 9]   \n",
       "9  [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]   \n",
       "\n",
       "                                         mip_runtime  \n",
       "0  [0.7710902690887451, 4.629194021224976, 2.6587...  \n",
       "1  [0.5698845386505127, 10.735763549804688, 5.367...  \n",
       "2  [0.6406888961791992, 3.4138107299804688, 2.337...  \n",
       "3  [0.6343221664428711, 1.2823545932769775, 5.480...  \n",
       "4  [0.7090640068054199, 0.9008779525756836, 0.853...  \n",
       "5  [1.2646329402923584, 2.888512372970581, 3.8674...  \n",
       "6  [1.1114680767059326, 15.565851211547852, 8.417...  \n",
       "7  [0.7301604747772217, 4.078875541687012, 5.4972...  \n",
       "8  [2.8923544883728027, 1.7235264778137207, 0.822...  \n",
       "9  [0.8763759136199951, 4.857979774475098, 2.6047...  "
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df = pd.DataFrame({\n",
    "    \"seed\":seeds,\n",
    "    \"num_timesteps\":[10 for i in range(len(seeds))],\n",
    "    \"num_attackers\":[1 for i in range(len(seeds))],\n",
    "    \"num_defenders\":[2 for i in range(len(seeds))],\n",
    "    \"num_clusters\":[10 for i in range(len(seeds))],\n",
    "    \"dims\":[7 for i in range(len(seeds))],\n",
    "    \"defense_time_threshold\":[2 for i in range(len(seeds))],\n",
    "    \"force_return\":[False for i in range(len(seeds))],\n",
    "    \"num_defender_actions\": [len(gsg.schedule_form_dict[\"defender_actions\"]) for i in range(len(seeds))],\n",
    "    \"nash_value\":nus,\n",
    "    \"nash_support\":nsupports,\n",
    "    \"nash_runtime\":nruntimes,\n",
    "    \"mip_value\":mip_us_per_seed,\n",
    "    \"mip_support\":mip_supports_per_seed,\n",
    "    \"mip_runtime\":mip_runtimes_per_seed,\n",
    "})\n",
    "df\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "a0cc970c-84e4-4aff-acfc-74252dc1b166",
   "metadata": {},
   "outputs": [],
   "source": [
    "df.to_csv(\"GSG_SF_T10_SPARSITY_RANDOM_MATRIX.csv\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "29568547-0e7f-4ff3-8f8b-ee22341b3bcc",
   "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
}
