{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "de5bd59c",
   "metadata": {},
   "outputs": [],
   "source": [
    "import argparse\n",
    "import os\n",
    "from pathlib import Path\n",
    "from typing import Dict, List, Tuple\n",
    "\n",
    "import pandas as pd\n",
    "import seaborn as sns\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib as mpl\n",
    "\n",
    "expnum = 6"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "840ca4d8",
   "metadata": {},
   "outputs": [],
   "source": [
    "file_path = Path(f\"results/exp{expnum}_results.txt\")\n",
    "series: Dict[str, List[float]] = {}\n",
    "with file_path.open('r') as f:\n",
    "    for line in f:\n",
    "        line = line.strip()\n",
    "        if not line:\n",
    "            continue\n",
    "        if ':' not in line:\n",
    "            continue\n",
    "        label, values_str = line.split(':', 1)\n",
    "        label = label.strip()\n",
    "        # Remove potential trailing commas or spaces and split\n",
    "        values = [v.strip() for v in values_str.split(',') if v.strip()]\n",
    "        try:\n",
    "            numbers = [float(v) for v in values]\n",
    "        except ValueError:\n",
    "            # Skip lines that don't parse cleanly\n",
    "            continue\n",
    "        series[label] = numbers"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d12a0b73",
   "metadata": {},
   "outputs": [],
   "source": [
    "skip_step = 200  # number of initial steps to skip\n",
    "\n",
    "# Build long dataframe\n",
    "records = []\n",
    "for algo, nums in series.items():\n",
    "    for i, v in enumerate(nums, start=1):  # steps start at 1\n",
    "        records.append({\n",
    "            'algorithm': algo,\n",
    "            'step': i,\n",
    "            'error_prob': v,\n",
    "        })\n",
    "# skip the first skip_step steps\n",
    "records = [r for r in records if r['step'] > skip_step]\n",
    "df_long = pd.DataFrame.from_records(records)\n",
    "df_long"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7d593815",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Final error per algorithm\n",
    "final_records = []\n",
    "for algo, nums in series.items():\n",
    "    if len(nums) == 0:\n",
    "        continue\n",
    "    final_records.append({\n",
    "        'algorithm': algo,\n",
    "        'final_error': nums[-1]*100,  # convert to percentage\n",
    "    })\n",
    "df_final = pd.DataFrame.from_records(final_records)\n",
    "df_final"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a4bfb850",
   "metadata": {},
   "outputs": [],
   "source": [
    "mpl.rcParams.update({\n",
    "    \"text.usetex\": True,\n",
    "\n",
    "    # IMPORTANT: let LaTeX decide the font (via preamble),\n",
    "    # but keep matplotlib in serif mode\n",
    "    \"font.family\": \"serif\",\n",
    "\n",
    "    # Embed fonts as TrueType (selectable/searchable)\n",
    "    \"pdf.fonttype\": 42,\n",
    "    \"ps.fonttype\": 42,\n",
    "\n",
    "    # Sizes (optional but helps consistency)\n",
    "    \"axes.titlesize\": 18,\n",
    "    \"axes.labelsize\": 12,\n",
    "    \"legend.fontsize\": 12,\n",
    "    \"legend.title_fontsize\": 12,\n",
    "    \"xtick.labelsize\": 12,\n",
    "    \"ytick.labelsize\": 12,\n",
    "        \n",
    "\t# Force Times-like fonts in the LaTeX that matplotlib runs\n",
    "    \"text.latex.preamble\": r\"\"\"\n",
    "        \\usepackage{newtxtext}\n",
    "        \\usepackage{newtxmath}\n",
    "    \"\"\",\n",
    "})\n",
    "palette = [\"#7F7F7F\",\"#3F007D\",\"#6A3D9A\",\"#9C89B8\",\"#0B6623\",\"#2CA02C\",\"#8BC34A\",\"#8B0000\",\"#D62728\",\"#FF8C00\"]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ece12ba3",
   "metadata": {},
   "outputs": [],
   "source": [
    "title = f'Experiment BAI.{expnum} - Error Probability over Time'\n",
    "out_path = Path(f'results/BAI.{expnum}.pdf')\n",
    "algos = ['Uniform', 'UCBE-2', 'UCBE-4', 'UCBE-8', 'UGapE-2', 'UGapE-4', 'UGapE-8', 'VarDE_lse-0.05', 'VarDE_lse-0.1', 'VarDE_lse-0.15']\n",
    "\n",
    "plt.figure(figsize=(9, 4))\n",
    "palette = sns.color_palette(palette, n_colors=len(algos))\n",
    "ax = sns.lineplot(\n",
    "    data=df_long[df_long['algorithm'].isin(algos)],\n",
    "    x='step',\n",
    "    y='error_prob',\n",
    "    hue='algorithm',\n",
    "    palette=palette,\n",
    "    linewidth=2.0,\n",
    "    alpha=1.0,\n",
    ")\n",
    "\n",
    "ax.set_title(title, pad=12)\n",
    "ax.set_xlabel('Number of Samples')\n",
    "ax.set_ylabel('Error Probability')\n",
    "ax.grid(True, which='major', linestyle='--', linewidth=0.5, alpha=1.0)\n",
    "\n",
    "ax.legend(\n",
    "    loc=\"center left\",\n",
    "    bbox_to_anchor=(1.02, 0.5),\n",
    "    framealpha=1.0,\n",
    ")\n",
    "\n",
    "plt.tight_layout(rect=[0, 0, 1, 1])\n",
    "out_path.parent.mkdir(parents=True, exist_ok=True)\n",
    "plt.savefig(out_path)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c8c5ea19",
   "metadata": {},
   "outputs": [],
   "source": [
    "mpl.rcParams.update({\n",
    "    \"text.usetex\": True,\n",
    "\n",
    "    # IMPORTANT: let LaTeX decide the font (via preamble),\n",
    "    # but keep matplotlib in serif mode\n",
    "    \"font.family\": \"serif\",\n",
    "\n",
    "    # Embed fonts as TrueType (selectable/searchable)\n",
    "    \"pdf.fonttype\": 42,\n",
    "    \"ps.fonttype\": 42,\n",
    "\n",
    "    # Sizes (optional but helps consistency)\n",
    "    \"axes.titlesize\": 23,\n",
    "    \"axes.labelsize\": 20,\n",
    "    \"legend.fontsize\": 20,\n",
    "    \"legend.title_fontsize\": 20,\n",
    "    \"xtick.labelsize\": 18,\n",
    "    \"ytick.labelsize\": 18,\n",
    "        \n",
    "\t# Force Times-like fonts in the LaTeX that matplotlib runs\n",
    "    \"text.latex.preamble\": r\"\"\"\n",
    "        \\usepackage{newtxtext}\n",
    "        \\usepackage{newtxmath}\n",
    "    \"\"\",\n",
    "})\n",
    "palette = [\"#1F77B4\",\"#2CA02C\",\"#6A3D9A\",\"#D62728\",\"#FF8C00\"]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "076353ce",
   "metadata": {},
   "outputs": [],
   "source": [
    "title = f'Experiment BAI.{expnum} - Error Probability over Time'\n",
    "out_path = Path(f'results/BAI.{expnum}.pdf')\n",
    "algos = df_long['algorithm'].unique()\n",
    "\n",
    "plt.figure(figsize=(9, 4))\n",
    "ax = sns.lineplot(\n",
    "    data=df_long,\n",
    "    x='step',\n",
    "    y='error_prob',\n",
    "    hue='algorithm',\n",
    "    palette=palette,\n",
    "    linewidth=2.0,\n",
    "    alpha=1.0,\n",
    ")\n",
    "ax.set_title(title, pad=12)\n",
    "ax.set_xlabel('Number of Samples')\n",
    "ax.set_ylabel('Error Probability')\n",
    "ax.grid(True, which='major', linestyle='--', linewidth=0.5, alpha=1.0)\n",
    "\n",
    "ax.legend(loc='upper right', framealpha=1.0)\n",
    "\n",
    "plt.tight_layout()\n",
    "out_path.parent.mkdir(parents=True, exist_ok=True)\n",
    "plt.savefig(out_path)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "dude",
   "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.11.14"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
