{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "df2 = pd.read_csv(\"./outputs/exp6_dumbbell/exp6_3_attacks/exp6_3_attacks_acc.csv\")\n",
    "df = df2[df2['Group'] == 'global']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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1fq1116rezwe3ev16jfccIP+9ddf6+PHj9ePHDmi+3w+/eabb9ZXrFih67quX3zxxfqWLVt0Xdf1Rx99VP/ggw/aMPqANWvW6CNHjtQffvhhXdfrj/H222/XFy1apOu6rr/22mv6c8891ybx6rquHzlyRB8zZoyel5ene71efebMmfqKFSs61OvekPZe9nW945d/Ufbbr/Ze/jt62dd1Uf7bUruowVqzZg3nnnsukZGRhISEMHnyZJYsWdLWYQXFxcXxyCOPYDKZMBqNpKenc/jwYdLS0ujcuTMGg4Hp06ezZMkScnJycLvdDB48GIAZM2a0+XMpLy/nxRdf5Ne//jVAvTH6fD42btzI5MmTa93fVr7//numTZtGYmIiRqORF198EavV2mFe98Zo72UfOnb5F2W/fWvv5b8jl30Q5b+ttYsEq7CwkLi4uOD/8fHxFBQUtGFEtfXo0SP45h0+fJjFixcjSVKdMR//XOLi4tr8ufzhD3/g/vvvJzw8HDjx9a6JsaysDJvNhsFgqHV/W8nMzERVVW655RYuvfRSPvzww3rLSnt83RujvZd96NjlX5T99q29l/+OXPZBlP+21i4SLL2Oobgkqe0HEDve/v37ufnmm3n44YdJTU09YbkkSe3uuXz66ackJSUxatSo4H31xdjeYldVlbVr1/L888/zySefsH37drKzs09Yrz3G3lgdKe6OVv5F2W//OkrsHa3sgyj/7UG7GMk9ISGBTZs2Bf8vLCwkPj6+DSM60ebNm7n33nt57LHHuPjii9mwYQPFxcXB5TUxJyQk1Lq/qKioTZ/L4sWLKSoq4rLLLqOiogKn04kkSXXGGB0djd1uR1VVFEVp89hjY2MZNWoU0dHRAEyaNIklS5agKEpwnfb6ujdWRyj70DHLvyj77V9HKP8dseyDKP/tQbuowTrvvPNYu3YtpaWluFwuvvvuO8aNG9fWYQXl5eVx9913M2/ePC6++GIABg0aREZGRrAqc9GiRYwbN47k5GTMZjObN28G4IsvvmjT5/LOO++waNEivvzyS+69914mTpzIM888U2eMRqOR4cOHs3jx4nYR+/nnn8+qVauorKxEVVV++uknpkyZ0iFe98Zq72UfOm75F2W//Wvv5b+jln0Q5b89aDc1WPfffz833HADPp+Pq666ioEDB7Z1WEH/+te/8Hg8PPvss8H7rrvuOp599lnuuecePB4P48ePZ8qUKQDMmzePuXPn4nA46Nu3LzfccENbhV6v+mJ84okneOSRR/j73/9OUlISL7zwQpvFOGjQIG699VZmzZqFz+dj9OjRzJw5k27dunXY1/147b3sw5lX/kXZbz/ae/k/08o+iPJ/Oom5CAVBEARBEFpYu2giFARBEARBOJOIBEsQBEEQBKGFiQRLEARBEAShhYkESxAEQRAEoYWJBEsQBEEQBKGFiQSrnZk4cSLbt2/ntddeY9myZS2675tvvpnS0lIAbrvtNg4cONCi+xeE5hBlXzibifJ/5mkX42AJJ1q/fj3du3dv0X2uXr06ePvtt99u0X0LQksRZV84m4nyf+YQCVY7tHLlSnbs2MFzzz2HoiiMHz+eefPmsXHjRlRVpW/fvsydOxebzcbEiRMZOHAge/fu5YEHHsBgMPDmm2/i9XopLS3l8ssv57777uPRRx8F4MYbb+Stt97iV7/6FS+//DIDBgzg448/5v3330eWZWJjY3n88cfp2rUrjzzyCDabjb1795Kfn0+3bt144YUXCA0N5ZVXXuH777/HaDQSFRXFM888026mJxA6LlH2hbOZKP9nGF1oV84//3x927Zt+vXXX69/++23uq7r+quvvqo/++yzuqZpuq7r+t/+9jf9iSeeCK7/2muv6bqu65qm6ddff72ekZGh67qu5+fn63369NFLSkp0Xdf1nj17Bm/XPM6aNWv0Cy64IHj/woUL9alTp+qapukPP/ywfu211+oej0f3er365Zdfri9YsEDPzc3Vhw4dqns8Hl3Xdf1f//qX/v3335+W10c4c4myL5zNRPk/84garA5gxYoVVFVVsWbNGgB8Ph8xMTHB5cOHDwcCM4j/4x//YMWKFSxatIiDBw+i6zoul6veff/0009MmzYtOKnmjBkzeOqpp4Izl48dOxaTyQRAz549qaioICEhgd69e3PFFVcwbtw4xo0bV2vGdkFoKaLsC2czUf47NpFgdQCapvHYY48xfvx4ABwOBx6PJ7g8JCQEAKfTyRVXXMEFF1zA8OHDufLKK1m2bBn6SWZDqmuZruv4/X4ALBZL8H5JktB1HVmW+e9//8v27dtZu3YtTz/9NCNHjmTu3Lkt8nwFoYYo+8LZTJT/jk30ImynFEUJFvQxY8bwwQcf4PV60TSNxx9/vM6JODMzM7Hb7dx3331MnDiRDRs2BLc5fp81xowZw+LFi4M9TBYuXEhkZCRpaWn1xrZnzx4uueQS0tPTueOOO5gzZw579+5tqacunOVE2RfOZqL8nzlEDVY7df755/PXv/4Vn8/HXXfdxV//+leuuOIKVFWlT58+PPLIIyds06tXLyZMmMDUqVMJDw8nNTWV7t27k5mZSWpqKhdeeCGzZs3ijTfeCG4zevRo5syZw4033oimaURHR/Pmm28iy/Xn3r1792bq1KlceeWVhISEYLFYxBGM0GJE2RfOZqL8nzkk/WR1iIIgCIIgCMIpE02EgiAIgiAILUwkWIIgCIIgCC1MJFiCIAiCIAgtTCRYgiAIgiAILUwkWIIgCIIgCC1MJFiCIAiCIAgtTCRYgiAIgiAILUwkWIIgCIIgCC3s/wEOhme2eDJMagAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 720x144 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "\n",
    "plt.rcParams[\"font.family\"] = \"Times New Roman\"\n",
    "plt.rcParams[\"font.size\"] = 2\n",
    "plt.rcParams[\"legend.columnspacing\"] = 0.5\n",
    "plt.rcParams[\"legend.handlelength\"] = 1\n",
    "plt.rcParams[\"legend.borderaxespad\"] = 0\n",
    "plt.rcParams[\"legend.labelspacing\"] = 0.1\n",
    "plt.rcParams[\"legend.frameon\"] = False\n",
    "\n",
    "\n",
    "sns.set()\n",
    "aggregators = [\n",
    "    r\"$\\tau=0.1$\", r\"$\\tau=0.5$\", r\"$\\tau=1$\", r\"$\\tau=2$\", r\"$\\tau=10$\", \"Adaptive\"\n",
    "]\n",
    "colors = sns.color_palette()[:len(aggregators)]\n",
    "\n",
    "# fig, axes = plt.subplots(nrows=3, ncols=3, figsize=(12, 6), sharey=True)\n",
    "\n",
    "# # for i, group in enumerate(['global', 'clique 1', 'clique 2']):\n",
    "# for i, group in enumerate(['global']):\n",
    "#     df = df2[df2['Group'] == group]\n",
    "#     def plot_attacks(df, ax, title, legend=False):\n",
    "#         for agg, c in zip(aggregators, colors):\n",
    "#             _df = df[df['Agg'] == agg]\n",
    "#             ax.plot(_df['Iterations'], _df['Accuracy (%)'], color=c, label=agg)\n",
    "\n",
    "#         if legend:\n",
    "#             ax.legend(loc='lower left', bbox_to_anchor=[0.1, 0.])\n",
    "#         ax.set_xlim(0, 750)\n",
    "#         ax.set_xlabel(\"Iterations\")\n",
    "#         ax.set_title(title)\n",
    "\n",
    "#     plot_attacks(df[df['Attack'] == 'BF'], axes[i][0], title=f\"Bit-Flipping | {group}\")\n",
    "#     plot_attacks(df[df['Attack'] == 'LF'], axes[i][1], title=f\"Label-Flipping | {group}\")\n",
    "#     plot_attacks(df[df['Attack'] == 'ALIE'], axes[i][2], title=f\"ALIE | {group}\", legend=(i == 0))\n",
    "\n",
    "# axes[0][0].set_ylim(45, 100)\n",
    "# axes[0][0].set_yticks([50, 60, 70, 80, 90, 100])\n",
    "# axes[0][0].set_ylabel('Accuracy (%)', labelpad=-2)\n",
    "# for i in range(3):\n",
    "#     axes[0][i].tick_params(axis='y', which='major', pad=-4)\n",
    "#     axes[0][i].tick_params(axis='x', which='major', pad=-2)\n",
    "\n",
    "# fig.subplots_adjust(wspace=0.093, hspace=0.6)\n",
    "\n",
    "# fig.savefig(\"../manuscript/figures/tuning_tau.pdf\", bbox_inches=\"tight\", dpi=720)\n",
    "\n",
    "\n",
    "fig, axes = plt.subplots(nrows=1, ncols=3, figsize=(10, 2), sharey=True)\n",
    "\n",
    "# for i, group in enumerate(['global', 'clique 1', 'clique 2']):\n",
    "for i, group in enumerate(['global']):\n",
    "    df = df2[df2['Group'] == group]\n",
    "    def plot_attacks(df, ax, title, legend=False):\n",
    "        for agg, c in zip(aggregators, colors):\n",
    "            _df = df[df['Agg'] == agg]\n",
    "            if agg == 'Adaptive':\n",
    "                ax.plot(_df['Iterations'], _df['Accuracy (%)'], color=c, label=agg, marker=\"*\")\n",
    "            else:\n",
    "                ax.plot(_df['Iterations'], _df['Accuracy (%)'], color=c, label=agg)\n",
    "\n",
    "        if legend:\n",
    "            ax.legend(loc='lower left', bbox_to_anchor=[0.1, 0.])\n",
    "        ax.set_xlim(0, 750)\n",
    "        ax.set_xlabel(\"Iterations\")\n",
    "        ax.set_title(title)\n",
    "\n",
    "    plot_attacks(df[df['Attack'] == 'BF'], axes[0], title=f\"Bit-Flipping\")\n",
    "    plot_attacks(df[df['Attack'] == 'LF'], axes[1], title=f\"Label-Flipping\")\n",
    "    plot_attacks(df[df['Attack'] == 'ALIE'], axes[2], title=f\"ALIE\", legend=(i == 0))\n",
    "\n",
    "axes[0].set_ylim(45, 100)\n",
    "axes[0].set_yticks([50, 60, 70, 80, 90, 100])\n",
    "axes[0].set_ylabel('Accuracy (%)', labelpad=-2)\n",
    "for i in range(3):\n",
    "    axes[i].tick_params(axis='y', which='major', pad=-4)\n",
    "    axes[i].tick_params(axis='x', which='major', pad=-2)\n",
    "\n",
    "fig.subplots_adjust(wspace=0.093, hspace=0.6)\n",
    "\n",
    "fig.savefig(\"../manuscript/figures/tuning_tau.pdf\", bbox_inches=\"tight\", dpi=720)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "interpreter": {
   "hash": "d55a7d355c2d2bc0905cf312cf31c7bd25efc90d5ad78f8099868776121b8193"
  },
  "kernelspec": {
   "display_name": "Python 3.8.5 64-bit ('base': conda)",
   "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.8.5"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
