{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "import scipy.stats as stats\n",
    "\n",
    "FILENAME = \"equal_symmetric\"\n",
    "\n",
    "DIST_LABEL = {\n",
    "    \"uniform\": \"Uniform\",\n",
    "    \"triangle_sym\": \"Symm. Triangular\",\n",
    "    \"triangle_asym\": \"Asymm. Triangular\",\n",
    "    \"beta_sym\": \"Symm. Beta\",\n",
    "    \"beta_asym\": \"Asymm. Beta\",\n",
    "}\n",
    "\n",
    "MECH_LABEL = {\n",
    "    \"opt\": \"Optimal\",\n",
    "    \"esp_sym_worst\": \"ESP (0, 1)\",\n",
    "    \"esp_sym_best\": \"ESP (Best)\",\n",
    "}\n",
    "\n",
    "df = pd.read_csv(f\"../results/{FILENAME}.csv\")\n",
    "# Columns are: \"k_val\", \"dist\", \"n\", \"mech\", \"sw_mean\", \"sw_std\"\n",
    "df.head()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "CONFIDENCE = 0.95\n",
    "Z_SCORE = stats.norm.ppf((1 + CONFIDENCE) / 2)\n",
    "N_TRIALS = 500\n",
    "\n",
    "opt_mask = df[\"mech\"] == \"opt\"\n",
    "df[\"sw_mean_ratio\"] = 1.0\n",
    "opt_mean = df.groupby([\"k_val\", \"dist\", \"n\"])[\"sw_mean\"].transform(\"max\")\n",
    "df[\"sw_mean_ratio\"] = opt_mean / df[\"sw_mean\"]\n",
    "\n",
    "# We probably need to manually calculate the upper and lower bounds\n",
    "ci = Z_SCORE * df[\"sw_std\"] / np.sqrt(N_TRIALS)\n",
    "df[\"sw_ci_lower\"] = opt_mean / (df[\"sw_mean\"] - ci)\n",
    "df[\"sw_ci_upper\"] = opt_mean / (df[\"sw_mean\"] + ci)\n",
    "\n",
    "\n",
    "df.head(10)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "def plot_k_dist(df, k_val, dist, ax):\n",
    "    df = df.loc[df[\"k_val\"] == k_val].loc[df[\"dist\"] == dist]\n",
    "    lines = []\n",
    "    for mech in df[\"mech\"].unique():\n",
    "        if mech == \"opt\":\n",
    "            continue\n",
    "        df_mech = df.loc[df[\"mech\"] == mech]\n",
    "        lines.append(ax.plot(df_mech[\"n\"], df_mech[\"sw_mean_ratio\"], label=mech)[0])\n",
    "        ax.fill_between(df_mech[\"n\"], df_mech[\"sw_ci_lower\"], df_mech[\"sw_ci_upper\"], alpha=0.4)\n",
    "        # plt.title(f\"{DIST_LABEL[dist]}, $k_1 > k_2$, $\\\\alpha = {k_val}$\", fontsize=12)\n",
    "        plt.title(f\"$\\\\alpha={k_val}$\", fontsize=14)\n",
    "    plt.legend(loc=\"upper left\", handles=lines, labels=LABELS)\n",
    "\n",
    "SAVE = True\n",
    "LABELS = [\"ESP (0, 1)\", \"ESP (Best)\"]\n",
    "\n",
    "for dist in df[\"dist\"].unique():\n",
    "    for i, k_val in enumerate(df[\"k_val\"].unique()):\n",
    "        plt.figure(figsize=(4, 4))\n",
    "        plot_k_dist(df, k_val, dist, plt.gca())\n",
    "        plt.ylim(1, 1.3)\n",
    "        plt.xlabel(\"Number of Agents\", fontsize=12)\n",
    "        plt.ylabel(\"Bayesian Approximation Ratio\", fontsize=12)\n",
    "        if SAVE:\n",
    "            plt.savefig(f\"../results/figures/test_2/{FILENAME}_{dist}_{k_val}_plot.pdf\", format=\"pdf\", bbox_inches=\"tight\")"
   ]
  }
 ],
 "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.10.8"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
