{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "54d28ffc",
   "metadata": {},
   "outputs": [],
   "source": [
    "import csv\n",
    "import math\n",
    "import os\n",
    "\n",
    "import matplotlib as mpl\n",
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "41e7e568",
   "metadata": {},
   "outputs": [],
   "source": [
    "path = \"results_stree.csv\"  # single input file\n",
    "outdir = \"plots\"\n",
    "title = \"Experiment MCTS.4 - Synthetic Tree\"  # optional title override"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2135a053",
   "metadata": {},
   "outputs": [],
   "source": [
    "mpl.rcParams.update({\n",
    "    \"text.usetex\": True,\n",
    "    \"font.family\": \"serif\",\n",
    "\n",
    "    # Embed fonts as TrueType (selectable/searchable)\n",
    "    \"pdf.fonttype\": 42,\n",
    "    \"ps.fonttype\": 42,\n",
    "\n",
    "    # sizes (tune if you want)\n",
    "    \"axes.titlesize\": 23,\n",
    "    \"axes.labelsize\": 18,\n",
    "    \"legend.fontsize\": 14,\n",
    "    \"legend.title_fontsize\": 14,\n",
    "    \"xtick.labelsize\": 18,\n",
    "    \"ytick.labelsize\": 18,\n",
    "\n",
    "    # Times-like fonts, matching paper\n",
    "    \"text.latex.preamble\": r\"\"\"\n",
    "        \\usepackage{newtxtext}\n",
    "        \\usepackage{newtxmath}\n",
    "    \"\"\",\n",
    "})"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "884c9f33",
   "metadata": {},
   "outputs": [],
   "source": [
    "rows = []\n",
    "with open(path, \"r\", newline=\"\") as f:\n",
    "    reader = csv.DictReader(f)\n",
    "    required = {\"env\", \"algorithm\", \"run\", \"trial\", \"mc_mean\", \"mc_stddev\"}\n",
    "    missing = required - set(reader.fieldnames or [])\n",
    "    if missing:\n",
    "        raise ValueError(f\"{path}: missing columns: {missing}\")\n",
    "    for r in reader:\n",
    "        rows.append({\n",
    "            \"env\": r[\"env\"],\n",
    "            \"algorithm\": r[\"algorithm\"],\n",
    "            \"run\": int(r[\"run\"]),\n",
    "            \"trial\": int(r[\"trial\"]),\n",
    "            \"mc_mean\": float(r[\"mc_mean\"]),\n",
    "            \"mc_stddev\": float(r[\"mc_stddev\"]),\n",
    "        })"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4c8069c1",
   "metadata": {},
   "outputs": [],
   "source": [
    "algos = [\"UCT\", \"MENTS\", \"RENTS\", \"TENTS\", \"DENTS\", \"BTS\", \"VarDE\"]\n",
    "colors = [\"#1f77b4\", \"#d62728\", \"#9467bd\", \"#8c564b\", \"#ff27be\", \"#ff7f0e\", \"#2ca02c\"]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9f7aa76d",
   "metadata": {},
   "outputs": [],
   "source": [
    "os.makedirs(outdir, exist_ok=True)\n",
    "outputs = []\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(9, 4))\n",
    "\n",
    "for alg in algos:\n",
    "    trials = sorted(set(r[\"trial\"] for r in rows if r[\"algorithm\"] == alg))\n",
    "    xs = [t / 1000.0 for t in trials]  # paper uses x1000\n",
    "\n",
    "    ys = []\n",
    "    yerr = []\n",
    "    for t in trials:\n",
    "        rows_t = [r for r in rows if r[\"algorithm\"] == alg and r[\"trial\"] == t]\n",
    "        means = [rr[\"mc_mean\"] for rr in rows_t]\n",
    "        if len(means) >= 2:\n",
    "            m = sum(means) / len(means)\n",
    "            s = math.sqrt(sum((x - m) ** 2 for x in means) / (len(means) - 1))\n",
    "            ys.append(m)\n",
    "            yerr.append(s)\n",
    "        else:\n",
    "            ys.append(rows_t[0][\"mc_mean\"])\n",
    "            yerr.append(rows_t[0][\"mc_stddev\"])\n",
    "\n",
    "    color = colors.pop(0) if colors else None\n",
    "    label = alg\n",
    "    ax.plot(xs, ys, linewidth=2.0, label=label, color=color)\n",
    "\n",
    "    lower = [y - e for y, e in zip(ys, yerr)]\n",
    "    upper = [y + e for y, e in zip(ys, yerr)]\n",
    "    ax.fill_between(xs, lower, upper, alpha=0.15, color=color)\n",
    "\n",
    "ax.set_xlabel(\"Number of trials (x1000)\")\n",
    "ax.set_ylabel(\"Monte-Carlo value estimate\")\n",
    "\n",
    "ax.set_title(title)\n",
    "\n",
    "ax.grid(True, linestyle=\"--\", linewidth=0.5)\n",
    "ax.legend(loc=\"lower right\", frameon=True, framealpha=0.8)\n",
    "\n",
    "out_path = os.path.join(outdir, f\"{rows[0]['env']}.pdf\")\n",
    "fig.tight_layout()\n",
    "fig.savefig(out_path)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "varde",
   "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
}
