{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "df1 = pd.read_csv(\"./outputs/exp8_dumbbell_improvement/exp8_2_attacks/exp8_2_attacks_acc.csv\")\n",
    "df1['NonIID'] = df1['Bucketing'].apply(lambda x: True)\n",
    "\n",
    "df2 = pd.read_csv(\"./outputs/exp6_dumbbell/exp6_1_attacks/exp6_1_attacks_acc.csv\")\n",
    "df2['Bucketing'] = df2['Agg'].apply(lambda x: False)\n",
    "df2['RandomEdge'] = df2['Agg'].apply(lambda x: False)\n",
    "df2 = df2[~df2['NonIID']]\n",
    "\n",
    "df = pd.concat([df1, df2])\n",
    "df = df[df['Group'] == 'clique 1']\n",
    "\n",
    "df['Agg'] = df['Agg'].apply(lambda x: 'Ideal Comm.' if x == 'Gossip' else x)\n",
    "df['Agg'] = df['Agg'].apply(lambda x: 'ClippedGossip' if x == 'SCClip' else x)\n",
    "\n",
    "# Limit Ourselves to one attack\n",
    "df = df[df['Attack'] == 'ALIE']\n",
    "# df = df[df['Attack'] == 'BF']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAtEAAAClCAYAAACa5aH5AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8QVMy6AAAACXBIWXMAAAsTAAALEwEAmpwYAAB0jklEQVR4nO3dd3wUdf748dfM1mx67w1IoXeULggKCCigZ0PErmc5O56HX73Ts516v7MfnhW7YlcQKyIg0jskJCGk97Z9d2Z+f2wSQAgQSIXP8+GasDvlPTPvzL539jOfj6RpmoYgCIIgCIIgCMdN7uwABEEQBEEQBKG7EUW0IAiCIAiCILSSKKIFQRAEQRAEoZVEES0IgiAIgiAIrSSKaEEQBEEQBEFoJVFEC4IgCIIgCEIr6Ts7gNPJxIkT+c9//sM777xDWloa11xzDffddx+rVq0iLCwMAI/HQ+/evbnvvvuIjIzs5IiFtlBYWMjZZ5/NI488wkUXXdT8/Kuvvkp2djaPP/74CS03IyODNWvWEBYWxhVXXMHll1/OlClTuOKKKygqKiIwMBDw5dTw4cO55557CAgIaJNtEg7XXscZOv5Yf/LJJ/zzn/8kISEBTdPwer0kJiby8MMPExUVdcLLPZ2dSvmxdu1arrvuOlJTU5ufs9ls9OrVi8cee4zQ0NATXvap4lQ63h1xPigsLGTy5Mmkp6c3P2e324mJieHRRx8lMTGxTdbT1sSV6C5g/vz5fP7553z++ed8/fXXpKWlce2116IoSmeHJrQRWZZ54oknyMvL65D13Xvvvc059fnnnwNw9913d8i6T2cdfZyh/Y71sGHD+Pzzz/niiy/45ptviI2N5dlnnz3p5Z7OTqX8SEpKOmS53377LbIs89prr530sk8Vp9Lx7ojzgdlsPiT25cuXk56ezr///e82XU9bEkV0FyNJEjfeeCNOp5NVq1Z1djhCGzGbzVx11VXcdddduN3uQ15raGjg7rvvZvr06cyYMYMnn3wSr9cLQP/+/Xnuuee45JJLmDhxIm+88Uar120wGPjrX//KunXryMnJaYvNEVpwtOMMXedY33fffXzyySfHvVyPx4PVahXfjp2kUzU/AKxWK9XV1QQHB7c6rlPVqXq8T+R88Nxzz/Hcc88d9/QALpeLioqKLp1ToojuojIyMsjKyursMIQ2dNNNN+Hn53fYp+pHHnmEkJAQvvzyS5YsWcKePXuar+a43W5CQ0N5//33efbZZ3n66adxuVytXrfZbCYlJeWUyakpU6Z0dggtauk4Q/c61uvXr+f8889n5syZjBkzht9//50LL7zwpJYpnDr5sX//fs4//3ymT5/OyJEjmT9/PhMnTuTKK688qeWeak6V490R5wOn08n555/PjBkzGDVqFLNmzSI1NbVLf4sq2kR3UZIk4efn19lhCG1IlmX+9a9/MWvWLMaMGdP8/C+//MJ7772HJEkYjUYuueQS3nzzTa6//noAzj77bAD69u2L2+3GbrdjMplavf5TKae2bdvW2SG0qKXjDJ1/rC+66CLcbjclJSX89ttvvPnmmwwZMoQHH3zwsGmHDRvGf//7XwBUVeWtt97i2muv5ZtvvkGSpFbHJPicKvnR1JwDYMmSJfz73//m7LPPxmAwtDqeU9mpcrxP9Hxw8803U1hYSGVlJQDff/89CQkJvPDCC4dN29ScA2DlypXcc889jB49Gn9//1Zvc0cRRXQXpGkaO3bsYO7cuZ0ditDG4uLieOihh1iwYAEXXHAB4DshHUxV1eav9IDmk2bTiUrTtFav1+FwkJOTQ1pa2glGLrTGkY4zdP6x/uijjwDf17cjRoxg9uzZx7VMWZa5+OKLeeyxx6iqqiIiIqLVcQkHnGr5MWfOHLZs2cKdd97JkiVL0OtFaXGwU+14t+Z80FQsNzXluPXWW49rHWPHjuWqq67izjvvZOnSpc03S3Y1ojlHF6MoCi+88AKhoaEMHz68s8MR2sHUqVMZN24cb775JgBjxozhnXfeQdM03G43H374IaNGjWqz9TmdTh599FHGjRtHfHx8my23M0VHR3d2CMf0x+MM3ftYf/fdd8THxzf3JCScnFMtP+666y7Ky8t5++2323S5p4pT7Xh3xPng6quvJigoqEvf0Cw+LnYBb7zxBl988QWSJKEoCv3792fRokWdHZbQjhYuXMiGDRuaf3/kkUeYMWMGHo+HsWPHcuONN57U8p988kleeuklZFnG6/UyatQo/va3v7VF6F3Cxo0bOzuE43LwcW76d1c41sfTvVZTG0hJkvB6vYSEhPDCCy8gyzJlZWVcf/31LFq0qFt8oOmqunN+/FFwcDB33303jz32GNOnT2fLli28//77vPLKKyca+imnOx/vkz0fHO8V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",
      "text/plain": [
       "<Figure size 864x144 with 5 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "from matplotlib.collections import LineCollection\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 = ['ClippedGossip', 'GM', 'MOZI', 'TM', 'Ideal Comm.']\n",
    "colors = sns.color_palette()[:len(aggregators)]\n",
    "\n",
    "fig, axes = plt.subplots(nrows=1, ncols=5, figsize=(12, 2), sharey=True)\n",
    "\n",
    "def plot_iid(df, ax):\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",
    "    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(\"IID\")\n",
    "\n",
    "plot_iid(df[~df['NonIID']], axes[0])\n",
    "\n",
    "def plot_noniid(df, ax):\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",
    "    ax.set_xlim(0, 750)\n",
    "    ax.set_xlabel(\"Iterations\")\n",
    "    ax.set_title(\"NonIID\")\n",
    "\n",
    "plot_noniid(df[(df['NonIID']) & (~df['Bucketing']) & (~df['RandomEdge'])], axes[1])\n",
    "\n",
    "def plot_bucketing(df, ax):\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",
    "    ax.set_xlim(0, 750)\n",
    "    ax.set_xlabel(\"Iterations\")\n",
    "    ax.set_title(\"NonIID + B.\")\n",
    "\n",
    "plot_bucketing(df[(df['NonIID']) & (df['Bucketing']) & (~df['RandomEdge'])], axes[2])\n",
    "\n",
    "def plot_edge(df, ax):\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",
    "    ax.set_xlim(0, 750)\n",
    "    ax.set_xlabel(\"Iterations\")\n",
    "    ax.set_title(\"NonIID + R.\")\n",
    "\n",
    "plot_edge(df[(df['NonIID']) & (~df['Bucketing']) & (df['RandomEdge'])], axes[3])\n",
    "\n",
    "\n",
    "def plot_both(df, ax):\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",
    "    ax.set_xlim(0, 750)\n",
    "    ax.set_xlabel(\"Iterations\")\n",
    "    ax.set_title(\"NonIID + B. + R.\")\n",
    "\n",
    "plot_both(df[(df['NonIID']) & (df['Bucketing']) & (df['RandomEdge'])], axes[4])\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(5):\n",
    "    axes[i].tick_params(axis='y', which='major', pad=-4)\n",
    "    axes[i].tick_params(axis='x', which='major', pad=-2)\n",
    "\n",
    "# Add separation line\n",
    "l1 = [(785, 45), (785, 106)]\n",
    "lc = LineCollection([l1], color=[\"k\",\"blue\"], lw=1, ls='--' )\n",
    "lc.set_clip_on(False)\n",
    "axes[1].add_collection(lc)\n",
    "\n",
    "fig.subplots_adjust(wspace=0.093)\n",
    "\n",
    "fig.savefig(\"../manuscript/figures/exp_acc.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
}
