{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "from pathlib import Path\n",
    "import json\n",
    "import matplotlib.pyplot as plt\n",
    "from matplotlib.pyplot import figure\n",
    "import pyspiel\n",
    "from tqdm import tqdm\n",
    "import utils.terminals_np as terminals\n",
    "from scipy.stats import sem"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_summary_stats(A):\n",
    "    stats = {}\n",
    "    stats['min'] = np.min(A)\n",
    "    stats['max'] = np.max(A)\n",
    "    stats['mean'] = np.mean(A)\n",
    "    stats['std err'] = sem(A)\n",
    "    return stats"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [],
   "source": [
    "ROOT = Path('results/poly_leduc_cfr_plus')\n",
    "data = []\n",
    "\n",
    "vulns = np.zeros(30)\n",
    "bounds = np.zeros(30)\n",
    "deltas = np.zeros(30)\n",
    "gammas = np.zeros(30)\n",
    "for run_idx in range(30):\n",
    "    log = json.load(open(ROOT/str(run_idx)/'log.json'))\n",
    "    vulns[run_idx] = log['vuln']\n",
    "    bounds [run_idx] = log['bounds'][-1]\n",
    "    deltas[run_idx] = log['delta'][-1]\n",
    "    gammas[run_idx] = log['gamma'][-1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "sort_idxs = np.argsort(bounds)\n",
    "bounds = bounds[sort_idxs]\n",
    "vulns = vulns[sort_idxs]\n",
    "gammas = gammas[sort_idxs]\n",
    "deltas = deltas[sort_idxs]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 300x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots(figsize=(3, 3))\n",
    "ax.boxplot(gammas, positions=[0], labels=[''])\n",
    "ax.set_ylabel(r'$\\gamma_j$', rotation=0, labelpad=20)\n",
    "ax.spines[['right', 'top']].set_visible(False)\n",
    "plt.savefig('figures/leduc_gammas.pdf', bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'min': 0.0032446756958961487,\n",
       " 'max': 0.00854514166712761,\n",
       " 'mean': 0.0038738273084163665,\n",
       " 'std err': 0.0001697711616250471}"
      ]
     },
     "execution_count": 23,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "get_summary_stats(gammas)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 300x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots(figsize=(3, 3))\n",
    "ax.boxplot(deltas, positions=[0], labels=[''])\n",
    "ax.set_ylabel(r'$\\delta_j$', rotation=0, labelpad=20)\n",
    "ax.spines[['right', 'top']].set_visible(False)\n",
    "plt.savefig('figures/leduc_deltas.pdf', bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'min': 0.006463110446929932,\n",
       " 'max': 0.021185778081417084,\n",
       " 'mean': 0.008748250703016916,\n",
       " 'std err': 0.000464378242729593}"
      ]
     },
     "execution_count": 24,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "get_summary_stats(deltas)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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3scff1xRUVEKDw/XsWPHNHHiRP3whz/UtGnTlJOT0xM9AgAAAN1mcjgcju6cWFdXp9raWh07dkxXXXWVIiMjvd2bz7S0tCgoKEjNzc0aOnSor9sBAADoWx4J6mS8uXf76KJuPXhCki699FKFh4dLkkwmk9caAgAAALypWw+eePHFFxUdHS2z2Syz2azo6Gj953/+p7d7AwAAAM6bxzO8y5cv1+rVq7Vw4UIlJiZKkiorK/XAAw+orq5Ojz76qNebBAAAQO+KWPpGp6/909yLjXiBx4H3hRde0B/+8Aelp6c7x26++WZNmjRJCxcuJPACAACgT/F4ScPp06c1efLkDuNxcXH65ptvutVEYWGhIiIiZDablZCQoF27dp21fuPGjYqKipLZbFZMTIy2bNni8vojjzyiqKgoDR48WMOHD1dSUpJ27tzZrd4AAABwYfM48N5999164YUXOoyvXbtWP/vZzzxuYMOGDbJarcrNzVV1dbViY2OVnJyshoYGt/U7duxQenq65s+fr5qaGqWmpio1NVW1tbXOmvHjx2vNmjX64IMP9N577ykiIkIzZ85UY2Ojx/0BAADgwubxtmQLFy7UK6+8ovDwcE2dOlWStHPnTtXV1SkjI0MDBw501q5evfqc10tISNCUKVO0Zs0aSZLdbld4eLgWLlyopUuXdqhPS0tTa2urNm/e7BybOnWqLBaLioqK3L7HmW3G3n77bd1www3n7IltyQAAQH939jW8d7p/wSjbktXW1urqq6+WJB04cECSFBwcrODgYJdZ1q5sVXbq1ClVVVUpKyvLOebn56ekpCRVVla6PaeyslJWq9VlLDk5WaWlpZ2+x9q1axUUFKTY2Fi3NW1tbWpra3P+3NLScs7eAQAAcGHwOPBu3brVa2/e1NSk9vZ2hYaGuoyHhobq448/dnuOzWZzW2+z2VzGNm/erDlz5uj48eMaNWqUysvLFRwc7PaaeXl5WrFixXncCQAAAPoqj9fwnm0d7AcffHBezXjTjBkztGfPHu3YsUMpKSm64447Ol0XnJWVpebmZufxxRdf9HK3AAAA6CkeB96YmBi98UbHNR1PP/204uPjPbpWcHCw/P39VV9f7zJeX1+vsLAwt+eEhYV1qX7w4MG6/PLLNXXqVL344osaMGCAXnzxRbfXDAwM1NChQ10OAAAAGIPHgddqter222/X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",
      "text/plain": [
       "<Figure size 800x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "x = np.arange(len(vulns))  # the label locations\n",
    "width = 1/3  # the width of the bars\n",
    "multiplier = 0\n",
    "fig, ax = plt.subplots(figsize=(8, 4))\n",
    "\n",
    "# for vuln\n",
    "offset = width * multiplier\n",
    "rects = ax.bar(x + offset, vulns, width, label=r'$Vul_j$')\n",
    "multiplier += 1\n",
    "\n",
    "# for bounds\n",
    "offset = width * multiplier\n",
    "rects = ax.bar(x + offset, bounds, width, label=r'$2 (\\delta_j+ \\gamma_j) $')\n",
    "multiplier += 1\n",
    "\n",
    "ax.set_ylabel('Expected Utility')\n",
    "ax.set_xlabel(r'$j$')\n",
    "ax.set_xticks([])\n",
    "ax.legend(loc='upper left', ncols=3)\n",
    "ax.set_ylim(0, 0.08)\n",
    "ax.spines[['right', 'top']].set_visible(False)\n",
    "plt.savefig('figures/leduc_bounds.pdf', bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'min': 1.8891195467722506,\n",
       " 'max': 3.0459446994926935,\n",
       " 'mean': 2.5113294278760794,\n",
       " 'std err': 0.048533767512612985}"
      ]
     },
     "execution_count": 25,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "get_summary_stats(bounds/vulns)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Total Variation (TV)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_TV(reach_probs):\n",
    "    num_strats = len(reach_probs)\n",
    "    TV = np.zeros((num_strats, num_strats)) # will store total variaion\n",
    "    for i_1, r_1 in enumerate(tqdm(reach_probs)):\n",
    "        for i_2, r_2 in enumerate(reach_probs):\n",
    "            TV[i_1, i_2] =  np.sum(np.abs(r_1- r_2))/2\n",
    "    return np.max(TV)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 30/30 [00:01<00:00, 15.05it/s]\n",
      "100%|██████████| 30/30 [00:01<00:00, 15.36it/s]\n",
      "100%|██████████| 30/30 [00:01<00:00, 15.58it/s]\n",
      "100%|██████████| 30/30 [00:01<00:00, 15.08it/s]\n",
      "100%|██████████| 30/30 [00:01<00:00, 15.49it/s]\n",
      "100%|██████████| 30/30 [00:02<00:00, 14.16it/s]\n",
      "100%|██████████| 30/30 [00:01<00:00, 16.11it/s]\n",
      "100%|██████████| 30/30 [00:01<00:00, 15.28it/s]\n",
      "100%|██████████| 30/30 [00:02<00:00, 14.99it/s]\n",
      "100%|██████████| 30/30 [00:01<00:00, 15.33it/s]\n",
      "100%|██████████| 30/30 [00:02<00:00, 14.54it/s]\n",
      "100%|██████████| 30/30 [00:01<00:00, 15.56it/s]\n",
      "100%|██████████| 30/30 [00:02<00:00, 14.82it/s]\n",
      "100%|██████████| 30/30 [00:02<00:00, 14.68it/s]\n",
      "100%|██████████| 30/30 [00:02<00:00, 14.72it/s]\n",
      "100%|██████████| 30/30 [00:01<00:00, 16.16it/s]\n",
      "100%|██████████| 30/30 [00:01<00:00, 15.34it/s]\n",
      "100%|██████████| 30/30 [00:01<00:00, 15.26it/s]\n",
      "100%|██████████| 30/30 [00:02<00:00, 14.75it/s]\n",
      "100%|██████████| 30/30 [00:01<00:00, 15.28it/s]\n",
      "100%|██████████| 30/30 [00:01<00:00, 15.23it/s]\n",
      "100%|██████████| 30/30 [00:02<00:00, 14.97it/s]\n",
      "100%|██████████| 30/30 [00:01<00:00, 15.11it/s]\n",
      "100%|██████████| 30/30 [00:02<00:00, 14.55it/s]\n",
      "100%|██████████| 30/30 [00:02<00:00, 14.32it/s]\n",
      "100%|██████████| 30/30 [00:02<00:00, 14.08it/s]\n",
      "100%|██████████| 30/30 [00:02<00:00, 14.26it/s]\n",
      "100%|██████████| 30/30 [00:02<00:00, 14.34it/s]\n",
      "100%|██████████| 30/30 [00:02<00:00, 14.17it/s]\n",
      "100%|██████████| 30/30 [00:02<00:00, 14.43it/s]\n",
      "100%|██████████| 30/30 [01:12<00:00,  2.41s/it]\n"
     ]
    }
   ],
   "source": [
    "NUM_PLAYERS = 3\n",
    "NUM_STRATS = 900\n",
    "GAME = 'leduc_poker'\n",
    "game = pyspiel.load_game(GAME, {\"players\": NUM_PLAYERS})\n",
    "root = Path('cfr/cfr_plus_leduc')\n",
    "chance_prob = terminals.chance_terminal_reach_probs(game)\n",
    "\n",
    "tvs = np.zeros(30)\n",
    "for run_idx, run in enumerate(tqdm(range(30))):\n",
    "    reach_probs = []\n",
    "    start = run*30\n",
    "    for strat_run in range(start, start+30):\n",
    "        r = chance_prob.copy()\n",
    "        for p in range(NUM_PLAYERS):\n",
    "            r *= np.load(root/str(strat_run)/'strats'/('{}.npy'.format(p)))\n",
    "        reach_probs.append(r)\n",
    "    reach_probs = np.array(reach_probs)\n",
    "    tvs[run_idx] = get_TV(reach_probs)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 800x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "sorted_tvs = tvs[sort_idxs]\n",
    "\n",
    "x = np.arange(len(vulns))  # the label locations\n",
    "width = 0.5  # the width of the bars\n",
    "multiplier = 0\n",
    "multiplier = 0\n",
    "fig, ax = plt.subplots(figsize=(8, 4))\n",
    "\n",
    "# for vuln\n",
    "offset = width * multiplier\n",
    "rects = ax.bar(x + offset, sorted_tvs, width)\n",
    "\n",
    "ax.set_ylabel(r'$TV_j$', rotation=0, labelpad=20)\n",
    "ax.set_xlabel(r'$j$')\n",
    "ax.set_ylim(0.18, 0.28)\n",
    "ax.set_xticks([])\n",
    "ax.spines[['right', 'top']].set_visible(False)\n",
    "plt.savefig('figures/leduc_TV.pdf', bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'min': 0.2107856179320977,\n",
       " 'max': 0.2593958902798726,\n",
       " 'mean': 0.22178619110477035,\n",
       " 'std err': 0.0016717483781393827}"
      ]
     },
     "execution_count": 26,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "get_summary_stats(tvs)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 107,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 30/30 [00:00<00:00, 32.78it/s]\n"
     ]
    }
   ],
   "source": [
    "epsilons = np.zeros((30, 30, 11, 3))\n",
    "for run_idx, run in enumerate(tqdm(range(30))):\n",
    "    reach_probs = []\n",
    "    start = run*30\n",
    "    for strat_run in range(start, start+30):\n",
    "        for itr_idx, itr in enumerate(range(0, 1100, 100)):\n",
    "            epsilons_run = np.load(root/str(strat_run)/'epsilons'/('{}.npy'.format(itr)))\n",
    "            epsilons[run_idx, strat_run%30, itr_idx, :] = epsilons_run"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 112,
   "metadata": {},
   "outputs": [],
   "source": [
    "epsilons_final = np.zeros((900, 3))\n",
    "for p in range(3):\n",
    "    epsilons_final[:, p] = epsilons[:,:, -1, p].flatten()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "np.max(epsilons) # the maximum epsilon"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "venv",
   "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.9.18"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
