{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "methods = [\"Random Selection\", \"Global Best\", \"MLC (Naive)\", \"Regression (Ours)\", \"MLC (Ours)\", \"PPL (Ours)\"]\n",
    "acc = [62.9, 72.5, 52.1, 79.7, 86.3, 90.8]\n",
    "err = [24.0, 22.7, 23.9, 20.4, 19.9, 20.1]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "\n",
    "# Data\n",
    "methods = [\"Random Selection\", \"Global Best\", \"MLC (Naive)\", \"Regression (Ours)\", \"MLC (Ours)\", \"PPL (Ours)\"]\n",
    "acc = [62.9, 72.5, 52.1, 79.7, 86.3, 90.8]\n",
    "err = [24.0, 22.7, 23.9, 20.4, 19.9, 20.1]\n",
    "\n",
    "fig, ax1 = plt.subplots()\n",
    "\n",
    "# Plotting accuracy\n",
    "ax1.bar(methods, acc, color='b', alpha=0.6, label='Accuracy', width=0.4, align='center')\n",
    "ax1.set_xlabel('Methods')\n",
    "ax1.set_ylabel('Accuracy (%)', color='b')\n",
    "ax1.tick_params(axis='y', labelcolor='b')\n",
    "\n",
    "# Creating another y-axis for error\n",
    "ax2 = ax1.twinx()\n",
    "ax2.bar([x for x in range(len(methods))], err, color='r', alpha=0.6, label='Error', width=0.4, align='edge')\n",
    "ax2.set_ylabel('Error (%)', color='r')\n",
    "ax2.tick_params(axis='y', labelcolor='r')\n",
    "\n",
    "fig.tight_layout()\n",
    "plt.title('Comparison of Methods: Accuracy vs Error')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "plt.figure(figsize=(6, 5))\n",
    "sns.set(font_scale=1.6)\n",
    "sns.set_style(\"whitegrid\")\n",
    "\n",
    "# Data\n",
    "methods = [\"Random\", \"GB\", f\"MLC(*)\", \"Eq. 1\", \"MLC\", \"PPL\"]\n",
    "acc = [62.9, 72.5, 52.1, 79.7, 86.3, 90.8]\n",
    "err = [24.0, 22.7, 23.9, 20.4, 19.9, 20.1]\n",
    "\n",
    "x = np.arange(len(methods))  # the label locations\n",
    "width = 0.35  # the width of the bars\n",
    "\n",
    "fig, ax1 = plt.subplots()\n",
    "\n",
    "# Plotting accuracy\n",
    "bars1 = ax1.bar(x - width/2, acc, width, color='r', alpha=0.75, label='Accuracy')\n",
    "# ax1.set_xlabel('Methods')\n",
    "ax1.set_ylabel('Test 0-1 ACC.', color='r')\n",
    "ax1.tick_params(axis='y', labelcolor='r')\n",
    "\n",
    "# Creating another y-axis for error\n",
    "ax2 = ax1.twinx()\n",
    "bars2 = ax2.bar(x + width/2, err, width, color='b', alpha=0.75, label='Error')\n",
    "ax2.set_ylabel('Test worst-group error', color='b')\n",
    "ax2.tick_params(axis='y', labelcolor='b')\n",
    "\n",
    "# Adding labels and titles\n",
    "ax1.set_xticks(x)\n",
    "# rotate x-axis labels\n",
    "ax1.set_xticklabels(methods, rotation=0, fontsize=16)\n",
    "fig.tight_layout()\n",
    "# plt.title('Comparison of Methods: Accuracy vs Error')\n",
    "\n",
    "# adjust the range of y-axis\n",
    "ax1.set_ylim([40, 95])\n",
    "ax2.set_ylim([15, 25])\n",
    "\n",
    "# shut off grid on y-axis\n",
    "ax1.xaxis.grid(False)\n",
    "ax2.grid(False)\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.savefig('toy_res.pdf', dpi=300)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "div_backup",
   "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.9.18"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
