{
 "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_mixed\"\n",
    "\n",
    "df = pd.read_csv(f\"../results/{FILENAME}.csv\")\n",
    "# Columns are: \"ratios\", \"alpha\", \"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([\"ratios\", \"alpha\", \"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": [
    "# Plot a graph for each ratio\n",
    "# There should be a line for each alpha value\n",
    "# The graph should n against sw_mean_ratio\n",
    "# Only plot the esp_mixed_best mechanism\n",
    "\n",
    "SAVE = True\n",
    "\n",
    "ratios = df[\"ratios\"].unique()\n",
    "alphas = df[\"alpha\"].unique()\n",
    "n_values = df[\"n\"].unique()\n",
    "\n",
    "for ratio in ratios:\n",
    "    plt.figure(figsize=(4, 4))\n",
    "    for alpha in alphas:\n",
    "        mask = (df[\"ratios\"] == ratio) & (df[\"alpha\"] == alpha)\n",
    "        # Just plot the mechanism, don't show errors for now\n",
    "        mask = mask & (df[\"mech\"] == \"esp_mixed_best\")\n",
    "        plt.plot(n_values, df[mask][\"sw_mean_ratio\"], label=f\"$\\\\alpha$ = {alpha}\",)\n",
    "        ax = plt.gca()\n",
    "        ax.fill_between(n_values, df[mask][\"sw_ci_lower\"], df[mask][\"sw_ci_upper\"], alpha=0.3)\n",
    "    # Add a reference line at y=4/3\n",
    "    # plt.axhline(y=4/3, color=\"red\", linestyle=\"--\")\n",
    "        \n",
    "\n",
    "    plt.title(f\"$\\\\Lambda = {ratio}$\", fontsize=14)\n",
    "    plt.xlabel(\"Number of Agents\", fontsize=12)\n",
    "    plt.ylabel(\"Bayesian Approximation Ratio\", fontsize=12)\n",
    "    plt.legend(loc=\"lower right\")\n",
    "    if SAVE:\n",
    "        plt.savefig(f\"../results/figures/test_1/{FILENAME}_{ratio}.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
}
