{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "df1 = pd.read_csv(\"/home/lhe/Projects/2020-2021/decentralized-robustness/experiments/outputs/exp8_dumbbell_improvement/exp8_1/exp8_1_acc.csv\")\n",
    "df1['NonIID'] = df1['Bucketing'].apply(lambda x: True)\n",
    "\n",
    "df2 = pd.read_csv(\"/home/lhe/Projects/2020-2021/decentralized-robustness/experiments/outputs/exp6_dumbbell/exp6_1/exp6_1_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"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 864x144 with 5 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 = ['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",
    "fig.subplots_adjust(wspace=0.093)\n",
    "\n",
    "fig.savefig(\"../manuscript/figures/exp_ALIE_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
}
