{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "8b02d7c062c53502",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-05-15T18:46:31.111886Z",
     "start_time": "2025-05-15T18:46:30.288720Z"
    }
   },
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import matplotlib as mpl\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "from matplotlib.lines import lineStyles\n",
    "from scipy.stats import alpha\n",
    "\n",
    "# General configuration\n",
    "mpl.rcParams.update({\n",
    "    \"text.usetex\": False,                   # Set True if you're compiling with LaTeX\n",
    "    \"font.family\": \"serif\",                # 'serif' or 'sans-serif' as preferred\n",
    "    \"font.size\": 8,                        # NeurIPS papers often use 8 pt font\n",
    "    \"axes.titlesize\": 8,\n",
    "    \"axes.labelsize\": 8,\n",
    "    \"xtick.labelsize\": 7,\n",
    "    \"ytick.labelsize\": 7,\n",
    "    \"legend.fontsize\": 7,\n",
    "    \"figure.titlesize\": 8,\n",
    "    \"lines.linewidth\": 1.2,\n",
    "    \"lines.markersize\": 4,\n",
    "    \"axes.linewidth\": 0.8,\n",
    "    \"xtick.major.width\": 0.8,\n",
    "    \"ytick.major.width\": 0.8,\n",
    "    \"legend.frameon\": False,\n",
    "    \"legend.loc\": \"best\",\n",
    "    \"savefig.dpi\": 300,\n",
    "    \"savefig.bbox\": \"tight\",\n",
    "    \"pdf.fonttype\": 42,                    # Embed fonts in PDF (important for submission)\n",
    "    \"ps.fonttype\": 42\n",
    "})\n",
    "\n",
    "width = 3.5  # inches for single column, 7 for double\n",
    "height = width / 1.618\n",
    "\n",
    "\n",
    "colors = ['#3599BF', '#CE6661', '#64B268', '#3298BE', '#E68656']  # Colorblind-safe\n",
    "markers = ['o', 's', '^', 'D', 'x']  # Use distinct shapes\n",
    "\n",
    "def setup_neurips_plot(width=3.5, height=None):\n",
    "    \"\"\"\n",
    "    Create a Matplotlib figure and axis with NeurIPS-friendly styling.\n",
    "\n",
    "    Parameters:\n",
    "        width (float): Width of the figure in inches (3.5 for single-column).\n",
    "        height (float): Height in inches. Defaults to golden ratio if None.\n",
    "\n",
    "    Returns:\n",
    "        fig, ax: Matplotlib figure and axis.\n",
    "    \"\"\"\n",
    "    # Golden ratio for aesthetics\n",
    "    if height is None:\n",
    "        height = width / 1.618\n",
    "\n",
    "    fig, ax = plt.subplots(figsize=(width, height), constrained_layout=True)\n",
    "\n",
    "    # Clean up spines\n",
    "    ax.spines['top'].set_visible(False)\n",
    "    ax.spines['right'].set_visible(False)\n",
    "    for spine in ['left', 'bottom']:\n",
    "        ax.spines[spine].set_linewidth(0.8)\n",
    "\n",
    "    return fig, ax"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "23373f24951c729f",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-05-15T19:17:31.662313Z",
     "start_time": "2025-05-15T19:17:31.632697Z"
    }
   },
   "outputs": [],
   "source": [
    "import wandb\n",
    "import pandas as pd\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "# ——— CONFIG —————————————————————————————————————————————\n",
    "ENTITY     = \"padlex\"\n",
    "PROJECT    = \"pgx-az\"\n",
    "ldx_runs   = [\n",
    "    \"ldx-reversi-baseline-full-obs\",\n",
    "    \"ldx-reversi-baseline-loop1\",\n",
    "    \"ldx-reversi-baseline-loop2\",\n",
    "]\n",
    "pgx_runs   = [\n",
    "    \"pgx-reversi-baseline-full\",\n",
    "    \"pgx-reversi-baseline-loop1\",\n",
    "    \"pgx-reversi-baseline-loop2\",\n",
    "]\n",
    "# the raw W&B history keys you want\n",
    "p1_win_key = \"eval/vs_baseline/player1/win_rate\"\n",
    "p2_win_key = \"eval/vs_baseline/player2/win_rate\"\n",
    "FEATURES   = [p1_win_key, p2_win_key]\n",
    "MAX_STEPS  = 219\n",
    "FRAME_MULTIPLE = 256 * 1024 # in each iteration we play 1024 games for 256 turns."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f86d49882e0a09f3",
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "# ——————————————————————————————————————————————————————\n",
    "\n",
    "api = wandb.Api()\n",
    "\n",
    "def fetch_runs_history(entity: str, project: str, runs: list, keys: list) -> dict:\n",
    "    out = {}\n",
    "    for name in runs:\n",
    "        run = api.runs(path=f\"{entity}/{project}\", filters={\"display_name\": {\"$in\": [name]}})[0]\n",
    "        df  = pd.DataFrame(run.history(keys=keys, pandas=False))\n",
    "        df  = df.rename(columns={\"_step\": \"step\"}).set_index(\"step\").loc[:MAX_STEPS]\n",
    "        out[name] = df\n",
    "    return out\n",
    "\n",
    "\n",
    "def combine_win_rate(dfs: dict, k1: str, k2: str) -> pd.DataFrame:\n",
    "    merged = {}\n",
    "    for run_name, df in dfs.items():\n",
    "        w1 = df.get(k1, pd.Series(dtype=float))\n",
    "        w2 = df.get(k2, pd.Series(dtype=float))\n",
    "        merged[run_name] = (w1 + w2) / 2\n",
    "    return pd.DataFrame(merged)\n",
    "\n",
    "\n",
    "# 1) Pull data for both methods\n",
    "ldx_hist = fetch_runs_history(ENTITY, PROJECT, ldx_runs, FEATURES)\n",
    "pgx_hist = fetch_runs_history(ENTITY, PROJECT, pgx_runs, FEATURES)\n",
    "\n",
    "# 2) Compute per-run average win rates\n",
    "ldx_win_df = combine_win_rate(ldx_hist, p1_win_key, p2_win_key)\n",
    "pgx_win_df = combine_win_rate(pgx_hist, p1_win_key, p2_win_key)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "994f9a7bb5918787",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-05-15T19:37:26.000698Z",
     "start_time": "2025-05-15T19:37:25.736706Z"
    }
   },
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 350x216.316 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from matplotlib.lines import Line2D\n",
    "\n",
    "# parameters\n",
    "SMOOTH_WINDOW = 5  # or whatever you used before\n",
    "\n",
    "# build figure\n",
    "fig, ax = setup_neurips_plot()\n",
    "\n",
    "for df, label, color in zip([ldx_win_df, pgx_win_df], [\"Ludax\", \"PGX\"], colors[:2]):\n",
    "\n",
    "    # plot raw runs\n",
    "    for run in df.columns:\n",
    "        ax.plot(df.index * FRAME_MULTIPLE / 10**6, df[run], alpha=1, color=color, linestyle=\"-\", linewidth=0.6)\n",
    "\n",
    "raw_legend_lines = [\n",
    "    Line2D([0], [0], color=colors[0], linewidth=1, linestyle=\"-\", alpha=1, label=\"Ludax runs\"),\n",
    "    Line2D([0], [0], color=colors[1], linewidth=1, linestyle=\"-\", alpha=1, label=\"PGX runs\"),\n",
    "    Line2D([0], [0], color=\"gray\", linewidth=1, linestyle=\"--\", alpha=1, label=\"(PGX) Baseline\"),\n",
    "]\n",
    "handles, labels = ax.get_legend_handles_labels()\n",
    "handles.extend(raw_legend_lines)\n",
    "\n",
    "# Set the legend\n",
    "\n",
    "# PGX baseline\n",
    "ax.axhline(0.5, linestyle=\"--\", color=\"gray\", alpha=1, linewidth=0.8)\n",
    "\n",
    "# labels & legend\n",
    "ax.set_xlabel(\"Millions of frames\")\n",
    "ax.set_ylabel(\"Win rate vs baseline\")\n",
    "ax.set_title(\"$\\\\bf{Reversi}:$ Individual Runs\")\n",
    "ax.legend(handles=handles, loc=\"lower right\", framealpha=0.9)\n",
    "fig.savefig(\"../data/rl_runs/reversi/reversi_win_raw_runs_frames.pdf\", bbox_inches=\"tight\")\n",
    "\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "469364a04cc2c338",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-05-15T19:37:23.670216Z",
     "start_time": "2025-05-15T19:37:23.521280Z"
    }
   },
   "outputs": [
    {
     "data": {
      "image/png": "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VkLTjNi49Aek79iINdndcNWFY5FkMYkCntfnh4XFO0kOZZwbmD99uQa7K9wNdryOKQ788+z+dT7P9FP+A/d4PDj55JMP+/iszL3vvvuQqLBm4oYbbsA333xzTIz0hAkT5DGF3ljpfCTceOONWLJkidzv168f5s2bJynF119/fYONVxnpOKKyygNPlQd7iypg+Xo2Ks12DLzycmQ5wiXePo8HJrsdaclOpY/RjNm3b5/842ftwMMPP4wpU6ZEi72qqqpw7bXXokuXLmjfvj38fl5XhbngggukaGzz5s247LLL8Nvf/ha///3v8fHHH0vxGD3G9PR0vPDCC7BGcuqZskpjT02dPn36YOnSpWI416xZg5UrV8pzHAs/584775TPzM3NxXnnnYezzjoLH330kWjwcDzU23n11VeRk5MjdRBt2rSRymF+9osvvnjAiejbb79Fx44d4XSGNWZefvll7N69W+QjeIxXXnkFl19+uRyXc1m8eLEYVn4/rKMYMmRI1HN96KGH5Jaia23btpWx8iRw1113yeP8/HyceuqpuOSSS+R75Pv53V599dUwGo0iAHfPPffg559/xsUXX4ybbrqpzjnz+6XOEOdDxc5Yxo8fL2NuSCPNGGizoKysjPnecpuIuH1+bc/efdrWHbu16Q/+Xfv5xmu0JZ99qRUVlsiWuztP27MnV6vyeI/1UBUNyEMPPaTdd999B+yfPn26PEfmz5+vTZ48We4///zz2u233y73KyoqNLvdHn3PZ599JrfFxcXaiSeeGN1/2WWXaY899ph277331joGHn/kyJFyf+XKlVqXLl20YDAox+nXr5/sf/nll7XbbrtN7rvdbnlNIBDQvv32WxkH4bhmzZoVHf8VV1wh92fOnKndeuutB3zuc889F50LGThwoPbdd9/J/cWLF8vt9u3btc6dO8t4SkpKNIfDIZ/Hx506dZLXzJkzR7vggguixznllFNkHlOnTtXuuOMO2cfXd+vWTcvLy6v2fdb8jMLCwkPO+cILL9Q+/vhj2T9v3jxt9OjR0WO5XC7N6XRqDYnypOMAVvpVutwSb/5owUqcmb8FZR26o//wsOcRkFLtADKzMuCopfO3ouXAuCc9Xr2KV9e/odf4yy+/iCdIXZvCwsLoe+ih0htcsGBBncfVJYPpaVPrnd4l49263g5jx/Ryn3zyyeilfWlp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64YbboiWI7Pwqm3btgk1h3/9619SLJaRkZGQf0dkzZo1eOqpp+RKYPHixdi6dSuCwaBIQyTKHOpD/F7LHGPBp0ThcIWp4ompU6fiz3/+s2i2JOIc3n33Xbz66qsyB15aJ8ocfvjhBzmxjBw5UkIDifp3dP/994tz5fF4JHz22muvHfBv+pdffkGi02KN9KEEnxKFwxWmihc++ugj+f7/8pe/iBeXiHO44oorJDZ99tlnJ9Tv8Omnn4pMw5NPPineKFXYaKATZfw6NNCEcekBAwZg/vz5B/ybjvc51IcWG+6IFXwiFHziP7ZEI1aYihxKmCpePNAdO3aIgea4eT+R5sDGFVygIgzVMGxG9bVEmQMXbun90xPt378/zjrrLFx99dUJM36yYcMGTJs2DToMdZxxxhnye/CqIBHmUF9adMXh559/LjErxhi5op0I2R3MSOEfJzMjrr/+ehGs4qq8LkxVWFgo3W3idVWe3s6ECRMwePBgeczxvvTSS7IanyhzoEFgCXK/fv3EC929e7eEbvLy8hJmDmTGjBl44YUXROKTf0ddunRJmPHv3btXGoaceOKJkonCNQGeeHjyZAiqffv2knVTm+Z8otGijbRCoVDEOy023KFQKBSJgDLSCoVCEccoI61QKBRxjDLSCoVCEccoI61QKBRxjDLSCoVCEccoI61QKBRxjDLSikZh7ty5IqTEikhWdtaEDYlZcPDYY4/JYxYg3HvvvXL/5Zdflue+++477Ny5E+effz7GjBkTfe/o0aOjlXHHCupFXHjhhbjjjjswbtw4KSiKZdGiRTj33HNx5513qq73iqPjWMvwKZov06dP17p3765dd9111fYvX75c69GjhzZ69Ohq0rEFBQXRx3xu/vz5cp+3sa/NycnRAoGAdixZvHixNmLECLnvcrlEdjWWG264QXvttdfkfmlp6TEZo6J5EJ81n4pmA/UhWHJMnQ5qXOie8o033hiVkaS3TI+0pKREvOeD8eGHH+Jvf/sb7rvvPkyZMkUE+O+++26RPOX91q1b49FHHxVPlmX+vXv3FjU0et5UStNV3z755BP897//FbH49evXS5m3XqquQ2U77qcaHOVhqfPCUmmWIT/99NNyhXDrrbeKp3zKKadUG+PChQulQcOqVavE8+d4zzzzTBEA4nMcM0uZP/74YynDzsnJEcnNE044Qd7P11OLgqJHK1askO+HynWfffaZzJPfHWVG9TFWVlbS4ZLt2Wefhclkkv0cK8WU6Om/88471ZTuFAnCsT5LKJq3J00veNKkSVFvml70008/rb344ovVvOOa3vLBPOnJkyfLsclf//pX7dZbb40+N27cOO2NN96Ifj49drfbLZ53+/bttU2bNslz/fv313744Qe5//3332sLFy48YPyvv/66Nn78+Ojjm266SXvwwQdrHVNNYseoC9SzsQSbTGzYsEGbN2+eNnv27KiX/eOPP2pnn312tdePGTNGhOzZjMLhcGjffPONPHfFFVdEmw5wjNdee230fVdeeaX2n//8RysqKtJSUlKiVxwvvfSSVlZWVud4FfGLikkrGh16iPTi6HlSiOjmm29usGPPmTMHI0aMiD4eNWpUNaF3yllSypKeJT1WtrsijCdfcsklMrbMzEzRVj7cYx8ujKtTsIiSuPSqeWXBVmi80uD3smnTpgOUGikSxHHTe9bH0rNnz+g8OEYqwvGqgRvlOfPz85Geni5zp4f//PPPy1x5RaFIPJSRVjQ6vXr1wqWXXiphAV7ON+Uld2wXGxpqhgcI1dEWLFggY6HBfO+995p0LIRqgGPHjhUlOoZw2FWkttfTUNd8rM+DUI7zlVdekY1hHIZSKNn5zTffiPGnah+/95onAUVioIy0okmgx8p46U033dSgx6WBYuskHcZ766MhzKwLNh9+4IEHJG6u60M3xLHrC3WP9VZPjMsfCRzPvHnzoo8p+zpz5kzxtNlait40TwK8CmDsXZF4qIVDRaPAhbu3335b2hm1adMGffr0iRo8enhcHONiFhfieCnOS3JqZNMbJLzPfbzUj32ORo3tn6jhzE7XNLL0HLmAx5AA9YWvueYaMUj8/D179kiIori4OHpM6kCzGwwXHrOzs2XRjguBNeHzDNGwn6HuxVKzmAZVHxM/l53CY3WXOTd9jDwx8UpCD5NQs5njI3wf0w65sMiUPo6RvQdpWPXXM71Pv8+FQBpl/TGvADhGLlBeeeWV8j1zHLfddpvoXPNKgWPlFQRDOjyWIvFQetIKhUIRx6hwh0KhUMQxykgrFApFHKOMtEKhUMQxykgrFApFHKOMtEKhUMQxykgrFApFHKOMtEKhUMQxykgrFApFHKOMtEKhUMQxykgrFAoF4pf/D/dJ/5jsIdImAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 350x216.316 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "# ——————————————————————————————————————————————————————\n",
    "# Now plot Win Rate **vs** Training Time (hours)\n",
    "fig, ax = setup_neurips_plot()\n",
    "\n",
    "for win_df, label, color in zip(\n",
    "    [ldx_win_df, pgx_win_df],\n",
    "    [\"Ludax\", \"PGX\"],\n",
    "    colors[:2]\n",
    "):\n",
    "    # a) compute per-step mean & var of win rate\n",
    "    mean_raw   = win_df.mean(axis=1)\n",
    "    var_raw    = win_df.var(axis=1)\n",
    "    mean_smooth= mean_raw.rolling(window=SMOOTH_WINDOW, min_periods=1, center=True).mean()\n",
    "    std_smooth = np.sqrt(var_raw.rolling(window=SMOOTH_WINDOW, min_periods=1, center=True).mean())\n",
    "\n",
    "    frames = df.index * FRAME_MULTIPLE / 10**6\n",
    "\n",
    "    # c) plot the smoothed mean vs time\n",
    "    ax.plot(frames, mean_smooth, color=color, label=f\"{label} mean (smoothed)\")\n",
    "    \n",
    "    # d) shade ±1σ around it\n",
    "    lower = mean_smooth - std_smooth\n",
    "    upper = mean_smooth + std_smooth\n",
    "    ax.fill_between(frames, lower, upper,\n",
    "                    color=color, alpha=0.07,\n",
    "                    label=f\"  ±1σ\")\n",
    "\n",
    "# PGX baseline\n",
    "ax.axhline(0.5, linestyle=\"--\", color=\"gray\", alpha=1, linewidth=0.8) #\n",
    "\n",
    "# y limit\n",
    "ax.set_ylim(0, 0.7)\n",
    "\n",
    "# labels & legend\n",
    "ax.set_xlabel(\"Millions of frames\")\n",
    "ax.set_ylabel(\"         \")\n",
    "ax.set_title(\"Mean and Variance\")\n",
    "ax.legend(loc=\"lower right\", framealpha=0.9)\n",
    "\n",
    "fig.savefig(\"../data/rl_runs/reversi/reversi_win_mean_frames.pdf\", bbox_inches=\"tight\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "7743c9e6b8a155a2",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-05-15T19:58:18.956395Z",
     "start_time": "2025-05-15T19:58:18.949683Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Ludax time: 2.97 hours\n",
      "PGX time: 2.93 hours\n",
      "Ludax is 1.51% slower than PGX\n"
     ]
    }
   ],
   "source": [
    "ldx_time = (3.0402630150318153 + 2.944597161942057 + 2.935502486427628) / 3\n",
    "pgx_time = (2.9331635726822736 + 2.9284172223011655 + 2.9263961433039767) / 3\n",
    "print(f\"Ludax time: {ldx_time:.2f} hours\")\n",
    "print(f\"PGX time: {pgx_time:.2f} hours\")\n",
    "\n",
    "print(f\"Ludax is {(ldx_time - pgx_time) / pgx_time * 100:.2f}% slower than PGX\")"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 2
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython2",
   "version": "2.7.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
