{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a03eb6a2",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import torch\n",
    "import matplotlib.pyplot as plt\n",
    "import csv\n",
    "import os\n",
    "from os import listdir\n",
    "from numpy import genfromtxt\n",
    "plt.rcParams.update({'font.size': 12})"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7c22bfcf",
   "metadata": {},
   "outputs": [],
   "source": [
    "tab_attack = ['SF', 'FOE', 'ALIE', 'mimic']\n",
    "tab_attack_name = ['SF', 'FOE', 'ALIE', 'Mimic']\n",
    "tab_sign = ['-', '--', '-.', ':']\n",
    "markers = ['^','s', '<', 'o']\n",
    "\n",
    "\n",
    "colors = [ (0, 0.4470, 0.7410), (0.8500, 0.3250, 0.0980), (0.4660, 0.6740, 0.1880), (120/255,120/255, 120/255)]\n",
    "\n",
    "nb_runs = 10\n",
    "tab_acc = np.zeros((len(tab_attack), nb_runs, 500))\n",
    "\n",
    "for i, attack in enumerate(tab_attack):\n",
    "    for run in range(nb_runs):\n",
    "        folder_name = './save_fig4/T_500_n_150_f_15_n_sampled_26_server_lr_1_workers_lr_0.1_milestones_[300, 400, 460]_gamma_0.2_attack_'+attack+'_agg_trmean_batch_size_8_nb_local_steps_[5,10,15,20,25,30,35]_device_cuda_nb_run_5_seed_1'\n",
    "        tab_acc[i][run] = genfromtxt(\"./\"+folder_name+\"/data/Accuracies_\"+str(run)+\".csv\", delimiter=',')\n",
    "\n",
    "err = np.zeros((len(tab_attack), 500))\n",
    "for i in range(len(err)):\n",
    "    err[i] = 1.96*np.std(tab_acc[i], axis = 0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d9fd70ee",
   "metadata": {},
   "outputs": [],
   "source": [
    "for i, attack in enumerate(tab_attack_name):\n",
    "    plt.plot(np.arange(500), np.mean(tab_acc[i], axis = 0), label = attack, color = colors[i], linestyle = tab_sign[i], marker = markers[i], markevery = 50)\n",
    "    plt.fill_between(np.arange(500), np.mean(tab_acc[i], axis = 0) - err[i], np.mean(tab_acc[i], axis = 0) + err[i], alpha = 0.25)\n",
    "    \n",
    "plt.xlabel('Number of local steps')\n",
    "plt.ylabel('Accuracy')\n",
    "plt.xlim(0,500)\n",
    "\n",
    "plt.ylim(0,85)\n",
    "plt.grid()\n",
    "plt.legend()\n",
    "plt.savefig('fig4.pdf')"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.13"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
