{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "da8d7804-224e-4be9-936a-3d08e2fe0b08",
   "metadata": {},
   "outputs": [],
   "source": [
    "import argparse\n",
    "import client\n",
    "import config\n",
    "import logging\n",
    "import os\n",
    "import server\n",
    "from matplotlib import pyplot as plt\n",
    "import numpy as np"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "36c5223c-2a5c-4342-8f28-6e852cebada2",
   "metadata": {},
   "outputs": [],
   "source": [
    "### Sync-ST ###"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "53433ef9-2f5f-47b4-b37f-368e5afb4fe5",
   "metadata": {},
   "outputs": [],
   "source": [
    "parser = argparse.ArgumentParser()\n",
    "parser.add_argument('-c', '--config', type=str, default='./configFiles/sync_het_demo.json',\n",
    "                    help='Federated learning configuration file.')\n",
    "parser.add_argument('-l', '--log', type=str, default='INFO',\n",
    "                    help='Log messages level.')\n",
    "args = parser.parse_args([])\n",
    "# Set logging\n",
    "logging.basicConfig(\n",
    "    format='[%(levelname)s][%(asctime)s]: %(message)s', level=getattr(logging, args.log.upper()), datefmt='%H:%M:%S')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1426319f-e9e5-4672-9827-d5184772ac5e",
   "metadata": {},
   "outputs": [],
   "source": [
    "fl_config = config.Config(args.config)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8fd7cd15-1c5f-422b-987e-4d4b5f6955f3",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "# Initialize server\n",
    "fl_server = server.Server(fl_config)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "00fae31a-4add-4b28-8057-a86016abe4ac",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "fl_server.boot()\n",
    "fl_server.train()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "63064ed3-efda-4186-a26e-de2488d1cbcb",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0, 0.5, 'Test Accuracy')"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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ly5Qv77rmpYDAiTfy5aV7paBvr7SnD9njjy/QGrif//9N/Pnz2f9+vVs3ryZZcuWZdh8pLyz1pKSUnLLnWgQL0ahoembmNx6q4ytWbgw+7Spg9qUKhOmT5em5rvuksVJ8vLRR9KXPWGC9B+dPp01zXvvSc32yy+lNu60zjXWyg+Adu1ksZKc+PtLMH3lFQngPj4F/WSF07ChDIorbW3apI9Mv0CC+KFDh/D398fLywsAf3//tHXKp02bRufOnWnfvj07duwAZJvQ3r1706lTJ3r37p3tIi4LFiygV69eHD9+nCVLltCrVy86d+7MNddcQ2xsLACTJ0+mTZs2dOjQgUmTJgFwyy23cM8999C3b19atGiRtuFKcnIyjz76KN26daNDhw589NFHgKxDMHDgwLQ8zp07F5AV5Vq3bs29995L586diYyM5LXXXkt7/bPPPuuy8tQgXkyOHZPxOKlBfNgw+UGfXcXm0CFJq/3hqkzYvVt2zRo0SGqe118vQTkmRn5t7tolu26lCguTvujBg+GNN6S23Lmz9GtfdBH07SsB/uuvpSl81ChZpnTatPRa+9q10nT1n//kXaNu2FCa00sqgJclqf3ibm6yScoFYMiQIRw4cIAWLVpw7733smLFirRz/v7+rF+/nv/85z+8/vrrALRq1YqVK1eyYcMGpkyZwpNPPpnhenPmzOHll19moaPG9MILL7Bs2TLWr19P165defPNNzl58iRz5sxh69atbN68maeffjrt9eHh4axYsYIFCxZwzz33EB8fz2effYafnx9r165l7dq1fPLJJ+zbtw9vb2/mzJnD+vXrWb58OY888kjaDmg7d+7k5ptvZsOGDYSFhREWFsaaNWvYuHEjoaGhrFy50iXlqVuRFpPUQW2dO8u9h4fsX/D221Ijd97adu1audeauCp1KSkyeKtSJRnEceCABOEWLWR6lXOzYP36cvzgQdm154svJOj36iUjyzdskH7bgwelqR2kpm6MjDC/+27ZRKRPH5nuVaWKjEBXOUsN4o0bS5kXowcffJCNGzdmOZ6cnIx7Ibci7dixY65roAP4+voSGhrKH3/8wfLly7nuuut4+eWXAdm8BGTZ1J8cAxqjo6MZP348YWFhGGNIdOqjXL58OevWrWPJkiVUq1aN+fPns23bNvr06QNAQkICvXr1olq1anh7e3PHHXdw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",
      "text/plain": [
       "<Figure size 576x360 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize = (8,5))\n",
    "for i, model in enumerate(fl_server.config.models):\n",
    "    t = [0]+fl_server.test_accuracies[i][0]\n",
    "    y = np.array([0]+fl_server.test_accuracies[i][2])\n",
    "    idx = np.argmax(y == y[-1])\n",
    "    plt.plot(t,y,color=['blue','red','orange','black'][i])\n",
    "    plt.plot([t[idx]]*5,np.linspace(0,y[idx],5),color = 'green',alpha = 0.7,label='_nolegend_' )\n",
    "    plt.legend([r.name for r in fl_server.config.models])\n",
    "plt.title('Test Accuracies - Sync-ST')\n",
    "plt.xlabel('Time')\n",
    "plt.grid()\n",
    "plt.ylabel('Test Accuracy')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3829d1ce-cb81-48df-b3f4-15922854af7b",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "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
}
