{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "0840ff54-6eb0-4a93-80e1-c66ac909096b",
   "metadata": {},
   "outputs": [],
   "source": [
    "from simplex_proj import *\n",
    "from linsys_solve import *\n",
    "from linsys_solve2 import *\n",
    "from pcfr import *\n",
    "from game_gen import *\n",
    "from game_util import *\n",
    "from gurobi_algorithms import *\n",
    "from testing_utilities import *\n",
    "from typing import Iterable, Dict, Optional, Tuple\n",
    "from final_pssn import *\n",
    "from final_testing import *\n",
    "\n",
    "import os\n",
    "import datetime"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "c0391dd0-704d-49fc-bf29-b21c5ef9caa5",
   "metadata": {},
   "outputs": [],
   "source": [
    "from __future__ import annotations\n",
    "from typing import Optional, Callable, List\n",
    "import re\n",
    "import time\n",
    "\n",
    "def log_path_with_threshold(method_name, game_name, seed, threshold):\n",
    "    base = build_base_path(method_name, game_name, \"threshold\")\n",
    "    return f\"{base}_{seed}_thr{-int(np.log10(threshold))}.csv\"\n",
    "    \n",
    "TOTAL_TIME_RE = re.compile(r\"Total time taken:\\s*([\\d.]+)\\s*seconds\\.?\", re.IGNORECASE)\n",
    "\n",
    "def _parse_total_time_from_log(file_path: str) -> Optional[float]:\n",
    "    \"\"\"Return total runtime in seconds by parsing 'Total time taken: X seconds.' from a log file.\"\"\"\n",
    "    try:\n",
    "        with open(file_path, \"r\") as f:\n",
    "            TOTAL_TIME_RE = re.compile(r\"Total time taken:\\s*([\\d.]+)\\s*seconds\\.?\", re.IGNORECASE)\n",
    "            for line in f:\n",
    "                m = TOTAL_TIME_RE.search(line)\n",
    "                if m:\n",
    "                    return float(m.group(1))\n",
    "    except OSError:\n",
    "        pass\n",
    "    return None"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "e1230ddf-22c4-43bd-83db-4554c3df6dbe",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "method   \tt@1e-01     \tt@1e-02     \tt@1e-03     \tt@1e-04     \n",
      "pssn     \t0.117998    \t0.105867    \t0.123313    \t0.181578    \n",
      "pssn_v2  \t0.115768    \t0.104756    \t0.119859    \t0.185821    \n"
     ]
    }
   ],
   "source": [
    "random_matrix_average_runtime_table_by_threshold(\n",
    "    game_name=\"normal\",\n",
    "    method_names=[\"pssn\", \"pssn_v2\"],\n",
    "    seed_start=1,\n",
    "    seed_end=10,\n",
    "    thresholds=[1e-1, 1e-2, 1e-3, 1e-4],\n",
    "    n = 100,\n",
    "    m = 100\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "752e99ce-258f-4169-b16e-1665272b15ef",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "method   \tt@1e-01     \tt@1e-02     \tt@1e-03     \tt@1e-04     \n",
      "pssn     \t0.087888    \t0.099985    \t0.112717    \t0.179821    \n",
      "pssn_v2  \t0.083263    \t0.098226    \t0.111123    \t0.179614    \n"
     ]
    }
   ],
   "source": [
    "random_matrix_average_runtime_table_by_threshold(\n",
    "    game_name=\"uniform\",\n",
    "    method_names=[\"pssn\", \"pssn_v2\"],\n",
    "    seed_start=1,\n",
    "    seed_end=10,\n",
    "    thresholds=[1e-1, 1e-2, 1e-3, 1e-4],\n",
    "    n = 100,\n",
    "    m = 100\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "69504ffd-0e9e-429d-8929-3e7608a40e6c",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "method   \tt@1e-04     \tt@1e-05     \tt@1e-06     \tt@1e-07     \n",
      "pssn     \t3.154271    \t2.645327    \t4.212758    \t6.866291    \n",
      "pssn_v2  \t2.939143    \t2.423784    \t17.269249   \t23.692618   \n"
     ]
    }
   ],
   "source": [
    "random_matrix_average_runtime_table_by_threshold(\n",
    "    game_name=\"uniform\",\n",
    "    method_names=[\"pssn\", \"pssn_v2\"],\n",
    "    seed_start=1,\n",
    "    seed_end=10,\n",
    "    thresholds=[1e-4, 1e-5, 1e-6, 1e-7],\n",
    "    n = 400,\n",
    "    m = 400\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "4b3a8f4c-3ce1-4db7-97f1-0a34f12eb019",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "method   \tt@1e-04     \tt@1e-05     \tt@1e-06     \tt@1e-07     \n",
      "pssn     \t3.761765    \t2.645073    \t4.518703    \t7.131880    \n",
      "pssn_v2  \t3.445822    \t3.067738    \t26.444890   \t39.878494   \n"
     ]
    }
   ],
   "source": [
    "random_matrix_average_runtime_table_by_threshold(\n",
    "    game_name=\"normal\",\n",
    "    method_names=[\"pssn\", \"pssn_v2\"],\n",
    "    seed_start=1,\n",
    "    seed_end=10,\n",
    "    thresholds=[1e-4, 1e-5, 1e-6, 1e-7],\n",
    "    n = 400,\n",
    "    m = 400\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "4ec3b22a-91b4-4275-bf7d-fa1aa14e2392",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "method   \tt@1e-04     \tt@1e-05     \tt@1e-06     \tt@1e-07     \n",
      "pssn     \t35.320440   \t5.306196    \t33.992508   \t10.826528   \n",
      "pssn_v2  \t34.497115   \t5.094009    \t89.872314   \t119.247848  \n"
     ]
    }
   ],
   "source": [
    "random_matrix_average_runtime_table_by_threshold(\n",
    "    game_name=\"normal\",\n",
    "    method_names=[\"pssn\", \"pssn_v2\"],\n",
    "    seed_start=1,\n",
    "    seed_end=10,\n",
    "    thresholds=[1e-4, 1e-5, 1e-6, 1e-7],\n",
    "    n = 400,\n",
    "    m = 800\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "7e0c7c0e-890c-4b72-86ae-298a2898f8bc",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "method   \tt@1e-04     \tt@1e-05     \tt@1e-06     \tt@1e-07     \n",
      "pssn     \t9.069791    \t5.940237    \t4.648491    \t6.839095    \n",
      "pssn_v2  \t9.578071    \t4.323426    \t5.125264    \t74.375092   \n"
     ]
    }
   ],
   "source": [
    "random_matrix_average_runtime_table_by_threshold(\n",
    "    game_name=\"uniform\",\n",
    "    method_names=[\"pssn\", \"pssn_v2\"],\n",
    "    seed_start=1,\n",
    "    seed_end=10,\n",
    "    thresholds=[1e-4, 1e-5, 1e-6, 1e-7],\n",
    "    n = 400,\n",
    "    m = 800\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "507b8cd4-ee04-4752-bca0-0a21920033f8",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "method     \tt@1e-02     \tt@1e-04     \tt@1e-06     \tt@1e-08     \tt@1e-10     \tt@1e-12     \n",
      "pcfr_li    \t0.007588    \t0.119810    \t4.476132    \t31.204935   \t            \t            \n",
      "pcfr_qa    \t0.007991    \t0.050285    \t0.470800    \t6.237704    \t26.312486   \t            \n",
      "pssn       \t0.034924    \t0.104541    \t0.116413    \t0.117309    \t0.117578    \t0.117989    \n",
      "pssn_v2    \t0.035019    \t0.102142    \t0.114166    \t0.115071    \t0.115352    \t0.115759    \n",
      "hack_pssn  \t            \t            \t            \t            \t            \t            \n"
     ]
    }
   ],
   "source": [
    "extract_methods_threshold_avgs(\n",
    "    game_name = \"normal\",\n",
    "    method_names = [\"pcfr_li\", \"pcfr_qa\", \"pssn\", \"pssn_v2\", \"hack_pssn\"],\n",
    "    seed_start = 1,\n",
    "    seed_end = 10,\n",
    "    directory = \"100x100\",\n",
    "    switch = 1e-1\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "a710429c-9cd2-4e53-955b-beacc1d39d82",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "method     \tt@1e-02     \tt@1e-04     \tt@1e-06     \tt@1e-08     \tt@1e-10     \tt@1e-12     \n",
      "pcfr_li    \t0.009025    \t0.077018    \t5.169593    \t30.807904   \t            \t            \n",
      "pcfr_qa    \t0.008025    \t0.040655    \t0.396254    \t8.452298    \t27.945712   \t            \n",
      "pssn       \t0.022035    \t0.070349    \t0.085990    \t0.086933    \t0.087519    \t0.087878    \n",
      "pssn_v2    \t0.019563    \t0.066205    \t0.081268    \t0.082146    \t0.082755    \t0.083254    \n",
      "hack_pssn  \t            \t            \t            \t            \t            \t            \n"
     ]
    }
   ],
   "source": [
    "extract_methods_threshold_avgs(\n",
    "    game_name = \"uniform\",\n",
    "    method_names = [\"pcfr_li\", \"pcfr_qa\", \"pssn\", \"pssn_v2\", \"hack_pssn\"],\n",
    "    seed_start = 1,\n",
    "    seed_end = 10,\n",
    "    directory = \"100x100\",\n",
    "    switch = 1e-1\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "4f4bef3c-1a22-4348-b203-f1b2efedbac0",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "method     \tt@1e-02     \tt@1e-04     \tt@1e-06     \tt@1e-08     \tt@1e-10     \tt@1e-12     \n",
      "pcfr_li    \t0.005272    \t0.087662    \t3.139650    \t22.092377   \t            \t            \n",
      "pcfr_qa    \t0.005296    \t0.034077    \t0.331637    \t4.257839    \t18.042114   \t            \n",
      "pssn       \t0.074555    \t0.462588    \t2.608101    \t2.631156    \t2.641054    \t2.645058    \n",
      "pssn_v2    \t0.076540    \t0.480772    \t2.971826    \t3.051554    \t3.063970    \t3.067720    \n",
      "hack_pssn  \t            \t            \t            \t            \t            \t            \n"
     ]
    }
   ],
   "source": [
    "extract_methods_threshold_avgs(\n",
    "    game_name = \"normal\",\n",
    "    method_names = [\"pcfr_li\", \"pcfr_qa\", \"pssn\", \"pssn_v2\", \"hack_pssn\"],\n",
    "    seed_start = 1,\n",
    "    seed_end = 10,\n",
    "    directory = \"400x400\",\n",
    "    switch = 1e-5\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "ae4b41d7-b9ee-4c15-a3bd-a8c3979ea64c",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "method     \tt@1e-02     \tt@1e-04     \tt@1e-06     \tt@1e-08     \tt@1e-10     \tt@1e-12     \n",
      "pcfr_li    \t0.006482    \t0.054017    \t3.608156    \t20.129593   \t            \t            \n",
      "pcfr_qa    \t0.005370    \t0.027466    \t0.268092    \t5.755197    \t18.877429   \t            \n",
      "pssn       \t0.075216    \t0.375074    \t2.538418    \t2.629074    \t2.639824    \t2.645314    \n",
      "pssn_v2    \t0.075150    \t0.375276    \t2.319093    \t2.410325    \t2.416912    \t2.423771    \n",
      "hack_pssn  \t            \t            \t            \t            \t            \t            \n"
     ]
    }
   ],
   "source": [
    "extract_methods_threshold_avgs(\n",
    "    game_name = \"uniform\",\n",
    "    method_names = [\"pcfr_li\", \"pcfr_qa\", \"pssn\", \"pssn_v2\", \"hack_pssn\"],\n",
    "    seed_start = 1,\n",
    "    seed_end = 10,\n",
    "    directory = \"400x400\",\n",
    "    switch = 1e-5\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "2fafb6c6-62c2-4dc6-a487-b9e9deb618f7",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "method     \tt@1e-02     \tt@1e-04     \tt@1e-06     \tt@1e-08     \tt@1e-10     \tt@1e-12     \n",
      "pcfr_li    \t0.005540    \t0.086595    \t3.325116    \t23.505439   \t            \t            \n",
      "pcfr_qa    \t0.005824    \t0.036443    \t0.366328    \t4.923164    \t19.829906   \t            \n",
      "pssn       \t0.127793    \t0.689854    \t4.238332    \t5.267054    \t5.289470    \t5.306178    \n",
      "pssn_v2    \t0.127992    \t0.690608    \t3.983496    \t5.055014    \t5.077121    \t5.093992    \n",
      "hack_pssn  \t0.125336    \t0.571758    \t3.894894    \t4.785835    \t4.790341    \t4.814823    \n"
     ]
    }
   ],
   "source": [
    "extract_methods_threshold_avgs(\n",
    "    game_name = \"normal\",\n",
    "    method_names = [\"pcfr_li\", \"pcfr_qa\", \"pssn\", \"pssn_v2\", \"hack_pssn\"],\n",
    "    seed_start = 1,\n",
    "    seed_end = 10,\n",
    "    directory = \"400x800\",\n",
    "    switch = 1e-5\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "84c82c51-6315-42f1-a77c-3771dde77914",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "method     \tt@1e-02     \tt@1e-04     \tt@1e-06     \tt@1e-08     \tt@1e-10     \tt@1e-12     \n",
      "pcfr_li    \t0.006953    \t0.059384    \t3.848058    \t21.685364   \t            \t            \n",
      "pcfr_qa    \t0.005918    \t0.029523    \t0.293110    \t6.424328    \t21.966379   \t            \n",
      "pssn       \t0.088892    \t0.375603    \t3.462673    \t5.766755    \t5.922330    \t5.940221    \n",
      "pssn_v2    \t0.090335    \t0.384521    \t3.637597    \t4.290308    \t4.306591    \t4.323409    \n",
      "hack_pssn  \t0.101335    \t0.399395    \t3.905081    \t5.067654    \t5.082149    \t5.092214    \n"
     ]
    }
   ],
   "source": [
    "extract_methods_threshold_avgs(\n",
    "    game_name = \"uniform\",\n",
    "    method_names = [\"pcfr_li\", \"pcfr_qa\", \"pssn\", \"pssn_v2\", \"hack_pssn\"],\n",
    "    seed_start = 1,\n",
    "    seed_end = 10,\n",
    "    directory = \"400x800\",\n",
    "    switch = 1e-5\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "c34a451a-3d70-4206-b11c-d7b5dd8ff3e4",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "method     \tt@1e-02     \tt@1e-04     \tt@1e-06     \tt@1e-08     \tt@1e-10     \tt@1e-12     \n",
      "pcfr_li    \t0.006953    \t0.059384    \t3.848058    \t21.685364   \t            \t            \n",
      "pcfr_qa    \t0.005918    \t0.029523    \t0.293110    \t6.424328    \t21.966379   \t            \n",
      "pssn       \t0.089462    \t0.375661    \t3.386717    \t4.613384    \t4.631686    \t4.648475    \n",
      "pssn_v2    \t0.093363    \t0.384658    \t4.357614    \t5.090267    \t5.114187    \t5.125246    \n",
      "hack_pssn  \t0.101335    \t0.399395    \t3.905081    \t5.067654    \t5.082149    \t5.092214    \n"
     ]
    }
   ],
   "source": [
    "extract_methods_threshold_avgs(\n",
    "    game_name = \"uniform\",\n",
    "    method_names = [\"pcfr_li\", \"pcfr_qa\", \"pssn\", \"pssn_v2\", \"hack_pssn\"],\n",
    "    seed_start = 1,\n",
    "    seed_end = 10,\n",
    "    directory = \"400x800\",\n",
    "    switch = 1e-6\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "108c7e9b-0350-4f89-b0b4-6fe4efb38c6f",
   "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.13.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
