{
 "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": "c51e2995-9b67-45db-ac65-13f35d301ff6",
   "metadata": {},
   "outputs": [],
   "source": [
    "### FedAST ###"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "29634e90-92ed-4477-8c0f-5b84d9738046",
   "metadata": {},
   "outputs": [],
   "source": [
    "parser = argparse.ArgumentParser()\n",
    "parser.add_argument('-c', '--config', type=str, default='./configFiles/fedast_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": "428301ff-525d-436e-b991-d73113a7f3d7",
   "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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",
      "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 - FedAST')\n",
    "plt.xlabel('Time')\n",
    "plt.grid()\n",
    "plt.ylabel('Test Accuracy')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fba68e78-2e1f-4ec3-b7cd-f4e7b6a2a9c8",
   "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
}
