{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "collapsed": false,
    "jupyter": {
     "outputs_hidden": false
    },
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [],
   "source": [
    "%matplotlib inline\n",
    "\n",
    "import sys\n",
    "sys.path.insert(0, \"../fl_sim/\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "##################################################################\n",
      "#-------------   File is auto-generated by Qluman!  -------------#\n",
      "#-------------  Manual changes will be overwritten! -------------#\n",
      "#----------------------------------------------------------------#\n",
      "127.0.0.1\tlocalhost\n",
      "192.168.52.241\tlogin-1\n",
      "192.168.53.241\tlogin-1-ib\n",
      "192.168.54.241\tlogin-1-ipmi\n",
      "10.127.79.248\tcscc-login-1\n"
     ]
    }
   ],
   "source": [
    "!cat /etc/hosts"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "ename": "KeyboardInterrupt",
     "evalue": "",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m                         Traceback (most recent call last)",
      "Input \u001b[0;32mIn [3]\u001b[0m, in \u001b[0;36m<cell line: 7>\u001b[0;34m()\u001b[0m\n\u001b[1;32m      5\u001b[0m \u001b[38;5;28;01mimport\u001b[39;00m \u001b[38;5;21;01mpandas\u001b[39;00m \u001b[38;5;28;01mas\u001b[39;00m \u001b[38;5;21;01mpd\u001b[39;00m\n\u001b[1;32m      6\u001b[0m \u001b[38;5;28;01mimport\u001b[39;00m \u001b[38;5;21;01mmatplotlib\u001b[39;00m\u001b[38;5;21;01m.\u001b[39;00m\u001b[38;5;21;01mpyplot\u001b[39;00m \u001b[38;5;28;01mas\u001b[39;00m \u001b[38;5;21;01mplt\u001b[39;00m\n\u001b[0;32m----> 7\u001b[0m \u001b[38;5;28;01mimport\u001b[39;00m \u001b[38;5;21;01mseaborn\u001b[39;00m \u001b[38;5;28;01mas\u001b[39;00m \u001b[38;5;21;01msns\u001b[39;00m\n\u001b[1;32m      8\u001b[0m plt\u001b[38;5;241m.\u001b[39mrcParams[\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mfigure.figsize\u001b[39m\u001b[38;5;124m\"\u001b[39m] \u001b[38;5;241m=\u001b[39m (\u001b[38;5;241m5\u001b[39m,\u001b[38;5;241m3\u001b[39m)\n\u001b[1;32m     10\u001b[0m \u001b[38;5;28;01mimport\u001b[39;00m \u001b[38;5;21;01mtorch\u001b[39;00m\n",
      "File \u001b[0;32m~/miniconda3/envs/torch/lib/python3.9/site-packages/seaborn/__init__.py:2\u001b[0m, in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m      1\u001b[0m \u001b[38;5;66;03m# Import seaborn objects\u001b[39;00m\n\u001b[0;32m----> 2\u001b[0m \u001b[38;5;28;01mfrom\u001b[39;00m \u001b[38;5;21;01m.\u001b[39;00m\u001b[38;5;21;01mrcmod\u001b[39;00m \u001b[38;5;28;01mimport\u001b[39;00m \u001b[38;5;241m*\u001b[39m  \u001b[38;5;66;03m# noqa: F401,F403\u001b[39;00m\n\u001b[1;32m      3\u001b[0m \u001b[38;5;28;01mfrom\u001b[39;00m \u001b[38;5;21;01m.\u001b[39;00m\u001b[38;5;21;01mutils\u001b[39;00m \u001b[38;5;28;01mimport\u001b[39;00m \u001b[38;5;241m*\u001b[39m  \u001b[38;5;66;03m# noqa: F401,F403\u001b[39;00m\n\u001b[1;32m      4\u001b[0m \u001b[38;5;28;01mfrom\u001b[39;00m \u001b[38;5;21;01m.\u001b[39;00m\u001b[38;5;21;01mpalettes\u001b[39;00m \u001b[38;5;28;01mimport\u001b[39;00m \u001b[38;5;241m*\u001b[39m  \u001b[38;5;66;03m# noqa: F401,F403\u001b[39;00m\n",
      "File \u001b[0;32m~/miniconda3/envs/torch/lib/python3.9/site-packages/seaborn/rcmod.py:7\u001b[0m, in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m      5\u001b[0m \u001b[38;5;28;01mimport\u001b[39;00m \u001b[38;5;21;01mmatplotlib\u001b[39;00m \u001b[38;5;28;01mas\u001b[39;00m \u001b[38;5;21;01mmpl\u001b[39;00m\n\u001b[1;32m      6\u001b[0m \u001b[38;5;28;01mfrom\u001b[39;00m \u001b[38;5;21;01mcycler\u001b[39;00m \u001b[38;5;28;01mimport\u001b[39;00m cycler\n\u001b[0;32m----> 7\u001b[0m \u001b[38;5;28;01mfrom\u001b[39;00m \u001b[38;5;21;01m.\u001b[39;00m \u001b[38;5;28;01mimport\u001b[39;00m palettes\n\u001b[1;32m     10\u001b[0m __all__ \u001b[38;5;241m=\u001b[39m [\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mset_theme\u001b[39m\u001b[38;5;124m\"\u001b[39m, \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mset\u001b[39m\u001b[38;5;124m\"\u001b[39m, \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mreset_defaults\u001b[39m\u001b[38;5;124m\"\u001b[39m, \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mreset_orig\u001b[39m\u001b[38;5;124m\"\u001b[39m,\n\u001b[1;32m     11\u001b[0m            \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124maxes_style\u001b[39m\u001b[38;5;124m\"\u001b[39m, \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mset_style\u001b[39m\u001b[38;5;124m\"\u001b[39m, \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mplotting_context\u001b[39m\u001b[38;5;124m\"\u001b[39m, \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mset_context\u001b[39m\u001b[38;5;124m\"\u001b[39m,\n\u001b[1;32m     12\u001b[0m            \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mset_palette\u001b[39m\u001b[38;5;124m\"\u001b[39m]\n\u001b[1;32m     15\u001b[0m _style_keys \u001b[38;5;241m=\u001b[39m [\n\u001b[1;32m     16\u001b[0m \n\u001b[1;32m     17\u001b[0m     \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124maxes.facecolor\u001b[39m\u001b[38;5;124m\"\u001b[39m,\n\u001b[0;32m   (...)\u001b[0m\n\u001b[1;32m     52\u001b[0m \n\u001b[1;32m     53\u001b[0m ]\n",
      "File \u001b[0;32m~/miniconda3/envs/torch/lib/python3.9/site-packages/seaborn/palettes.py:9\u001b[0m, in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m      5\u001b[0m \u001b[38;5;28;01mimport\u001b[39;00m \u001b[38;5;21;01mmatplotlib\u001b[39;00m \u001b[38;5;28;01mas\u001b[39;00m \u001b[38;5;21;01mmpl\u001b[39;00m\n\u001b[1;32m      7\u001b[0m \u001b[38;5;28;01mfrom\u001b[39;00m \u001b[38;5;21;01m.\u001b[39;00m\u001b[38;5;21;01mexternal\u001b[39;00m \u001b[38;5;28;01mimport\u001b[39;00m husl\n\u001b[0;32m----> 9\u001b[0m \u001b[38;5;28;01mfrom\u001b[39;00m \u001b[38;5;21;01m.\u001b[39;00m\u001b[38;5;21;01mutils\u001b[39;00m \u001b[38;5;28;01mimport\u001b[39;00m desaturate, get_color_cycle\n\u001b[1;32m     10\u001b[0m \u001b[38;5;28;01mfrom\u001b[39;00m \u001b[38;5;21;01m.\u001b[39;00m\u001b[38;5;21;01mcolors\u001b[39;00m \u001b[38;5;28;01mimport\u001b[39;00m xkcd_rgb, crayons\n\u001b[1;32m     13\u001b[0m __all__ \u001b[38;5;241m=\u001b[39m [\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mcolor_palette\u001b[39m\u001b[38;5;124m\"\u001b[39m, \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mhls_palette\u001b[39m\u001b[38;5;124m\"\u001b[39m, \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mhusl_palette\u001b[39m\u001b[38;5;124m\"\u001b[39m, \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mmpl_palette\u001b[39m\u001b[38;5;124m\"\u001b[39m,\n\u001b[1;32m     14\u001b[0m            \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mdark_palette\u001b[39m\u001b[38;5;124m\"\u001b[39m, \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mlight_palette\u001b[39m\u001b[38;5;124m\"\u001b[39m, \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mdiverging_palette\u001b[39m\u001b[38;5;124m\"\u001b[39m,\n\u001b[1;32m     15\u001b[0m            \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mblend_palette\u001b[39m\u001b[38;5;124m\"\u001b[39m, \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mxkcd_palette\u001b[39m\u001b[38;5;124m\"\u001b[39m, \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mcrayon_palette\u001b[39m\u001b[38;5;124m\"\u001b[39m,\n\u001b[1;32m     16\u001b[0m            \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mcubehelix_palette\u001b[39m\u001b[38;5;124m\"\u001b[39m, \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mset_color_codes\u001b[39m\u001b[38;5;124m\"\u001b[39m]\n",
      "File \u001b[0;32m~/miniconda3/envs/torch/lib/python3.9/site-packages/seaborn/utils.py:10\u001b[0m, in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m      7\u001b[0m \u001b[38;5;28;01mfrom\u001b[39;00m \u001b[38;5;21;01murllib\u001b[39;00m\u001b[38;5;21;01m.\u001b[39;00m\u001b[38;5;21;01mrequest\u001b[39;00m \u001b[38;5;28;01mimport\u001b[39;00m urlopen, urlretrieve\n\u001b[1;32m      9\u001b[0m \u001b[38;5;28;01mimport\u001b[39;00m \u001b[38;5;21;01mnumpy\u001b[39;00m \u001b[38;5;28;01mas\u001b[39;00m \u001b[38;5;21;01mnp\u001b[39;00m\n\u001b[0;32m---> 10\u001b[0m \u001b[38;5;28;01mfrom\u001b[39;00m \u001b[38;5;21;01mscipy\u001b[39;00m \u001b[38;5;28;01mimport\u001b[39;00m stats\n\u001b[1;32m     11\u001b[0m \u001b[38;5;28;01mimport\u001b[39;00m \u001b[38;5;21;01mpandas\u001b[39;00m \u001b[38;5;28;01mas\u001b[39;00m \u001b[38;5;21;01mpd\u001b[39;00m\n\u001b[1;32m     12\u001b[0m \u001b[38;5;28;01mimport\u001b[39;00m \u001b[38;5;21;01mmatplotlib\u001b[39;00m \u001b[38;5;28;01mas\u001b[39;00m \u001b[38;5;21;01mmpl\u001b[39;00m\n",
      "File \u001b[0;32m<frozen importlib._bootstrap>:1055\u001b[0m, in \u001b[0;36m_handle_fromlist\u001b[0;34m(module, fromlist, import_, recursive)\u001b[0m\n",
      "File \u001b[0;32m~/miniconda3/envs/torch/lib/python3.9/site-packages/scipy/__init__.py:211\u001b[0m, in \u001b[0;36m__getattr__\u001b[0;34m(name)\u001b[0m\n\u001b[1;32m    209\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21m__getattr__\u001b[39m(name):\n\u001b[1;32m    210\u001b[0m     \u001b[38;5;28;01mif\u001b[39;00m name \u001b[38;5;129;01min\u001b[39;00m submodules:\n\u001b[0;32m--> 211\u001b[0m         \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[43m_importlib\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mimport_module\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;124;43mf\u001b[39;49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[38;5;124;43mscipy.\u001b[39;49m\u001b[38;5;132;43;01m{\u001b[39;49;00m\u001b[43mname\u001b[49m\u001b[38;5;132;43;01m}\u001b[39;49;00m\u001b[38;5;124;43m'\u001b[39;49m\u001b[43m)\u001b[49m\n\u001b[1;32m    212\u001b[0m     \u001b[38;5;28;01melse\u001b[39;00m:\n\u001b[1;32m    213\u001b[0m         \u001b[38;5;28;01mtry\u001b[39;00m:\n",
      "File \u001b[0;32m~/miniconda3/envs/torch/lib/python3.9/importlib/__init__.py:127\u001b[0m, in \u001b[0;36mimport_module\u001b[0;34m(name, package)\u001b[0m\n\u001b[1;32m    125\u001b[0m             \u001b[38;5;28;01mbreak\u001b[39;00m\n\u001b[1;32m    126\u001b[0m         level \u001b[38;5;241m+\u001b[39m\u001b[38;5;241m=\u001b[39m \u001b[38;5;241m1\u001b[39m\n\u001b[0;32m--> 127\u001b[0m \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[43m_bootstrap\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43m_gcd_import\u001b[49m\u001b[43m(\u001b[49m\u001b[43mname\u001b[49m\u001b[43m[\u001b[49m\u001b[43mlevel\u001b[49m\u001b[43m:\u001b[49m\u001b[43m]\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mpackage\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mlevel\u001b[49m\u001b[43m)\u001b[49m\n",
      "File \u001b[0;32m~/miniconda3/envs/torch/lib/python3.9/site-packages/scipy/stats/__init__.py:467\u001b[0m, in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m      1\u001b[0m \u001b[38;5;124;03m\"\"\"\u001b[39;00m\n\u001b[1;32m      2\u001b[0m \u001b[38;5;124;03m.. _statsrefmanual:\u001b[39;00m\n\u001b[1;32m      3\u001b[0m \n\u001b[0;32m   (...)\u001b[0m\n\u001b[1;32m    462\u001b[0m \n\u001b[1;32m    463\u001b[0m \u001b[38;5;124;03m\"\"\"\u001b[39;00m\n\u001b[1;32m    465\u001b[0m \u001b[38;5;28;01mfrom\u001b[39;00m \u001b[38;5;21;01m.\u001b[39;00m\u001b[38;5;21;01m_warnings_errors\u001b[39;00m \u001b[38;5;28;01mimport\u001b[39;00m (ConstantInputWarning, NearConstantInputWarning,\n\u001b[1;32m    466\u001b[0m                                DegenerateDataWarning, FitError)\n\u001b[0;32m--> 467\u001b[0m \u001b[38;5;28;01mfrom\u001b[39;00m \u001b[38;5;21;01m.\u001b[39;00m\u001b[38;5;21;01m_stats_py\u001b[39;00m \u001b[38;5;28;01mimport\u001b[39;00m \u001b[38;5;241m*\u001b[39m\n\u001b[1;32m    468\u001b[0m \u001b[38;5;28;01mfrom\u001b[39;00m \u001b[38;5;21;01m.\u001b[39;00m\u001b[38;5;21;01m_variation\u001b[39;00m \u001b[38;5;28;01mimport\u001b[39;00m variation\n\u001b[1;32m    469\u001b[0m \u001b[38;5;28;01mfrom\u001b[39;00m \u001b[38;5;21;01m.\u001b[39;00m\u001b[38;5;21;01mdistributions\u001b[39;00m \u001b[38;5;28;01mimport\u001b[39;00m \u001b[38;5;241m*\u001b[39m\n",
      "File \u001b[0;32m~/miniconda3/envs/torch/lib/python3.9/site-packages/scipy/stats/_stats_py.py:39\u001b[0m, in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m     36\u001b[0m \u001b[38;5;28;01mfrom\u001b[39;00m \u001b[38;5;21;01mnumpy\u001b[39;00m\u001b[38;5;21;01m.\u001b[39;00m\u001b[38;5;21;01mlib\u001b[39;00m \u001b[38;5;28;01mimport\u001b[39;00m NumpyVersion\n\u001b[1;32m     37\u001b[0m \u001b[38;5;28;01mfrom\u001b[39;00m \u001b[38;5;21;01mnumpy\u001b[39;00m\u001b[38;5;21;01m.\u001b[39;00m\u001b[38;5;21;01mtesting\u001b[39;00m \u001b[38;5;28;01mimport\u001b[39;00m suppress_warnings\n\u001b[0;32m---> 39\u001b[0m \u001b[38;5;28;01mfrom\u001b[39;00m \u001b[38;5;21;01mscipy\u001b[39;00m\u001b[38;5;21;01m.\u001b[39;00m\u001b[38;5;21;01mspatial\u001b[39;00m\u001b[38;5;21;01m.\u001b[39;00m\u001b[38;5;21;01mdistance\u001b[39;00m \u001b[38;5;28;01mimport\u001b[39;00m cdist\n\u001b[1;32m     40\u001b[0m \u001b[38;5;28;01mfrom\u001b[39;00m \u001b[38;5;21;01mscipy\u001b[39;00m\u001b[38;5;21;01m.\u001b[39;00m\u001b[38;5;21;01mndimage\u001b[39;00m \u001b[38;5;28;01mimport\u001b[39;00m _measurements\n\u001b[1;32m     41\u001b[0m \u001b[38;5;28;01mfrom\u001b[39;00m \u001b[38;5;21;01mscipy\u001b[39;00m\u001b[38;5;21;01m.\u001b[39;00m\u001b[38;5;21;01m_lib\u001b[39;00m\u001b[38;5;21;01m.\u001b[39;00m\u001b[38;5;21;01m_util\u001b[39;00m \u001b[38;5;28;01mimport\u001b[39;00m (check_random_state, MapWrapper,\n\u001b[1;32m     42\u001b[0m                               rng_integers, _rename_parameter)\n",
      "File \u001b[0;32m~/miniconda3/envs/torch/lib/python3.9/site-packages/scipy/spatial/__init__.py:105\u001b[0m, in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m      1\u001b[0m \u001b[38;5;124;03m\"\"\"\u001b[39;00m\n\u001b[1;32m      2\u001b[0m \u001b[38;5;124;03m=============================================================\u001b[39;00m\n\u001b[1;32m      3\u001b[0m \u001b[38;5;124;03mSpatial algorithms and data structures (:mod:`scipy.spatial`)\u001b[39;00m\n\u001b[0;32m   (...)\u001b[0m\n\u001b[1;32m    102\u001b[0m \u001b[38;5;124;03m   QhullError\u001b[39;00m\n\u001b[1;32m    103\u001b[0m \u001b[38;5;124;03m\"\"\"\u001b[39;00m\n\u001b[0;32m--> 105\u001b[0m \u001b[38;5;28;01mfrom\u001b[39;00m \u001b[38;5;21;01m.\u001b[39;00m\u001b[38;5;21;01m_kdtree\u001b[39;00m \u001b[38;5;28;01mimport\u001b[39;00m \u001b[38;5;241m*\u001b[39m\n\u001b[1;32m    106\u001b[0m \u001b[38;5;28;01mfrom\u001b[39;00m \u001b[38;5;21;01m.\u001b[39;00m\u001b[38;5;21;01m_ckdtree\u001b[39;00m \u001b[38;5;28;01mimport\u001b[39;00m \u001b[38;5;241m*\u001b[39m\n\u001b[1;32m    107\u001b[0m \u001b[38;5;28;01mfrom\u001b[39;00m \u001b[38;5;21;01m.\u001b[39;00m\u001b[38;5;21;01m_qhull\u001b[39;00m \u001b[38;5;28;01mimport\u001b[39;00m \u001b[38;5;241m*\u001b[39m\n",
      "File \u001b[0;32m~/miniconda3/envs/torch/lib/python3.9/site-packages/scipy/spatial/_kdtree.py:5\u001b[0m, in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m      3\u001b[0m \u001b[38;5;28;01mimport\u001b[39;00m \u001b[38;5;21;01mnumpy\u001b[39;00m \u001b[38;5;28;01mas\u001b[39;00m \u001b[38;5;21;01mnp\u001b[39;00m\n\u001b[1;32m      4\u001b[0m \u001b[38;5;28;01mimport\u001b[39;00m \u001b[38;5;21;01mwarnings\u001b[39;00m\n\u001b[0;32m----> 5\u001b[0m \u001b[38;5;28;01mfrom\u001b[39;00m \u001b[38;5;21;01m.\u001b[39;00m\u001b[38;5;21;01m_ckdtree\u001b[39;00m \u001b[38;5;28;01mimport\u001b[39;00m cKDTree, cKDTreeNode\n\u001b[1;32m      7\u001b[0m __all__ \u001b[38;5;241m=\u001b[39m [\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mminkowski_distance_p\u001b[39m\u001b[38;5;124m'\u001b[39m, \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mminkowski_distance\u001b[39m\u001b[38;5;124m'\u001b[39m,\n\u001b[1;32m      8\u001b[0m            \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mdistance_matrix\u001b[39m\u001b[38;5;124m'\u001b[39m,\n\u001b[1;32m      9\u001b[0m            \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mRectangle\u001b[39m\u001b[38;5;124m'\u001b[39m, \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mKDTree\u001b[39m\u001b[38;5;124m'\u001b[39m]\n\u001b[1;32m     12\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21mminkowski_distance_p\u001b[39m(x, y, p\u001b[38;5;241m=\u001b[39m\u001b[38;5;241m2\u001b[39m):\n",
      "File \u001b[0;32m_ckdtree.pyx:10\u001b[0m, in \u001b[0;36minit scipy.spatial._ckdtree\u001b[0;34m()\u001b[0m\n",
      "File \u001b[0;32m~/miniconda3/envs/torch/lib/python3.9/site-packages/scipy/sparse/__init__.py:283\u001b[0m, in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m    278\u001b[0m \u001b[38;5;28;01mfrom\u001b[39;00m \u001b[38;5;21;01m.\u001b[39;00m\u001b[38;5;21;01m_arrays\u001b[39;00m \u001b[38;5;28;01mimport\u001b[39;00m (\n\u001b[1;32m    279\u001b[0m     csr_array, csc_array, lil_array, dok_array, coo_array, dia_array, bsr_array\n\u001b[1;32m    280\u001b[0m )\n\u001b[1;32m    282\u001b[0m \u001b[38;5;66;03m# For backward compatibility with v0.19.\u001b[39;00m\n\u001b[0;32m--> 283\u001b[0m \u001b[38;5;28;01mfrom\u001b[39;00m \u001b[38;5;21;01m.\u001b[39;00m \u001b[38;5;28;01mimport\u001b[39;00m csgraph\n\u001b[1;32m    285\u001b[0m \u001b[38;5;66;03m# Deprecated namespaces, to be removed in v2.0.0\u001b[39;00m\n\u001b[1;32m    286\u001b[0m \u001b[38;5;28;01mfrom\u001b[39;00m \u001b[38;5;21;01m.\u001b[39;00m \u001b[38;5;28;01mimport\u001b[39;00m (\n\u001b[1;32m    287\u001b[0m     base, bsr, compressed, construct, coo, csc, csr, data, dia, dok, extract,\n\u001b[1;32m    288\u001b[0m     lil, sparsetools, sputils\n\u001b[1;32m    289\u001b[0m )\n",
      "File \u001b[0;32m~/miniconda3/envs/torch/lib/python3.9/site-packages/scipy/sparse/csgraph/__init__.py:182\u001b[0m, in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m    154\u001b[0m __docformat__ \u001b[38;5;241m=\u001b[39m \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mrestructuredtext en\u001b[39m\u001b[38;5;124m\"\u001b[39m\n\u001b[1;32m    156\u001b[0m __all__ \u001b[38;5;241m=\u001b[39m [\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mconnected_components\u001b[39m\u001b[38;5;124m'\u001b[39m,\n\u001b[1;32m    157\u001b[0m            \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mlaplacian\u001b[39m\u001b[38;5;124m'\u001b[39m,\n\u001b[1;32m    158\u001b[0m            \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mshortest_path\u001b[39m\u001b[38;5;124m'\u001b[39m,\n\u001b[0;32m   (...)\u001b[0m\n\u001b[1;32m    179\u001b[0m            \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mcsgraph_to_masked\u001b[39m\u001b[38;5;124m'\u001b[39m,\n\u001b[1;32m    180\u001b[0m            \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mNegativeCycleError\u001b[39m\u001b[38;5;124m'\u001b[39m]\n\u001b[0;32m--> 182\u001b[0m \u001b[38;5;28;01mfrom\u001b[39;00m \u001b[38;5;21;01m.\u001b[39;00m\u001b[38;5;21;01m_laplacian\u001b[39;00m \u001b[38;5;28;01mimport\u001b[39;00m laplacian\n\u001b[1;32m    183\u001b[0m \u001b[38;5;28;01mfrom\u001b[39;00m \u001b[38;5;21;01m.\u001b[39;00m\u001b[38;5;21;01m_shortest_path\u001b[39;00m \u001b[38;5;28;01mimport\u001b[39;00m (\n\u001b[1;32m    184\u001b[0m     shortest_path, floyd_warshall, dijkstra, bellman_ford, johnson,\n\u001b[1;32m    185\u001b[0m     NegativeCycleError\n\u001b[1;32m    186\u001b[0m )\n\u001b[1;32m    187\u001b[0m \u001b[38;5;28;01mfrom\u001b[39;00m \u001b[38;5;21;01m.\u001b[39;00m\u001b[38;5;21;01m_traversal\u001b[39;00m \u001b[38;5;28;01mimport\u001b[39;00m (\n\u001b[1;32m    188\u001b[0m     breadth_first_order, depth_first_order, breadth_first_tree,\n\u001b[1;32m    189\u001b[0m     depth_first_tree, connected_components\n\u001b[1;32m    190\u001b[0m )\n",
      "File \u001b[0;32m~/miniconda3/envs/torch/lib/python3.9/site-packages/scipy/sparse/csgraph/_laplacian.py:7\u001b[0m, in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m      5\u001b[0m \u001b[38;5;28;01mimport\u001b[39;00m \u001b[38;5;21;01mnumpy\u001b[39;00m \u001b[38;5;28;01mas\u001b[39;00m \u001b[38;5;21;01mnp\u001b[39;00m\n\u001b[1;32m      6\u001b[0m \u001b[38;5;28;01mfrom\u001b[39;00m \u001b[38;5;21;01mscipy\u001b[39;00m\u001b[38;5;21;01m.\u001b[39;00m\u001b[38;5;21;01msparse\u001b[39;00m \u001b[38;5;28;01mimport\u001b[39;00m isspmatrix\n\u001b[0;32m----> 7\u001b[0m \u001b[38;5;28;01mfrom\u001b[39;00m \u001b[38;5;21;01mscipy\u001b[39;00m\u001b[38;5;21;01m.\u001b[39;00m\u001b[38;5;21;01msparse\u001b[39;00m\u001b[38;5;21;01m.\u001b[39;00m\u001b[38;5;21;01mlinalg\u001b[39;00m \u001b[38;5;28;01mimport\u001b[39;00m LinearOperator\n\u001b[1;32m     10\u001b[0m \u001b[38;5;66;03m###############################################################################\u001b[39;00m\n\u001b[1;32m     11\u001b[0m \u001b[38;5;66;03m# Graph laplacian\u001b[39;00m\n\u001b[1;32m     12\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21mlaplacian\u001b[39m(\n\u001b[1;32m     13\u001b[0m     csgraph,\n\u001b[1;32m     14\u001b[0m     normed\u001b[38;5;241m=\u001b[39m\u001b[38;5;28;01mFalse\u001b[39;00m,\n\u001b[0;32m   (...)\u001b[0m\n\u001b[1;32m     21\u001b[0m     symmetrized\u001b[38;5;241m=\u001b[39m\u001b[38;5;28;01mFalse\u001b[39;00m,\n\u001b[1;32m     22\u001b[0m ):\n",
      "File \u001b[0;32m~/miniconda3/envs/torch/lib/python3.9/site-packages/scipy/sparse/linalg/__init__.py:120\u001b[0m, in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m      1\u001b[0m \u001b[38;5;124;03m\"\"\"\u001b[39;00m\n\u001b[1;32m      2\u001b[0m \u001b[38;5;124;03mSparse linear algebra (:mod:`scipy.sparse.linalg`)\u001b[39;00m\n\u001b[1;32m      3\u001b[0m \u001b[38;5;124;03m==================================================\u001b[39;00m\n\u001b[0;32m   (...)\u001b[0m\n\u001b[1;32m    117\u001b[0m \n\u001b[1;32m    118\u001b[0m \u001b[38;5;124;03m\"\"\"\u001b[39;00m\n\u001b[0;32m--> 120\u001b[0m \u001b[38;5;28;01mfrom\u001b[39;00m \u001b[38;5;21;01m.\u001b[39;00m\u001b[38;5;21;01m_isolve\u001b[39;00m \u001b[38;5;28;01mimport\u001b[39;00m \u001b[38;5;241m*\u001b[39m\n\u001b[1;32m    121\u001b[0m \u001b[38;5;28;01mfrom\u001b[39;00m \u001b[38;5;21;01m.\u001b[39;00m\u001b[38;5;21;01m_dsolve\u001b[39;00m \u001b[38;5;28;01mimport\u001b[39;00m \u001b[38;5;241m*\u001b[39m\n\u001b[1;32m    122\u001b[0m \u001b[38;5;28;01mfrom\u001b[39;00m \u001b[38;5;21;01m.\u001b[39;00m\u001b[38;5;21;01m_interface\u001b[39;00m \u001b[38;5;28;01mimport\u001b[39;00m \u001b[38;5;241m*\u001b[39m\n",
      "File \u001b[0;32m~/miniconda3/envs/torch/lib/python3.9/site-packages/scipy/sparse/linalg/_isolve/__init__.py:4\u001b[0m, in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m      1\u001b[0m \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mIterative Solvers for Sparse Linear Systems\u001b[39m\u001b[38;5;124m\"\u001b[39m\n\u001b[1;32m      3\u001b[0m \u001b[38;5;66;03m#from info import __doc__\u001b[39;00m\n\u001b[0;32m----> 4\u001b[0m \u001b[38;5;28;01mfrom\u001b[39;00m \u001b[38;5;21;01m.\u001b[39;00m\u001b[38;5;21;01miterative\u001b[39;00m \u001b[38;5;28;01mimport\u001b[39;00m \u001b[38;5;241m*\u001b[39m\n\u001b[1;32m      5\u001b[0m \u001b[38;5;28;01mfrom\u001b[39;00m \u001b[38;5;21;01m.\u001b[39;00m\u001b[38;5;21;01mminres\u001b[39;00m \u001b[38;5;28;01mimport\u001b[39;00m minres\n\u001b[1;32m      6\u001b[0m \u001b[38;5;28;01mfrom\u001b[39;00m \u001b[38;5;21;01m.\u001b[39;00m\u001b[38;5;21;01mlgmres\u001b[39;00m \u001b[38;5;28;01mimport\u001b[39;00m lgmres\n",
      "File \u001b[0;32m~/miniconda3/envs/torch/lib/python3.9/site-packages/scipy/sparse/linalg/_isolve/iterative.py:9\u001b[0m, in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m      6\u001b[0m \u001b[38;5;28;01mfrom\u001b[39;00m \u001b[38;5;21;01mtextwrap\u001b[39;00m \u001b[38;5;28;01mimport\u001b[39;00m dedent\n\u001b[1;32m      7\u001b[0m \u001b[38;5;28;01mimport\u001b[39;00m \u001b[38;5;21;01mnumpy\u001b[39;00m \u001b[38;5;28;01mas\u001b[39;00m \u001b[38;5;21;01mnp\u001b[39;00m\n\u001b[0;32m----> 9\u001b[0m \u001b[38;5;28;01mfrom\u001b[39;00m \u001b[38;5;21;01m.\u001b[39;00m \u001b[38;5;28;01mimport\u001b[39;00m _iterative\n\u001b[1;32m     11\u001b[0m \u001b[38;5;28;01mfrom\u001b[39;00m \u001b[38;5;21;01mscipy\u001b[39;00m\u001b[38;5;21;01m.\u001b[39;00m\u001b[38;5;21;01msparse\u001b[39;00m\u001b[38;5;21;01m.\u001b[39;00m\u001b[38;5;21;01mlinalg\u001b[39;00m\u001b[38;5;21;01m.\u001b[39;00m\u001b[38;5;21;01m_interface\u001b[39;00m \u001b[38;5;28;01mimport\u001b[39;00m LinearOperator\n\u001b[1;32m     12\u001b[0m \u001b[38;5;28;01mfrom\u001b[39;00m \u001b[38;5;21;01m.\u001b[39;00m\u001b[38;5;21;01mutils\u001b[39;00m \u001b[38;5;28;01mimport\u001b[39;00m make_system\n",
      "File \u001b[0;32m<frozen importlib._bootstrap>:1007\u001b[0m, in \u001b[0;36m_find_and_load\u001b[0;34m(name, import_)\u001b[0m\n",
      "File \u001b[0;32m<frozen importlib._bootstrap>:982\u001b[0m, in \u001b[0;36m_find_and_load_unlocked\u001b[0;34m(name, import_)\u001b[0m\n",
      "File \u001b[0;32m<frozen importlib._bootstrap>:925\u001b[0m, in \u001b[0;36m_find_spec\u001b[0;34m(name, path, target)\u001b[0m\n",
      "File \u001b[0;32m<frozen importlib._bootstrap_external>:1423\u001b[0m, in \u001b[0;36mfind_spec\u001b[0;34m(cls, fullname, path, target)\u001b[0m\n",
      "File \u001b[0;32m<frozen importlib._bootstrap_external>:1395\u001b[0m, in \u001b[0;36m_get_spec\u001b[0;34m(cls, fullname, path, target)\u001b[0m\n",
      "File \u001b[0;32m<frozen importlib._bootstrap_external>:1522\u001b[0m, in \u001b[0;36mfind_spec\u001b[0;34m(self, fullname, target)\u001b[0m\n",
      "File \u001b[0;32m<frozen importlib._bootstrap_external>:142\u001b[0m, in \u001b[0;36m_path_stat\u001b[0;34m(path)\u001b[0m\n",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m: "
     ]
    }
   ],
   "source": [
    "import glob\n",
    "import torch\n",
    "from PIL import Image\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "plt.rcParams[\"figure.figsize\"] = (5,3)\n",
    "\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "from torch.utils.data import DataLoader\n",
    "\n",
    "from models import *\n",
    "from models.gan import ResNetDiscriminator, StyleVectorizer\n",
    "from data_funcs import *\n",
    "from utils.logger import Logger\n",
    "import utils.gan_utils as gan_utils"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "RUN_PADPAF = \"../outputs/id=padpaf/task=damnist-fedgan/lr=0.001_0.01/seed=123/model/*\"\n",
    "RUN_PADPAF_COND = \"../outputs/id=padpaf/task=damnist-fedgan-conditional-partial/lr=0.001_0.01/seed=123/model/*\"\n",
    "\n",
    "MODEL_PATHS = RUN_PADPAF"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "conditional = \"conditional\" in MODEL_PATHS"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "../outputs/id=padpaf/task=damnist-fedgan/lr=0.001_0.01/seed=123/model/model.pth.tar\n"
     ]
    }
   ],
   "source": [
    "# model_paths = glob.glob(\"models/partial/normal/model_round*.pth.tar\")\n",
    "def get_round(model_path):\n",
    "    return int(model_path[-11:-8])\n",
    "\n",
    "model_paths = glob.glob(MODEL_PATHS)\n",
    "# model_paths = sorted(model_paths, key=lambda pth: get_round(pth))  # sort by round\n",
    "for p in model_paths: print(p)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Evaluate Features"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Init setting and model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'cpu'"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "classifier_is_linear = True  # else: 2-layer nn with relu\n",
    "\n",
    "Logger.setup_logging(\"INFO\", logfile=\"\")\n",
    "Logger()\n",
    "\n",
    "image_size = 32\n",
    "channels = 3\n",
    "\n",
    "dataset_name = \"damnist\"\n",
    "data_path = \"../data/\"\n",
    "num_workers = 0\n",
    "device = \"cuda:0\" if torch.cuda.is_available() else \"cpu\"\n",
    "num_classes = 10\n",
    "\n",
    "batch_size = 32\n",
    "lr = 1e-2\n",
    "epochs = 50\n",
    "lr_gamma = 0.95\n",
    "\n",
    "device"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "loader_kwargs = {}\n",
    "if not device == 'cpu':\n",
    "    loader_kwargs[\"num_workers\"] = num_workers\n",
    "    loader_kwargs[\"persistent_workers\"] = num_workers > 0"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "def init_styleD(num_features=64):\n",
    "     return ResNetDiscriminator(num_features=num_features, image_size=image_size, channels=channels)\n",
    "\n",
    "\n",
    "def init_style_map(num_latents=128):\n",
    "     return StyleVectorizer(num_latents, 8, lr_mul=0.1)\n",
    "\n",
    "\n",
    "def init_model(num_latents=128, num_features=64):\n",
    "    return FedGAN(num_latents=num_latents,\n",
    "                             D_features=num_features, G_features=num_features,\n",
    "                             image_size=image_size, channels=channels, num_classes=num_classes if conditional else 0)\n",
    "\n",
    "\n",
    "def moving_avg(series, t=1):\n",
    "    return series\n",
    "    ###\n",
    "    avgs = []\n",
    "    for i in range(1, len(series) + 1):\n",
    "        last_t = series[:i][-t:]\n",
    "        avg = sum(last_t) / len(last_t)\n",
    "        avgs.append(avg)\n",
    "    return avgs\n",
    "\n",
    "\n",
    "def load_fedgan_one_style(global_model, fp, style_id=0, device=None):\n",
    "    state_dict = torch.load(fp, map_location=device)\n",
    "    # Global modules\n",
    "    global_model.contentD.load_state_dict(state_dict['contentD'])\n",
    "    global_model.G.load_state_dict(state_dict['G'])\n",
    "    # Local modules\n",
    "    local_state_dict = state_dict[str(style_id)]\n",
    "    global_model.styleD.load_state_dict(local_state_dict['styleD'])\n",
    "    global_model.style_map.load_state_dict(local_state_dict['style_map'])\n",
    "    return global_model\n",
    "\n",
    "\n",
    "def load_fedgan_all_styles(global_model, fp, device=None):\n",
    "    state_dict = torch.load(fp, map_location=device)\n",
    "    # Global modules\n",
    "    global_model.contentD.load_state_dict(state_dict['contentD'])\n",
    "    global_model.G.load_state_dict(state_dict['G'])\n",
    "    private_modules = []\n",
    "    for worker_id in range(len(state_dict)):\n",
    "        if str(worker_id) not in state_dict:\n",
    "            continue\n",
    "        # Local modules\n",
    "        local_state_dict = state_dict[str(worker_id)]\n",
    "        # TODO: can't we just deepcopy from global_model? (write copy() method)\n",
    "        styleD = init_styleD().to(device)\n",
    "        styleD.load_state_dict(local_state_dict['styleD'])\n",
    "        style_map = init_style_map().to(device)\n",
    "        style_map.load_state_dict(local_state_dict['style_map'])\n",
    "        style_modules = {\n",
    "            \"id\": worker_id,\n",
    "            \"styleD\": styleD,\n",
    "            \"style_map\": style_map,\n",
    "        }\n",
    "        private_modules.append(style_modules)\n",
    "    return global_model, private_modules"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Load test dataset"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "ename": "KeyboardInterrupt",
     "evalue": "",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m                         Traceback (most recent call last)",
      "Input \u001b[0;32mIn [88]\u001b[0m, in \u001b[0;36m<cell line: 1>\u001b[0;34m()\u001b[0m\n\u001b[0;32m----> 1\u001b[0m train_dataset, test_dataset \u001b[38;5;241m=\u001b[39m \u001b[43mload_data\u001b[49m\u001b[43m(\u001b[49m\u001b[43mdataset\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mdataset_name\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mpath\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mdata_path\u001b[49m\u001b[43m)\u001b[49m\n",
      "File \u001b[0;32m~/projects/PaDPaF/notebooks/../fl_sim/data_funcs/data_loader.py:80\u001b[0m, in \u001b[0;36mload_data\u001b[0;34m(path, dataset, load_trainset, download, full_dataset, transform, **dataset_opts)\u001b[0m\n\u001b[1;32m     78\u001b[0m \u001b[38;5;28;01melif\u001b[39;00m dataset \u001b[38;5;241m==\u001b[39m \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mdamnist\u001b[39m\u001b[38;5;124m'\u001b[39m:\n\u001b[1;32m     79\u001b[0m     \u001b[38;5;28;01mif\u001b[39;00m load_trainset:\n\u001b[0;32m---> 80\u001b[0m         fl_dataset \u001b[38;5;241m=\u001b[39m \u001b[43mDAMNIST\u001b[49m\u001b[43m(\u001b[49m\u001b[43mroot\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mpath\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mtrain\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;28;43;01mTrue\u001b[39;49;00m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mdownload\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mdownload\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43mdataset_opts\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m     81\u001b[0m         trainsets \u001b[38;5;241m=\u001b[39m [DAMNISTClient(\n\u001b[1;32m     82\u001b[0m             fl_dataset, client_id\u001b[38;5;241m=\u001b[39mclient_id)\n\u001b[1;32m     83\u001b[0m             \u001b[38;5;28;01mfor\u001b[39;00m client_id \u001b[38;5;129;01min\u001b[39;00m \u001b[38;5;28mrange\u001b[39m(fl_dataset\u001b[38;5;241m.\u001b[39mnum_clients)]\n\u001b[1;32m     84\u001b[0m     fl_dataset \u001b[38;5;241m=\u001b[39m DAMNIST(root\u001b[38;5;241m=\u001b[39mpath, train\u001b[38;5;241m=\u001b[39m\u001b[38;5;28;01mFalse\u001b[39;00m, download\u001b[38;5;241m=\u001b[39mdownload, \u001b[38;5;241m*\u001b[39m\u001b[38;5;241m*\u001b[39mdataset_opts)\n",
      "File \u001b[0;32m~/projects/PaDPaF/notebooks/../fl_sim/data_funcs/torch_datasets/damnist.py:75\u001b[0m, in \u001b[0;36mDAMNIST.__init__\u001b[0;34m(self, root, train, transform, target_transform, download, transform_indices, classes_per_client)\u001b[0m\n\u001b[1;32m     72\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21m__init__\u001b[39m(\u001b[38;5;28mself\u001b[39m, root, train\u001b[38;5;241m=\u001b[39m\u001b[38;5;28;01mTrue\u001b[39;00m, transform\u001b[38;5;241m=\u001b[39m\u001b[38;5;28;01mNone\u001b[39;00m, target_transform\u001b[38;5;241m=\u001b[39m\u001b[38;5;28;01mNone\u001b[39;00m,\n\u001b[1;32m     73\u001b[0m              download\u001b[38;5;241m=\u001b[39m\u001b[38;5;28;01mFalse\u001b[39;00m, transform_indices\u001b[38;5;241m=\u001b[39m\u001b[38;5;28mslice\u001b[39m(\u001b[38;5;28;01mNone\u001b[39;00m), classes_per_client\u001b[38;5;241m=\u001b[39m\u001b[38;5;241m1.0\u001b[39m):\n\u001b[0;32m---> 75\u001b[0m     \u001b[38;5;28;43msuper\u001b[39;49m\u001b[43m(\u001b[49m\u001b[43m)\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[38;5;21;43m__init__\u001b[39;49m\u001b[43m(\u001b[49m\u001b[43mroot\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mtrain\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mtrain\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mtransform\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mtransform\u001b[49m\u001b[43m,\u001b[49m\n\u001b[1;32m     76\u001b[0m \u001b[43m                     \u001b[49m\u001b[43mtarget_transform\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mtarget_transform\u001b[49m\u001b[43m,\u001b[49m\n\u001b[1;32m     77\u001b[0m \u001b[43m                     \u001b[49m\u001b[43mdownload\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mdownload\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m     78\u001b[0m     \u001b[38;5;66;03m# image normalization\u001b[39;00m\n\u001b[1;32m     79\u001b[0m     mean, std \u001b[38;5;241m=\u001b[39m [\u001b[38;5;241m0.5\u001b[39m], [\u001b[38;5;241m0.5\u001b[39m]\n",
      "File \u001b[0;32m~/miniconda3/envs/torch/lib/python3.9/site-packages/torchvision/datasets/mnist.py:104\u001b[0m, in \u001b[0;36mMNIST.__init__\u001b[0;34m(self, root, train, transform, target_transform, download)\u001b[0m\n\u001b[1;32m    101\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;129;01mnot\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_check_exists():\n\u001b[1;32m    102\u001b[0m     \u001b[38;5;28;01mraise\u001b[39;00m \u001b[38;5;167;01mRuntimeError\u001b[39;00m(\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mDataset not found. You can use download=True to download it\u001b[39m\u001b[38;5;124m\"\u001b[39m)\n\u001b[0;32m--> 104\u001b[0m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mdata, \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mtargets \u001b[38;5;241m=\u001b[39m \u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43m_load_data\u001b[49m\u001b[43m(\u001b[49m\u001b[43m)\u001b[49m\n",
      "File \u001b[0;32m~/miniconda3/envs/torch/lib/python3.9/site-packages/torchvision/datasets/mnist.py:123\u001b[0m, in \u001b[0;36mMNIST._load_data\u001b[0;34m(self)\u001b[0m\n\u001b[1;32m    121\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21m_load_data\u001b[39m(\u001b[38;5;28mself\u001b[39m):\n\u001b[1;32m    122\u001b[0m     image_file \u001b[38;5;241m=\u001b[39m \u001b[38;5;124mf\u001b[39m\u001b[38;5;124m\"\u001b[39m\u001b[38;5;132;01m{\u001b[39;00m\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mtrain\u001b[39m\u001b[38;5;124m'\u001b[39m \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mtrain \u001b[38;5;28;01melse\u001b[39;00m \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mt10k\u001b[39m\u001b[38;5;124m'\u001b[39m\u001b[38;5;132;01m}\u001b[39;00m\u001b[38;5;124m-images-idx3-ubyte\u001b[39m\u001b[38;5;124m\"\u001b[39m\n\u001b[0;32m--> 123\u001b[0m     data \u001b[38;5;241m=\u001b[39m \u001b[43mread_image_file\u001b[49m\u001b[43m(\u001b[49m\u001b[43mos\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mpath\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mjoin\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mraw_folder\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mimage_file\u001b[49m\u001b[43m)\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    125\u001b[0m     label_file \u001b[38;5;241m=\u001b[39m \u001b[38;5;124mf\u001b[39m\u001b[38;5;124m\"\u001b[39m\u001b[38;5;132;01m{\u001b[39;00m\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mtrain\u001b[39m\u001b[38;5;124m'\u001b[39m \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mtrain \u001b[38;5;28;01melse\u001b[39;00m \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mt10k\u001b[39m\u001b[38;5;124m'\u001b[39m\u001b[38;5;132;01m}\u001b[39;00m\u001b[38;5;124m-labels-idx1-ubyte\u001b[39m\u001b[38;5;124m\"\u001b[39m\n\u001b[1;32m    126\u001b[0m     targets \u001b[38;5;241m=\u001b[39m read_label_file(os\u001b[38;5;241m.\u001b[39mpath\u001b[38;5;241m.\u001b[39mjoin(\u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mraw_folder, label_file))\n",
      "File \u001b[0;32m~/miniconda3/envs/torch/lib/python3.9/site-packages/torchvision/datasets/mnist.py:544\u001b[0m, in \u001b[0;36mread_image_file\u001b[0;34m(path)\u001b[0m\n\u001b[1;32m    543\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21mread_image_file\u001b[39m(path: \u001b[38;5;28mstr\u001b[39m) \u001b[38;5;241m-\u001b[39m\u001b[38;5;241m>\u001b[39m torch\u001b[38;5;241m.\u001b[39mTensor:\n\u001b[0;32m--> 544\u001b[0m     x \u001b[38;5;241m=\u001b[39m \u001b[43mread_sn3_pascalvincent_tensor\u001b[49m\u001b[43m(\u001b[49m\u001b[43mpath\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mstrict\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;28;43;01mFalse\u001b[39;49;00m\u001b[43m)\u001b[49m\n\u001b[1;32m    545\u001b[0m     \u001b[38;5;28;01mif\u001b[39;00m x\u001b[38;5;241m.\u001b[39mdtype \u001b[38;5;241m!=\u001b[39m torch\u001b[38;5;241m.\u001b[39muint8:\n\u001b[1;32m    546\u001b[0m         \u001b[38;5;28;01mraise\u001b[39;00m \u001b[38;5;167;01mTypeError\u001b[39;00m(\u001b[38;5;124mf\u001b[39m\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mx should be of dtype torch.uint8 instead of \u001b[39m\u001b[38;5;132;01m{\u001b[39;00mx\u001b[38;5;241m.\u001b[39mdtype\u001b[38;5;132;01m}\u001b[39;00m\u001b[38;5;124m\"\u001b[39m)\n",
      "File \u001b[0;32m~/miniconda3/envs/torch/lib/python3.9/site-packages/torchvision/datasets/mnist.py:512\u001b[0m, in \u001b[0;36mread_sn3_pascalvincent_tensor\u001b[0;34m(path, strict)\u001b[0m\n\u001b[1;32m    510\u001b[0m \u001b[38;5;66;03m# read\u001b[39;00m\n\u001b[1;32m    511\u001b[0m \u001b[38;5;28;01mwith\u001b[39;00m \u001b[38;5;28mopen\u001b[39m(path, \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mrb\u001b[39m\u001b[38;5;124m\"\u001b[39m) \u001b[38;5;28;01mas\u001b[39;00m f:\n\u001b[0;32m--> 512\u001b[0m     data \u001b[38;5;241m=\u001b[39m \u001b[43mf\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mread\u001b[49m\u001b[43m(\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    513\u001b[0m \u001b[38;5;66;03m# parse\u001b[39;00m\n\u001b[1;32m    514\u001b[0m magic \u001b[38;5;241m=\u001b[39m get_int(data[\u001b[38;5;241m0\u001b[39m:\u001b[38;5;241m4\u001b[39m])\n",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m: "
     ]
    }
   ],
   "source": [
    "train_dataset, test_dataset = load_data(dataset=dataset_name, path=data_path)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<PIL.Image.Image image mode=RGB size=274x138>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([7, 2, 1, 0, 4, 1, 4, 9])\n",
      "tensor([5, 9, 0, 6, 9, 0, 1, 5])\n",
      "tensor([9, 7, 3, 4, 9, 6, 6, 5])\n",
      "tensor([4, 0, 7, 4, 0, 1, 3, 1])\n"
     ]
    }
   ],
   "source": [
    "test_loader = DataLoader(test_dataset, batch_size, shuffle=False, **loader_kwargs)\n",
    "for x, y in test_loader:\n",
    "    x, y = x.to(device), y.to(device)\n",
    "    display(Image.fromarray(gan_utils.tensor_to_np(gan_utils.make_grid(0.5+0.5*x))))\n",
    "    for i in range(0, y.size(0), 8):\n",
    "        print(y[i:i+8])\n",
    "    break"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Load model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "global_model = init_model().to(device)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Train a linear classifier on content features and a one style features"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'linear_classifier'"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "classifier_name = 'linear_classifier' if classifier_is_linear else 'mlp_classifier'\n",
    "\n",
    "def make_classifier(num_features, output_dim=num_classes, linear=classifier_is_linear):\n",
    "    if linear:\n",
    "        return nn.Linear(num_features, output_dim)\n",
    "    else:\n",
    "        return nn.Sequential(\n",
    "            nn.Linear(num_features, num_features),\n",
    "            nn.BatchNorm1d(num_features),\n",
    "            nn.ReLU(),\n",
    "            nn.Linear(num_features, output_dim),\n",
    "        )\n",
    "\n",
    "classifier_name"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "global_model = load_fedgan_one_style(global_model, model_paths[-1], style_id=0, device=device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "650\n"
     ]
    }
   ],
   "source": [
    "content_classifier = make_classifier(global_model.contentD.num_features).to(device)\n",
    "content_classifier_optim = torch.optim.Adam(content_classifier.parameters(), lr=lr)\n",
    "content_classifier_optim_sched = torch.optim.lr_scheduler.ExponentialLR(content_classifier_optim, gamma=lr_gamma)\n",
    "\n",
    "style_classifier = make_classifier(global_model.styleD.num_features).to(device)\n",
    "style_classifier_optim = torch.optim.Adam(style_classifier.parameters(), lr=lr)\n",
    "style_classifier_optim_sched = torch.optim.lr_scheduler.ExponentialLR(style_classifier_optim, gamma=lr_gamma)\n",
    "\n",
    "loss_fn = nn.CrossEntropyLoss().to(device)\n",
    "\n",
    "print(sum(p.numel() for p in content_classifier.parameters()))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[1/50] content_loss = 1.009043\tcontent_acc = 0.790935\tstyle_loss = 2.223506\tstyle_acc = 0.182907\n",
      "[2/50] content_loss = 0.356616\tcontent_acc = 0.928315\tstyle_loss = 2.146195\tstyle_acc = 0.242812\n",
      "[3/50] content_loss = 0.252189\tcontent_acc = 0.941693\tstyle_loss = 2.083236\tstyle_acc = 0.287041\n",
      "[4/50] content_loss = 0.205642\tcontent_acc = 0.948582\tstyle_loss = 2.032113\tstyle_acc = 0.316294\n",
      "[5/50] content_loss = 0.178346\tcontent_acc = 0.953574\tstyle_loss = 1.989802\tstyle_acc = 0.336262\n",
      "[6/50] content_loss = 0.160084\tcontent_acc = 0.957268\tstyle_loss = 1.954166\tstyle_acc = 0.352536\n",
      "[7/50] content_loss = 0.146832\tcontent_acc = 0.960064\tstyle_loss = 1.923684\tstyle_acc = 0.368710\n",
      "[8/50] content_loss = 0.136672\tcontent_acc = 0.962260\tstyle_loss = 1.897264\tstyle_acc = 0.382488\n",
      "[9/50] content_loss = 0.128580\tcontent_acc = 0.963658\tstyle_loss = 1.874105\tstyle_acc = 0.393670\n",
      "[10/50] content_loss = 0.121956\tcontent_acc = 0.965156\tstyle_loss = 1.853610\tstyle_acc = 0.402656\n",
      "[11/50] content_loss = 0.116426\tcontent_acc = 0.966554\tstyle_loss = 1.835328\tstyle_acc = 0.410543\n",
      "[12/50] content_loss = 0.111732\tcontent_acc = 0.967252\tstyle_loss = 1.818907\tstyle_acc = 0.418331\n",
      "[13/50] content_loss = 0.107694\tcontent_acc = 0.968650\tstyle_loss = 1.804073\tstyle_acc = 0.425020\n",
      "[14/50] content_loss = 0.104172\tcontent_acc = 0.969349\tstyle_loss = 1.790606\tstyle_acc = 0.430312\n",
      "[15/50] content_loss = 0.101061\tcontent_acc = 0.969549\tstyle_loss = 1.778327\tstyle_acc = 0.435104\n",
      "[16/50] content_loss = 0.098282\tcontent_acc = 0.969748\tstyle_loss = 1.767089\tstyle_acc = 0.439097\n",
      "[17/50] content_loss = 0.095780\tcontent_acc = 0.970248\tstyle_loss = 1.756772\tstyle_acc = 0.443490\n",
      "[18/50] content_loss = 0.093513\tcontent_acc = 0.971046\tstyle_loss = 1.747271\tstyle_acc = 0.446386\n",
      "[19/50] content_loss = 0.091451\tcontent_acc = 0.971745\tstyle_loss = 1.738501\tstyle_acc = 0.449581\n",
      "[20/50] content_loss = 0.089571\tcontent_acc = 0.972744\tstyle_loss = 1.730388\tstyle_acc = 0.452875\n",
      "[21/50] content_loss = 0.087854\tcontent_acc = 0.972843\tstyle_loss = 1.722867\tstyle_acc = 0.455671\n",
      "[22/50] content_loss = 0.086284\tcontent_acc = 0.972843\tstyle_loss = 1.715884\tstyle_acc = 0.458367\n",
      "[23/50] content_loss = 0.084849\tcontent_acc = 0.973243\tstyle_loss = 1.709388\tstyle_acc = 0.461362\n",
      "[24/50] content_loss = 0.083536\tcontent_acc = 0.973942\tstyle_loss = 1.703339\tstyle_acc = 0.464457\n",
      "[25/50] content_loss = 0.082333\tcontent_acc = 0.974541\tstyle_loss = 1.697698\tstyle_acc = 0.468251\n",
      "[26/50] content_loss = 0.081231\tcontent_acc = 0.974940\tstyle_loss = 1.692433\tstyle_acc = 0.470647\n",
      "[27/50] content_loss = 0.080220\tcontent_acc = 0.975539\tstyle_loss = 1.687512\tstyle_acc = 0.472244\n",
      "[28/50] content_loss = 0.079292\tcontent_acc = 0.975539\tstyle_loss = 1.682910\tstyle_acc = 0.474541\n",
      "[29/50] content_loss = 0.078439\tcontent_acc = 0.975938\tstyle_loss = 1.678602\tstyle_acc = 0.476837\n",
      "[30/50] content_loss = 0.077652\tcontent_acc = 0.976538\tstyle_loss = 1.674567\tstyle_acc = 0.477835\n",
      "[31/50] content_loss = 0.076926\tcontent_acc = 0.976837\tstyle_loss = 1.670784\tstyle_acc = 0.480132\n",
      "[32/50] content_loss = 0.076254\tcontent_acc = 0.976837\tstyle_loss = 1.667235\tstyle_acc = 0.481430\n",
      "[33/50] content_loss = 0.075628\tcontent_acc = 0.977336\tstyle_loss = 1.663903\tstyle_acc = 0.483027\n"
     ]
    },
    {
     "ename": "KeyboardInterrupt",
     "evalue": "",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m                         Traceback (most recent call last)",
      "Input \u001b[0;32mIn [25]\u001b[0m, in \u001b[0;36m<cell line: 5>\u001b[0;34m()\u001b[0m\n\u001b[1;32m     12\u001b[0m \u001b[38;5;66;03m# Get features from discriminators\u001b[39;00m\n\u001b[1;32m     13\u001b[0m \u001b[38;5;28;01mwith\u001b[39;00m torch\u001b[38;5;241m.\u001b[39mno_grad():\n\u001b[0;32m---> 14\u001b[0m     _, content_features \u001b[38;5;241m=\u001b[39m \u001b[43mglobal_model\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mcontentD\u001b[49m\u001b[43m(\u001b[49m\u001b[43mx\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mreturn_h\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;28;43;01mTrue\u001b[39;49;00m\u001b[43m)\u001b[49m\n\u001b[1;32m     15\u001b[0m     _, style_features \u001b[38;5;241m=\u001b[39m global_model\u001b[38;5;241m.\u001b[39mstyleD(x, return_h\u001b[38;5;241m=\u001b[39m\u001b[38;5;28;01mTrue\u001b[39;00m)\n\u001b[1;32m     16\u001b[0m     \u001b[38;5;66;03m# content_features = global_model.contentD(x, return_h=True)\u001b[39;00m\n\u001b[1;32m     17\u001b[0m     \u001b[38;5;66;03m# style_features = global_model.styleD(x, return_h=True)\u001b[39;00m\n\u001b[1;32m     18\u001b[0m \u001b[38;5;66;03m# Get predictions from classifiers\u001b[39;00m\n",
      "File \u001b[0;32m~/miniconda3/envs/torch/lib/python3.9/site-packages/torch/nn/modules/module.py:1130\u001b[0m, in \u001b[0;36mModule._call_impl\u001b[0;34m(self, *input, **kwargs)\u001b[0m\n\u001b[1;32m   1126\u001b[0m \u001b[38;5;66;03m# If we don't have any hooks, we want to skip the rest of the logic in\u001b[39;00m\n\u001b[1;32m   1127\u001b[0m \u001b[38;5;66;03m# this function, and just call forward.\u001b[39;00m\n\u001b[1;32m   1128\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;129;01mnot\u001b[39;00m (\u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_backward_hooks \u001b[38;5;129;01mor\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_forward_hooks \u001b[38;5;129;01mor\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_forward_pre_hooks \u001b[38;5;129;01mor\u001b[39;00m _global_backward_hooks\n\u001b[1;32m   1129\u001b[0m         \u001b[38;5;129;01mor\u001b[39;00m _global_forward_hooks \u001b[38;5;129;01mor\u001b[39;00m _global_forward_pre_hooks):\n\u001b[0;32m-> 1130\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[43mforward_call\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[38;5;28;43minput\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43mkwargs\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m   1131\u001b[0m \u001b[38;5;66;03m# Do not call functions when jit is used\u001b[39;00m\n\u001b[1;32m   1132\u001b[0m full_backward_hooks, non_full_backward_hooks \u001b[38;5;241m=\u001b[39m [], []\n",
      "File \u001b[0;32m~/github/FL/notebooks/../fl_sim/models/gan.py:299\u001b[0m, in \u001b[0;36mResNetDiscriminator.forward\u001b[0;34m(self, x, cond, label, return_h)\u001b[0m\n\u001b[1;32m    296\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21mforward\u001b[39m(\u001b[38;5;28mself\u001b[39m, x, cond\u001b[38;5;241m=\u001b[39m\u001b[38;5;28;01mNone\u001b[39;00m, label\u001b[38;5;241m=\u001b[39m\u001b[38;5;28;01mNone\u001b[39;00m, return_h\u001b[38;5;241m=\u001b[39m\u001b[38;5;28;01mFalse\u001b[39;00m):\n\u001b[1;32m    297\u001b[0m     \u001b[38;5;66;03m# assert cond is None or self.cond_dim > 0\u001b[39;00m\n\u001b[1;32m    298\u001b[0m     \u001b[38;5;66;03m# assert label is None or self.num_classes > 0\u001b[39;00m\n\u001b[0;32m--> 299\u001b[0m     h \u001b[38;5;241m=\u001b[39m \u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mmodel\u001b[49m\u001b[43m(\u001b[49m\u001b[43mx\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    300\u001b[0m     h \u001b[38;5;241m=\u001b[39m h\u001b[38;5;241m.\u001b[39mview(\u001b[38;5;241m-\u001b[39m\u001b[38;5;241m1\u001b[39m, \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mhidden_dim)\n\u001b[1;32m    301\u001b[0m     output \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mfc(h)\n",
      "File \u001b[0;32m~/miniconda3/envs/torch/lib/python3.9/site-packages/torch/nn/modules/module.py:1130\u001b[0m, in \u001b[0;36mModule._call_impl\u001b[0;34m(self, *input, **kwargs)\u001b[0m\n\u001b[1;32m   1126\u001b[0m \u001b[38;5;66;03m# If we don't have any hooks, we want to skip the rest of the logic in\u001b[39;00m\n\u001b[1;32m   1127\u001b[0m \u001b[38;5;66;03m# this function, and just call forward.\u001b[39;00m\n\u001b[1;32m   1128\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;129;01mnot\u001b[39;00m (\u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_backward_hooks \u001b[38;5;129;01mor\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_forward_hooks \u001b[38;5;129;01mor\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_forward_pre_hooks \u001b[38;5;129;01mor\u001b[39;00m _global_backward_hooks\n\u001b[1;32m   1129\u001b[0m         \u001b[38;5;129;01mor\u001b[39;00m _global_forward_hooks \u001b[38;5;129;01mor\u001b[39;00m _global_forward_pre_hooks):\n\u001b[0;32m-> 1130\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[43mforward_call\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[38;5;28;43minput\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43mkwargs\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m   1131\u001b[0m \u001b[38;5;66;03m# Do not call functions when jit is used\u001b[39;00m\n\u001b[1;32m   1132\u001b[0m full_backward_hooks, non_full_backward_hooks \u001b[38;5;241m=\u001b[39m [], []\n",
      "File \u001b[0;32m~/miniconda3/envs/torch/lib/python3.9/site-packages/torch/nn/modules/container.py:139\u001b[0m, in \u001b[0;36mSequential.forward\u001b[0;34m(self, input)\u001b[0m\n\u001b[1;32m    137\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21mforward\u001b[39m(\u001b[38;5;28mself\u001b[39m, \u001b[38;5;28minput\u001b[39m):\n\u001b[1;32m    138\u001b[0m     \u001b[38;5;28;01mfor\u001b[39;00m module \u001b[38;5;129;01min\u001b[39;00m \u001b[38;5;28mself\u001b[39m:\n\u001b[0;32m--> 139\u001b[0m         \u001b[38;5;28minput\u001b[39m \u001b[38;5;241m=\u001b[39m \u001b[43mmodule\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;28;43minput\u001b[39;49m\u001b[43m)\u001b[49m\n\u001b[1;32m    140\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[38;5;28minput\u001b[39m\n",
      "File \u001b[0;32m~/miniconda3/envs/torch/lib/python3.9/site-packages/torch/nn/modules/module.py:1130\u001b[0m, in \u001b[0;36mModule._call_impl\u001b[0;34m(self, *input, **kwargs)\u001b[0m\n\u001b[1;32m   1126\u001b[0m \u001b[38;5;66;03m# If we don't have any hooks, we want to skip the rest of the logic in\u001b[39;00m\n\u001b[1;32m   1127\u001b[0m \u001b[38;5;66;03m# this function, and just call forward.\u001b[39;00m\n\u001b[1;32m   1128\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;129;01mnot\u001b[39;00m (\u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_backward_hooks \u001b[38;5;129;01mor\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_forward_hooks \u001b[38;5;129;01mor\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_forward_pre_hooks \u001b[38;5;129;01mor\u001b[39;00m _global_backward_hooks\n\u001b[1;32m   1129\u001b[0m         \u001b[38;5;129;01mor\u001b[39;00m _global_forward_hooks \u001b[38;5;129;01mor\u001b[39;00m _global_forward_pre_hooks):\n\u001b[0;32m-> 1130\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[43mforward_call\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[38;5;28;43minput\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43mkwargs\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m   1131\u001b[0m \u001b[38;5;66;03m# Do not call functions when jit is used\u001b[39;00m\n\u001b[1;32m   1132\u001b[0m full_backward_hooks, non_full_backward_hooks \u001b[38;5;241m=\u001b[39m [], []\n",
      "File \u001b[0;32m~/github/FL/notebooks/../fl_sim/models/gan.py:214\u001b[0m, in \u001b[0;36mFirstResBlockDiscriminator.forward\u001b[0;34m(self, x)\u001b[0m\n\u001b[1;32m    213\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21mforward\u001b[39m(\u001b[38;5;28mself\u001b[39m, x):\n\u001b[0;32m--> 214\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mmodel(x) \u001b[38;5;241m+\u001b[39m \u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mbypass\u001b[49m\u001b[43m(\u001b[49m\u001b[43mx\u001b[49m\u001b[43m)\u001b[49m\n",
      "File \u001b[0;32m~/miniconda3/envs/torch/lib/python3.9/site-packages/torch/nn/modules/module.py:1130\u001b[0m, in \u001b[0;36mModule._call_impl\u001b[0;34m(self, *input, **kwargs)\u001b[0m\n\u001b[1;32m   1126\u001b[0m \u001b[38;5;66;03m# If we don't have any hooks, we want to skip the rest of the logic in\u001b[39;00m\n\u001b[1;32m   1127\u001b[0m \u001b[38;5;66;03m# this function, and just call forward.\u001b[39;00m\n\u001b[1;32m   1128\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;129;01mnot\u001b[39;00m (\u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_backward_hooks \u001b[38;5;129;01mor\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_forward_hooks \u001b[38;5;129;01mor\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_forward_pre_hooks \u001b[38;5;129;01mor\u001b[39;00m _global_backward_hooks\n\u001b[1;32m   1129\u001b[0m         \u001b[38;5;129;01mor\u001b[39;00m _global_forward_hooks \u001b[38;5;129;01mor\u001b[39;00m _global_forward_pre_hooks):\n\u001b[0;32m-> 1130\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[43mforward_call\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[38;5;28;43minput\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43mkwargs\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m   1131\u001b[0m \u001b[38;5;66;03m# Do not call functions when jit is used\u001b[39;00m\n\u001b[1;32m   1132\u001b[0m full_backward_hooks, non_full_backward_hooks \u001b[38;5;241m=\u001b[39m [], []\n",
      "File \u001b[0;32m~/miniconda3/envs/torch/lib/python3.9/site-packages/torch/nn/modules/container.py:139\u001b[0m, in \u001b[0;36mSequential.forward\u001b[0;34m(self, input)\u001b[0m\n\u001b[1;32m    137\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21mforward\u001b[39m(\u001b[38;5;28mself\u001b[39m, \u001b[38;5;28minput\u001b[39m):\n\u001b[1;32m    138\u001b[0m     \u001b[38;5;28;01mfor\u001b[39;00m module \u001b[38;5;129;01min\u001b[39;00m \u001b[38;5;28mself\u001b[39m:\n\u001b[0;32m--> 139\u001b[0m         \u001b[38;5;28minput\u001b[39m \u001b[38;5;241m=\u001b[39m \u001b[43mmodule\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;28;43minput\u001b[39;49m\u001b[43m)\u001b[49m\n\u001b[1;32m    140\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[38;5;28minput\u001b[39m\n",
      "File \u001b[0;32m~/miniconda3/envs/torch/lib/python3.9/site-packages/torch/nn/modules/module.py:1130\u001b[0m, in \u001b[0;36mModule._call_impl\u001b[0;34m(self, *input, **kwargs)\u001b[0m\n\u001b[1;32m   1126\u001b[0m \u001b[38;5;66;03m# If we don't have any hooks, we want to skip the rest of the logic in\u001b[39;00m\n\u001b[1;32m   1127\u001b[0m \u001b[38;5;66;03m# this function, and just call forward.\u001b[39;00m\n\u001b[1;32m   1128\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;129;01mnot\u001b[39;00m (\u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_backward_hooks \u001b[38;5;129;01mor\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_forward_hooks \u001b[38;5;129;01mor\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_forward_pre_hooks \u001b[38;5;129;01mor\u001b[39;00m _global_backward_hooks\n\u001b[1;32m   1129\u001b[0m         \u001b[38;5;129;01mor\u001b[39;00m _global_forward_hooks \u001b[38;5;129;01mor\u001b[39;00m _global_forward_pre_hooks):\n\u001b[0;32m-> 1130\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[43mforward_call\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[38;5;28;43minput\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43mkwargs\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m   1131\u001b[0m \u001b[38;5;66;03m# Do not call functions when jit is used\u001b[39;00m\n\u001b[1;32m   1132\u001b[0m full_backward_hooks, non_full_backward_hooks \u001b[38;5;241m=\u001b[39m [], []\n",
      "File \u001b[0;32m~/miniconda3/envs/torch/lib/python3.9/site-packages/torch/nn/modules/conv.py:457\u001b[0m, in \u001b[0;36mConv2d.forward\u001b[0;34m(self, input)\u001b[0m\n\u001b[1;32m    456\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21mforward\u001b[39m(\u001b[38;5;28mself\u001b[39m, \u001b[38;5;28minput\u001b[39m: Tensor) \u001b[38;5;241m-\u001b[39m\u001b[38;5;241m>\u001b[39m Tensor:\n\u001b[0;32m--> 457\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_conv_forward(\u001b[38;5;28minput\u001b[39m, \u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mweight\u001b[49m, \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mbias)\n",
      "File \u001b[0;32m~/miniconda3/envs/torch/lib/python3.9/site-packages/torch/nn/utils/parametrize.py:341\u001b[0m, in \u001b[0;36m_inject_property.<locals>.get_parametrized\u001b[0;34m(self)\u001b[0m\n\u001b[1;32m    338\u001b[0m         \u001b[38;5;28;01mreturn\u001b[39;00m get_cached_parametrization(parametrization)\n\u001b[1;32m    339\u001b[0m \u001b[38;5;28;01melse\u001b[39;00m:\n\u001b[1;32m    340\u001b[0m     \u001b[38;5;66;03m# If caching is not active, this function just evaluates the parametrization\u001b[39;00m\n\u001b[0;32m--> 341\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[43mparametrization\u001b[49m\u001b[43m(\u001b[49m\u001b[43m)\u001b[49m\n",
      "File \u001b[0;32m~/miniconda3/envs/torch/lib/python3.9/site-packages/torch/nn/modules/module.py:1130\u001b[0m, in \u001b[0;36mModule._call_impl\u001b[0;34m(self, *input, **kwargs)\u001b[0m\n\u001b[1;32m   1126\u001b[0m \u001b[38;5;66;03m# If we don't have any hooks, we want to skip the rest of the logic in\u001b[39;00m\n\u001b[1;32m   1127\u001b[0m \u001b[38;5;66;03m# this function, and just call forward.\u001b[39;00m\n\u001b[1;32m   1128\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;129;01mnot\u001b[39;00m (\u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_backward_hooks \u001b[38;5;129;01mor\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_forward_hooks \u001b[38;5;129;01mor\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_forward_pre_hooks \u001b[38;5;129;01mor\u001b[39;00m _global_backward_hooks\n\u001b[1;32m   1129\u001b[0m         \u001b[38;5;129;01mor\u001b[39;00m _global_forward_hooks \u001b[38;5;129;01mor\u001b[39;00m _global_forward_pre_hooks):\n\u001b[0;32m-> 1130\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[43mforward_call\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[38;5;28;43minput\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43mkwargs\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m   1131\u001b[0m \u001b[38;5;66;03m# Do not call functions when jit is used\u001b[39;00m\n\u001b[1;32m   1132\u001b[0m full_backward_hooks, non_full_backward_hooks \u001b[38;5;241m=\u001b[39m [], []\n",
      "File \u001b[0;32m~/miniconda3/envs/torch/lib/python3.9/site-packages/torch/nn/utils/parametrize.py:259\u001b[0m, in \u001b[0;36mParametrizationList.forward\u001b[0;34m(self)\u001b[0m\n\u001b[1;32m    256\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21mforward\u001b[39m(\u001b[38;5;28mself\u001b[39m) \u001b[38;5;241m-\u001b[39m\u001b[38;5;241m>\u001b[39m Tensor:\n\u001b[1;32m    257\u001b[0m     \u001b[38;5;66;03m# Unpack the originals for the first parametrization\u001b[39;00m\n\u001b[1;32m    258\u001b[0m     \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mis_tensor:\n\u001b[0;32m--> 259\u001b[0m         x \u001b[38;5;241m=\u001b[39m \u001b[38;5;28;43mself\u001b[39;49m\u001b[43m[\u001b[49m\u001b[38;5;241;43m0\u001b[39;49m\u001b[43m]\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43moriginal\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    260\u001b[0m     \u001b[38;5;28;01melse\u001b[39;00m:\n\u001b[1;32m    261\u001b[0m         originals \u001b[38;5;241m=\u001b[39m (\u001b[38;5;28mgetattr\u001b[39m(\u001b[38;5;28mself\u001b[39m, \u001b[38;5;124mf\u001b[39m\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124moriginal\u001b[39m\u001b[38;5;132;01m{\u001b[39;00mi\u001b[38;5;132;01m}\u001b[39;00m\u001b[38;5;124m\"\u001b[39m) \u001b[38;5;28;01mfor\u001b[39;00m i \u001b[38;5;129;01min\u001b[39;00m \u001b[38;5;28mrange\u001b[39m(\u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mntensors))\n",
      "File \u001b[0;32m~/miniconda3/envs/torch/lib/python3.9/site-packages/torch/nn/modules/module.py:1130\u001b[0m, in \u001b[0;36mModule._call_impl\u001b[0;34m(self, *input, **kwargs)\u001b[0m\n\u001b[1;32m   1126\u001b[0m \u001b[38;5;66;03m# If we don't have any hooks, we want to skip the rest of the logic in\u001b[39;00m\n\u001b[1;32m   1127\u001b[0m \u001b[38;5;66;03m# this function, and just call forward.\u001b[39;00m\n\u001b[1;32m   1128\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;129;01mnot\u001b[39;00m (\u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_backward_hooks \u001b[38;5;129;01mor\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_forward_hooks \u001b[38;5;129;01mor\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_forward_pre_hooks \u001b[38;5;129;01mor\u001b[39;00m _global_backward_hooks\n\u001b[1;32m   1129\u001b[0m         \u001b[38;5;129;01mor\u001b[39;00m _global_forward_hooks \u001b[38;5;129;01mor\u001b[39;00m _global_forward_pre_hooks):\n\u001b[0;32m-> 1130\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[43mforward_call\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[38;5;28;43minput\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43mkwargs\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m   1131\u001b[0m \u001b[38;5;66;03m# Do not call functions when jit is used\u001b[39;00m\n\u001b[1;32m   1132\u001b[0m full_backward_hooks, non_full_backward_hooks \u001b[38;5;241m=\u001b[39m [], []\n",
      "File \u001b[0;32m~/miniconda3/envs/torch/lib/python3.9/site-packages/torch/nn/utils/parametrizations.py:380\u001b[0m, in \u001b[0;36m_SpectralNorm.forward\u001b[0;34m(self, weight)\u001b[0m\n\u001b[1;32m    378\u001b[0m weight_mat \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_reshape_weight_to_matrix(weight)\n\u001b[1;32m    379\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mtraining:\n\u001b[0;32m--> 380\u001b[0m     \u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43m_power_method\u001b[49m\u001b[43m(\u001b[49m\u001b[43mweight_mat\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mn_power_iterations\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    381\u001b[0m \u001b[38;5;66;03m# See above on why we need to clone\u001b[39;00m\n\u001b[1;32m    382\u001b[0m u \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_u\u001b[38;5;241m.\u001b[39mclone(memory_format\u001b[38;5;241m=\u001b[39mtorch\u001b[38;5;241m.\u001b[39mcontiguous_format)\n",
      "File \u001b[0;32m~/miniconda3/envs/torch/lib/python3.9/site-packages/torch/autograd/grad_mode.py:27\u001b[0m, in \u001b[0;36m_DecoratorContextManager.__call__.<locals>.decorate_context\u001b[0;34m(*args, **kwargs)\u001b[0m\n\u001b[1;32m     24\u001b[0m \u001b[38;5;129m@functools\u001b[39m\u001b[38;5;241m.\u001b[39mwraps(func)\n\u001b[1;32m     25\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21mdecorate_context\u001b[39m(\u001b[38;5;241m*\u001b[39margs, \u001b[38;5;241m*\u001b[39m\u001b[38;5;241m*\u001b[39mkwargs):\n\u001b[1;32m     26\u001b[0m     \u001b[38;5;28;01mwith\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mclone():\n\u001b[0;32m---> 27\u001b[0m         \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[43mfunc\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43margs\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43mkwargs\u001b[49m\u001b[43m)\u001b[49m\n",
      "File \u001b[0;32m~/miniconda3/envs/torch/lib/python3.9/site-packages/torch/nn/utils/parametrizations.py:370\u001b[0m, in \u001b[0;36m_SpectralNorm._power_method\u001b[0;34m(self, weight_mat, n_power_iterations)\u001b[0m\n\u001b[1;32m    364\u001b[0m \u001b[38;5;28;01mfor\u001b[39;00m _ \u001b[38;5;129;01min\u001b[39;00m \u001b[38;5;28mrange\u001b[39m(n_power_iterations):\n\u001b[1;32m    365\u001b[0m     \u001b[38;5;66;03m# Spectral norm of weight equals to `u^T W v`, where `u` and `v`\u001b[39;00m\n\u001b[1;32m    366\u001b[0m     \u001b[38;5;66;03m# are the first left and right singular vectors.\u001b[39;00m\n\u001b[1;32m    367\u001b[0m     \u001b[38;5;66;03m# This power iteration produces approximations of `u` and `v`.\u001b[39;00m\n\u001b[1;32m    368\u001b[0m     \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_u \u001b[38;5;241m=\u001b[39m F\u001b[38;5;241m.\u001b[39mnormalize(torch\u001b[38;5;241m.\u001b[39mmv(weight_mat, \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_v),      \u001b[38;5;66;03m# type: ignore[has-type]\u001b[39;00m\n\u001b[1;32m    369\u001b[0m                           dim\u001b[38;5;241m=\u001b[39m\u001b[38;5;241m0\u001b[39m, eps\u001b[38;5;241m=\u001b[39m\u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39meps, out\u001b[38;5;241m=\u001b[39m\u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_u)   \u001b[38;5;66;03m# type: ignore[has-type]\u001b[39;00m\n\u001b[0;32m--> 370\u001b[0m     \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_v \u001b[38;5;241m=\u001b[39m \u001b[43mF\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mnormalize\u001b[49m\u001b[43m(\u001b[49m\u001b[43mtorch\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mmv\u001b[49m\u001b[43m(\u001b[49m\u001b[43mweight_mat\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mt\u001b[49m\u001b[43m(\u001b[49m\u001b[43m)\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43m_u\u001b[49m\u001b[43m)\u001b[49m\u001b[43m,\u001b[49m\n\u001b[1;32m    371\u001b[0m \u001b[43m                          \u001b[49m\u001b[43mdim\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;241;43m0\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43meps\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43meps\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mout\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43m_v\u001b[49m\u001b[43m)\u001b[49m\n",
      "File \u001b[0;32m~/miniconda3/envs/torch/lib/python3.9/site-packages/torch/nn/functional.py:4624\u001b[0m, in \u001b[0;36mnormalize\u001b[0;34m(input, p, dim, eps, out)\u001b[0m\n\u001b[1;32m   4622\u001b[0m \u001b[38;5;28;01melse\u001b[39;00m:\n\u001b[1;32m   4623\u001b[0m     denom \u001b[38;5;241m=\u001b[39m \u001b[38;5;28minput\u001b[39m\u001b[38;5;241m.\u001b[39mnorm(p, dim, keepdim\u001b[38;5;241m=\u001b[39m\u001b[38;5;28;01mTrue\u001b[39;00m)\u001b[38;5;241m.\u001b[39mclamp_min_(eps)\u001b[38;5;241m.\u001b[39mexpand_as(\u001b[38;5;28minput\u001b[39m)\n\u001b[0;32m-> 4624\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[43mtorch\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mdiv\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;28;43minput\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mdenom\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mout\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mout\u001b[49m\u001b[43m)\u001b[49m\n",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m: "
     ]
    }
   ],
   "source": [
    "content_losses = []\n",
    "content_accs = []\n",
    "style_losses = []\n",
    "style_accs = []\n",
    "for epoch in range(epochs):\n",
    "    mean_content_loss = 0.0\n",
    "    mean_content_acc = 0.0\n",
    "    mean_style_loss = 0.0\n",
    "    mean_style_acc = 0.0\n",
    "    for i, (x, y) in enumerate(test_loader):\n",
    "        x, y = x.to(device), y.to(device)\n",
    "        # Get features from discriminators\n",
    "        with torch.no_grad():\n",
    "            _, content_features = global_model.contentD(x, return_h=True)\n",
    "            _, style_features = global_model.styleD(x, return_h=True)\n",
    "        # Get predictions from classifiers\n",
    "        content_pred = content_classifier(content_features)\n",
    "        content_y = content_pred.max(dim=1).indices\n",
    "        style_pred = style_classifier(style_features)\n",
    "        style_y = style_pred.max(dim=1).indices\n",
    "        # Calculate loss and optimize\n",
    "        content_loss = loss_fn(content_pred, y)\n",
    "        style_loss = loss_fn(style_pred, y)\n",
    "        content_classifier_optim.zero_grad()\n",
    "        style_classifier_optim.zero_grad()\n",
    "        content_loss.backward()\n",
    "        style_loss.backward()\n",
    "        content_classifier_optim.step()\n",
    "        style_classifier_optim.step()\n",
    "        # Calculate accuracies\n",
    "        content_acc = (content_y == y).sum() / y.size(0)\n",
    "        style_acc = (style_y == y).sum() / y.size(0)\n",
    "        # accumulate mean losses and accs\n",
    "        mean_content_loss += content_loss.item() / len(test_loader)\n",
    "        mean_content_acc += content_acc.item() / len(test_loader)\n",
    "        mean_style_loss += style_loss.item() / len(test_loader)\n",
    "        mean_style_acc += style_acc.item() / len(test_loader)\n",
    "    # Record epoch mean loss and acc\n",
    "    content_losses.append(mean_content_loss)\n",
    "    content_accs.append(mean_content_acc)\n",
    "    style_losses.append(mean_style_loss)\n",
    "    style_accs.append(mean_style_acc)\n",
    "    print(f\"[{epoch+1}/{epochs}] \"  #[{i+1}/{len(test_loader)}] \"\n",
    "          f\"content_loss = {mean_content_loss:4f}\\t\"\n",
    "          f\"content_acc = {mean_content_acc:4f}\\t\"\n",
    "          f\"style_loss = {mean_style_loss:4f}\\t\"\n",
    "          f\"style_acc = {mean_style_acc:4f}\"\n",
    "         )\n",
    "    content_classifier_optim_sched.step()\n",
    "    style_classifier_optim_sched.step()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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cOFCiwZIRETUmtUrUSckJKBv374AgG+++QbdunXDvn37sHLlSsTFxVkyPiIiolatXom6uLgYWq0WALBt2zbce++9AIBOnTohNTXVctERERG1cvVK1F27dsWyZcvw66+/Ij4+HsOHDwcApKSkwNPT06IBEhERtWb1StRvvfUWPv74YwwePBgTJkxAREQEAOD77783NYkTERFRw0lCCFGfDfV6PbKzs+Hu7m4qu3DhAhwcHODj42OxAC0tOzsbrq6uyMrKgouLi9LhEBFRK1SXXFSvK+qCggLodDpTkr548SLee+89nDlzxqqTNBERUXNTr0Q9evRofPnllwCAzMxM9OvXD++88w5iYmKwdOlSiwZIRETUmtUrUR8+fBgDBgwAAKxbtw6+vr64ePEivvzyS3zwwQcWDZCIiKg1q1eizs/Ph7OzMwDg559/xtixY6FSqXDbbbfh4sWLFg2QiIioNatXom7Xrh02bNiA5ORk/PTTTxg2bBgAICMjgx20iIiILKheiXr+/Pl45plnEBoair59+yIyMhKAfHXds2dPiwZIRETUmtX78ay0tDSkpqYiIiICKpWc7w8ePAgXFxd06tTJokFaEh/PIiIipdUlF9nU90v8/Pzg5+dneotWYGAgBzshIiKysHo1fRsMBixcuBCurq4ICQlBSEgI3Nzc8K9//QsGg8HSMRIREbVa9bqifumll/D555/jzTffRP/+/QEAe/bswauvvorCwkK88cYbFg2SiIiotarXPeqAgAAsW7bM9NYso40bN2LGjBm4fPmyxQK0NN6jJiIipTX6EKLXr1+vssNYp06dcP369frskoiIiKpQr0QdERGBJUuWVCpfsmQJwsPDGxwUERERyeqVqBcvXozly5ejS5cueOSRR/DII4+gS5cuiIuLw9tvv13r/fzyyy8YNWoUAgICIEkSNmzYcNNtdu3ahVtvvRVarRbt2rVDXFxcfQ6BiIioWahXoh40aBDOnj2LMWPGIDMzE5mZmRg7dixOnjyJ//3vf7XeT15eHiIiIvDRRx/Vqv758+cxcuRI3HnnnTh69CjmzJmDadOm4aeffqrPYRAREVm9eg94UpVjx47h1ltvhV6vr3sgkoT169cjJiam2jrPP/88Nm/ejISEBFPZAw88gMzMTGzdurVW32PJzmTHL2XiSFImRnT3g4+zXYP2RURErUeT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",
      "text/plain": [
       "<Figure size 500x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 500x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure()\n",
    "plt.plot(np.array(moving_avg(content_losses)), label=\"content\", linestyle='solid')\n",
    "plt.plot(np.array(moving_avg(style_losses)), label=\"style\", linestyle='dashed')\n",
    "plt.title(\"Cross Entropy Loss\")\n",
    "plt.ylabel(\"Loss\")\n",
    "plt.xlabel(\"Epochs\")\n",
    "plt.legend()\n",
    "plt.tight_layout()\n",
    "# plt.savefig(f\"results/{classifier_name}{'_cond' if conditional else ''}_loss_one_style.pdf\")\n",
    "\n",
    "plt.figure()\n",
    "plt.plot(np.array(moving_avg(content_accs)), label=\"content\", linestyle='solid')\n",
    "plt.plot(np.array(moving_avg(style_accs)), label=\"style\", linestyle='dashed')\n",
    "plt.title(\"Accuracy\")\n",
    "plt.ylabel(\"Accuracy\")\n",
    "plt.xlabel(\"Epochs\")\n",
    "plt.legend()\n",
    "plt.tight_layout()\n",
    "# plt.savefig(f\"results/{classifier_name}{'_cond' if conditional else ''}_acc_one_style.pdf\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Train a classifier on all style features"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[0, 1, 2, 3, 4, 5, 6, 7]"
      ]
     },
     "execution_count": 25,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "global_model, private_modules = load_fedgan_all_styles(global_model, model_paths[-1], device=device)\n",
    "[m[\"id\"] for m in private_modules]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "content_classifier = make_classifier(global_model.contentD.num_features).to(device)\n",
    "content_classifier_optim = torch.optim.Adam(content_classifier.parameters(), lr=lr)\n",
    "content_classifier_optim_sched = torch.optim.lr_scheduler.ExponentialLR(content_classifier_optim, gamma=lr_gamma)\n",
    "\n",
    "for m in private_modules:\n",
    "    m[\"classifier\"] = make_classifier(global_model.styleD.num_features).to(device)\n",
    "    m[\"classifier_optim\"] = torch.optim.Adam(m[\"classifier\"].parameters(), lr=lr)\n",
    "    m[\"classifier_optim_sched\"] = torch.optim.lr_scheduler.ExponentialLR(m[\"classifier_optim\"], gamma=lr_gamma)\n",
    "\n",
    "loss_fn = nn.CrossEntropyLoss().to(device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[1/50] content_loss = 0.837149\tcontent_acc = 0.810304\tstyle[0]_loss = 2.242249\tstyle[0]_acc = 0.167432\tstyle[1]_loss = 2.290345\tstyle[1]_acc = 0.137181\tstyle[2]_loss = 2.277318\tstyle[2]_acc = 0.148163\tstyle[3]_loss = 2.225122\tstyle[3]_acc = 0.211562\tstyle[4]_loss = 2.226882\tstyle[4]_acc = 0.204872\tstyle[5]_loss = 2.191709\tstyle[5]_acc = 0.197484\tstyle[6]_loss = 2.153227\tstyle[6]_acc = 0.207967\tstyle[7]_loss = 2.237788\tstyle[7]_acc = 0.187700\n",
      "[2/50] content_loss = 0.284644\tcontent_acc = 0.937200\tstyle[0]_loss = 2.198197\tstyle[0]_acc = 0.200879\tstyle[1]_loss = 2.250599\tstyle[1]_acc = 0.179413\tstyle[2]_loss = 2.224299\tstyle[2]_acc = 0.192692\tstyle[3]_loss = 2.090625\tstyle[3]_acc = 0.287640\tstyle[4]_loss = 2.156717\tstyle[4]_acc = 0.252496\tstyle[5]_loss = 2.112485\tstyle[5]_acc = 0.247604\tstyle[6]_loss = 2.073969\tstyle[6]_acc = 0.244708\tstyle[7]_loss = 2.153526\tstyle[7]_acc = 0.240216\n",
      "[3/50] content_loss = 0.209404\tcontent_acc = 0.948982\tstyle[0]_loss = 2.169133\tstyle[0]_acc = 0.225539\tstyle[1]_loss = 2.220008\tstyle[1]_acc = 0.210863\tstyle[2]_loss = 2.194065\tstyle[2]_acc = 0.211362\tstyle[3]_loss = 2.008253\tstyle[3]_acc = 0.323682\tstyle[4]_loss = 2.113845\tstyle[4]_acc = 0.283147\tstyle[5]_loss = 2.069486\tstyle[5]_acc = 0.281050\tstyle[6]_loss = 2.047430\tstyle[6]_acc = 0.261981\tstyle[7]_loss = 2.102564\tstyle[7]_acc = 0.262879\n",
      "[4/50] content_loss = 0.174980\tcontent_acc = 0.954772\tstyle[0]_loss = 2.143376\tstyle[0]_acc = 0.247005\tstyle[1]_loss = 2.192944\tstyle[1]_acc = 0.236522\tstyle[2]_loss = 2.172236\tstyle[2]_acc = 0.227436\tstyle[3]_loss = 1.950084\tstyle[3]_acc = 0.349940\tstyle[4]_loss = 2.078084\tstyle[4]_acc = 0.306210\tstyle[5]_loss = 2.032857\tstyle[5]_acc = 0.306310\tstyle[6]_loss = 2.026440\tstyle[6]_acc = 0.276158\tstyle[7]_loss = 2.063499\tstyle[7]_acc = 0.281550\n",
      "[5/50] content_loss = 0.154585\tcontent_acc = 0.960763\tstyle[0]_loss = 2.120493\tstyle[0]_acc = 0.263279\tstyle[1]_loss = 2.168777\tstyle[1]_acc = 0.258786\tstyle[2]_loss = 2.154403\tstyle[2]_acc = 0.243710\tstyle[3]_loss = 1.905347\tstyle[3]_acc = 0.366314\tstyle[4]_loss = 2.046865\tstyle[4]_acc = 0.324980\tstyle[5]_loss = 2.000099\tstyle[5]_acc = 0.329673\tstyle[6]_loss = 2.007904\tstyle[6]_acc = 0.290335\tstyle[7]_loss = 2.031612\tstyle[7]_acc = 0.297724\n",
      "[6/50] content_loss = 0.141051\tcontent_acc = 0.963458\tstyle[0]_loss = 2.100079\tstyle[0]_acc = 0.274461\tstyle[1]_loss = 2.147099\tstyle[1]_acc = 0.274161\tstyle[2]_loss = 2.138962\tstyle[2]_acc = 0.259085\tstyle[3]_loss = 1.869068\tstyle[3]_acc = 0.384784\tstyle[4]_loss = 2.019195\tstyle[4]_acc = 0.339956\tstyle[5]_loss = 1.970646\tstyle[5]_acc = 0.349241\tstyle[6]_loss = 1.991070\tstyle[6]_acc = 0.303415\tstyle[7]_loss = 2.004786\tstyle[7]_acc = 0.310503\n",
      "[7/50] content_loss = 0.131150\tcontent_acc = 0.964557\tstyle[0]_loss = 2.081765\tstyle[0]_acc = 0.282748\tstyle[1]_loss = 2.127557\tstyle[1]_acc = 0.285443\tstyle[2]_loss = 2.125185\tstyle[2]_acc = 0.270068\tstyle[3]_loss = 1.838589\tstyle[3]_acc = 0.398862\tstyle[4]_loss = 1.994453\tstyle[4]_acc = 0.353734\tstyle[5]_loss = 1.944065\tstyle[5]_acc = 0.367412\tstyle[6]_loss = 1.975619\tstyle[6]_acc = 0.314197\tstyle[7]_loss = 1.981783\tstyle[7]_acc = 0.321486\n",
      "[8/50] content_loss = 0.123348\tcontent_acc = 0.966254\tstyle[0]_loss = 2.065250\tstyle[0]_acc = 0.292033\tstyle[1]_loss = 2.109855\tstyle[1]_acc = 0.294629\tstyle[2]_loss = 2.112685\tstyle[2]_acc = 0.280950\tstyle[3]_loss = 1.812346\tstyle[3]_acc = 0.411641\tstyle[4]_loss = 1.972193\tstyle[4]_acc = 0.366114\tstyle[5]_loss = 1.919979\tstyle[5]_acc = 0.382588\tstyle[6]_loss = 1.961353\tstyle[6]_acc = 0.324880\tstyle[7]_loss = 1.961762\tstyle[7]_acc = 0.331669\n",
      "[9/50] content_loss = 0.116932\tcontent_acc = 0.968051\tstyle[0]_loss = 2.050288\tstyle[0]_acc = 0.300319\tstyle[1]_loss = 2.093750\tstyle[1]_acc = 0.304213\tstyle[2]_loss = 2.101226\tstyle[2]_acc = 0.292931\tstyle[3]_loss = 1.789337\tstyle[3]_acc = 0.424521\tstyle[4]_loss = 1.952056\tstyle[4]_acc = 0.376098\tstyle[5]_loss = 1.898066\tstyle[5]_acc = 0.396066\tstyle[6]_loss = 1.948136\tstyle[6]_acc = 0.337460\tstyle[7]_loss = 1.944130\tstyle[7]_acc = 0.340954\n",
      "[10/50] content_loss = 0.111531\tcontent_acc = 0.968550\tstyle[0]_loss = 2.036676\tstyle[0]_acc = 0.308606\tstyle[1]_loss = 2.079041\tstyle[1]_acc = 0.309405\tstyle[2]_loss = 2.090649\tstyle[2]_acc = 0.302416\tstyle[3]_loss = 1.768889\tstyle[3]_acc = 0.434405\tstyle[4]_loss = 1.933758\tstyle[4]_acc = 0.384385\tstyle[5]_loss = 1.878060\tstyle[5]_acc = 0.408147\tstyle[6]_loss = 1.935861\tstyle[6]_acc = 0.345847\tstyle[7]_loss = 1.928457\tstyle[7]_acc = 0.348043\n",
      "[11/50] content_loss = 0.106911\tcontent_acc = 0.969449\tstyle[0]_loss = 2.024242\tstyle[0]_acc = 0.313998\tstyle[1]_loss = 2.065562\tstyle[1]_acc = 0.315196\tstyle[2]_loss = 2.080840\tstyle[2]_acc = 0.311901\tstyle[3]_loss = 1.750530\tstyle[3]_acc = 0.443890\tstyle[4]_loss = 1.917061\tstyle[4]_acc = 0.391474\tstyle[5]_loss = 1.859733\tstyle[5]_acc = 0.418131\tstyle[6]_loss = 1.924432\tstyle[6]_acc = 0.353934\tstyle[7]_loss = 1.914414\tstyle[7]_acc = 0.354533\n",
      "[12/50] content_loss = 0.102919\tcontent_acc = 0.970048\tstyle[0]_loss = 2.012847\tstyle[0]_acc = 0.318890\tstyle[1]_loss = 2.053171\tstyle[1]_acc = 0.320188\tstyle[2]_loss = 2.071714\tstyle[2]_acc = 0.320088\tstyle[3]_loss = 1.733915\tstyle[3]_acc = 0.450479\tstyle[4]_loss = 1.901775\tstyle[4]_acc = 0.399161\tstyle[5]_loss = 1.842896\tstyle[5]_acc = 0.429912\tstyle[6]_loss = 1.913772\tstyle[6]_acc = 0.359625\tstyle[7]_loss = 1.901751\tstyle[7]_acc = 0.362320\n",
      "[13/50] content_loss = 0.099440\tcontent_acc = 0.970547\tstyle[0]_loss = 2.002370\tstyle[0]_acc = 0.323482\tstyle[1]_loss = 2.041750\tstyle[1]_acc = 0.325978\tstyle[2]_loss = 2.063202\tstyle[2]_acc = 0.327177\tstyle[3]_loss = 1.718784\tstyle[3]_acc = 0.458167\tstyle[4]_loss = 1.887736\tstyle[4]_acc = 0.406749\tstyle[5]_loss = 1.827387\tstyle[5]_acc = 0.438998\tstyle[6]_loss = 1.903815\tstyle[6]_acc = 0.365815\tstyle[7]_loss = 1.890270\tstyle[7]_acc = 0.368710\n",
      "[14/50] content_loss = 0.096391\tcontent_acc = 0.971546\tstyle[0]_loss = 1.992712\tstyle[0]_acc = 0.327576\tstyle[1]_loss = 2.031198\tstyle[1]_acc = 0.331470\tstyle[2]_loss = 2.055247\tstyle[2]_acc = 0.334565\tstyle[3]_loss = 1.704936\tstyle[3]_acc = 0.466254\tstyle[4]_loss = 1.874808\tstyle[4]_acc = 0.410942\tstyle[5]_loss = 1.813067\tstyle[5]_acc = 0.447185\tstyle[6]_loss = 1.894506\tstyle[6]_acc = 0.370807\tstyle[7]_loss = 1.879814\tstyle[7]_acc = 0.373602\n",
      "[15/50] content_loss = 0.093697\tcontent_acc = 0.971845\tstyle[0]_loss = 1.983786\tstyle[0]_acc = 0.331170\tstyle[1]_loss = 2.021428\tstyle[1]_acc = 0.335663\tstyle[2]_loss = 2.047805\tstyle[2]_acc = 0.341653\tstyle[3]_loss = 1.692212\tstyle[3]_acc = 0.473043\tstyle[4]_loss = 1.862876\tstyle[4]_acc = 0.414637\tstyle[5]_loss = 1.799817\tstyle[5]_acc = 0.455871\tstyle[6]_loss = 1.885793\tstyle[6]_acc = 0.378395\tstyle[7]_loss = 1.870252\tstyle[7]_acc = 0.378195\n",
      "[16/50] content_loss = 0.091295\tcontent_acc = 0.972843\tstyle[0]_loss = 1.975517\tstyle[0]_acc = 0.334864\tstyle[1]_loss = 2.012364\tstyle[1]_acc = 0.338758\tstyle[2]_loss = 2.040831\tstyle[2]_acc = 0.347444\tstyle[3]_loss = 1.680482\tstyle[3]_acc = 0.479034\tstyle[4]_loss = 1.851837\tstyle[4]_acc = 0.421026\tstyle[5]_loss = 1.787533\tstyle[5]_acc = 0.461462\tstyle[6]_loss = 1.877628\tstyle[6]_acc = 0.382987\tstyle[7]_loss = 1.861482\tstyle[7]_acc = 0.382788\n",
      "[17/50] content_loss = 0.089136\tcontent_acc = 0.973343\tstyle[0]_loss = 1.967845\tstyle[0]_acc = 0.337760\tstyle[1]_loss = 2.003941\tstyle[1]_acc = 0.343251\tstyle[2]_loss = 2.034293\tstyle[2]_acc = 0.351637\tstyle[3]_loss = 1.669639\tstyle[3]_acc = 0.484625\tstyle[4]_loss = 1.841606\tstyle[4]_acc = 0.425919\tstyle[5]_loss = 1.776123\tstyle[5]_acc = 0.468251\tstyle[6]_loss = 1.869972\tstyle[6]_acc = 0.385683\tstyle[7]_loss = 1.853412\tstyle[7]_acc = 0.387780\n",
      "[18/50] content_loss = 0.087181\tcontent_acc = 0.973542\tstyle[0]_loss = 1.960713\tstyle[0]_acc = 0.342552\tstyle[1]_loss = 1.996100\tstyle[1]_acc = 0.347943\tstyle[2]_loss = 2.028156\tstyle[2]_acc = 0.354832\tstyle[3]_loss = 1.659592\tstyle[3]_acc = 0.490615\tstyle[4]_loss = 1.832107\tstyle[4]_acc = 0.430411\tstyle[5]_loss = 1.765510\tstyle[5]_acc = 0.474541\tstyle[6]_loss = 1.862787\tstyle[6]_acc = 0.391174\tstyle[7]_loss = 1.845970\tstyle[7]_acc = 0.391074\n",
      "[19/50] content_loss = 0.085402\tcontent_acc = 0.974141\tstyle[0]_loss = 1.954075\tstyle[0]_acc = 0.345547\tstyle[1]_loss = 1.988793\tstyle[1]_acc = 0.351138\tstyle[2]_loss = 2.022394\tstyle[2]_acc = 0.359525\tstyle[3]_loss = 1.650266\tstyle[3]_acc = 0.493910\tstyle[4]_loss = 1.823274\tstyle[4]_acc = 0.434904\tstyle[5]_loss = 1.755622\tstyle[5]_acc = 0.481030\tstyle[6]_loss = 1.856040\tstyle[6]_acc = 0.395467\tstyle[7]_loss = 1.839091\tstyle[7]_acc = 0.396565\n",
      "[20/50] content_loss = 0.083776\tcontent_acc = 0.974341\tstyle[0]_loss = 1.947886\tstyle[0]_acc = 0.349042\tstyle[1]_loss = 1.981974\tstyle[1]_acc = 0.355232\tstyle[2]_loss = 2.016978\tstyle[2]_acc = 0.363918\tstyle[3]_loss = 1.641592\tstyle[3]_acc = 0.498403\tstyle[4]_loss = 1.815049\tstyle[4]_acc = 0.438399\tstyle[5]_loss = 1.746397\tstyle[5]_acc = 0.487021\tstyle[6]_loss = 1.849701\tstyle[6]_acc = 0.400160\tstyle[7]_loss = 1.832721\tstyle[7]_acc = 0.399062\n",
      "[21/50] content_loss = 0.082288\tcontent_acc = 0.974541\tstyle[0]_loss = 1.942112\tstyle[0]_acc = 0.352835\tstyle[1]_loss = 1.975604\tstyle[1]_acc = 0.357129\tstyle[2]_loss = 2.011887\tstyle[2]_acc = 0.368910\tstyle[3]_loss = 1.633513\tstyle[3]_acc = 0.501697\tstyle[4]_loss = 1.807380\tstyle[4]_acc = 0.441893\tstyle[5]_loss = 1.737780\tstyle[5]_acc = 0.491014\tstyle[6]_loss = 1.843742\tstyle[6]_acc = 0.403255\tstyle[7]_loss = 1.826809\tstyle[7]_acc = 0.402656\n",
      "[22/50] content_loss = 0.080923\tcontent_acc = 0.974441\tstyle[0]_loss = 1.936718\tstyle[0]_acc = 0.356430\tstyle[1]_loss = 1.969646\tstyle[1]_acc = 0.360323\tstyle[2]_loss = 2.007099\tstyle[2]_acc = 0.373502\tstyle[3]_loss = 1.625979\tstyle[3]_acc = 0.505691\tstyle[4]_loss = 1.800221\tstyle[4]_acc = 0.446086\tstyle[5]_loss = 1.729722\tstyle[5]_acc = 0.493710\tstyle[6]_loss = 1.838135\tstyle[6]_acc = 0.407348\tstyle[7]_loss = 1.821315\tstyle[7]_acc = 0.405451\n",
      "[23/50] content_loss = 0.079665\tcontent_acc = 0.974441\tstyle[0]_loss = 1.931676\tstyle[0]_acc = 0.359026\tstyle[1]_loss = 1.964070\tstyle[1]_acc = 0.364117\tstyle[2]_loss = 2.002595\tstyle[2]_acc = 0.377995\tstyle[3]_loss = 1.618944\tstyle[3]_acc = 0.508686\tstyle[4]_loss = 1.793531\tstyle[4]_acc = 0.448882\tstyle[5]_loss = 1.722178\tstyle[5]_acc = 0.497005\tstyle[6]_loss = 1.832860\tstyle[6]_acc = 0.410543\tstyle[7]_loss = 1.816203\tstyle[7]_acc = 0.407748\n",
      "[24/50] content_loss = 0.078501\tcontent_acc = 0.975040\tstyle[0]_loss = 1.926957\tstyle[0]_acc = 0.361821\tstyle[1]_loss = 1.958846\tstyle[1]_acc = 0.367412\tstyle[2]_loss = 1.998357\tstyle[2]_acc = 0.379992\tstyle[3]_loss = 1.612366\tstyle[3]_acc = 0.512081\tstyle[4]_loss = 1.787273\tstyle[4]_acc = 0.451078\tstyle[5]_loss = 1.715109\tstyle[5]_acc = 0.499900\tstyle[6]_loss = 1.827893\tstyle[6]_acc = 0.413039\tstyle[7]_loss = 1.811439\tstyle[7]_acc = 0.408646\n",
      "[25/50] content_loss = 0.077415\tcontent_acc = 0.975140\tstyle[0]_loss = 1.922538\tstyle[0]_acc = 0.363918\tstyle[1]_loss = 1.953947\tstyle[1]_acc = 0.371506\tstyle[2]_loss = 1.994367\tstyle[2]_acc = 0.384485\tstyle[3]_loss = 1.606211\tstyle[3]_acc = 0.514277\tstyle[4]_loss = 1.781412\tstyle[4]_acc = 0.454373\tstyle[5]_loss = 1.708479\tstyle[5]_acc = 0.501398\tstyle[6]_loss = 1.823216\tstyle[6]_acc = 0.415136\tstyle[7]_loss = 1.806994\tstyle[7]_acc = 0.411641\n",
      "[26/50] content_loss = 0.076394\tcontent_acc = 0.975140\tstyle[0]_loss = 1.918397\tstyle[0]_acc = 0.364816\tstyle[1]_loss = 1.949351\tstyle[1]_acc = 0.373602\tstyle[2]_loss = 1.990610\tstyle[2]_acc = 0.387480\tstyle[3]_loss = 1.600445\tstyle[3]_acc = 0.517472\tstyle[4]_loss = 1.775920\tstyle[4]_acc = 0.457368\tstyle[5]_loss = 1.702257\tstyle[5]_acc = 0.503994\tstyle[6]_loss = 1.818809\tstyle[6]_acc = 0.418331\tstyle[7]_loss = 1.802839\tstyle[7]_acc = 0.413938\n",
      "[27/50] content_loss = 0.075430\tcontent_acc = 0.975739\tstyle[0]_loss = 1.914514\tstyle[0]_acc = 0.366314\tstyle[1]_loss = 1.945035\tstyle[1]_acc = 0.375899\tstyle[2]_loss = 1.987073\tstyle[2]_acc = 0.391773\tstyle[3]_loss = 1.595040\tstyle[3]_acc = 0.520467\tstyle[4]_loss = 1.770769\tstyle[4]_acc = 0.459165\tstyle[5]_loss = 1.696412\tstyle[5]_acc = 0.507488\tstyle[6]_loss = 1.814656\tstyle[6]_acc = 0.421625\tstyle[7]_loss = 1.798955\tstyle[7]_acc = 0.416034\n",
      "[28/50] content_loss = 0.074516\tcontent_acc = 0.976038\tstyle[0]_loss = 1.910870\tstyle[0]_acc = 0.368411\tstyle[1]_loss = 1.940980\tstyle[1]_acc = 0.377596\tstyle[2]_loss = 1.983741\tstyle[2]_acc = 0.394269\tstyle[3]_loss = 1.589969\tstyle[3]_acc = 0.522264\tstyle[4]_loss = 1.765934\tstyle[4]_acc = 0.462061\tstyle[5]_loss = 1.690920\tstyle[5]_acc = 0.509285\tstyle[6]_loss = 1.810739\tstyle[6]_acc = 0.423922\tstyle[7]_loss = 1.795319\tstyle[7]_acc = 0.418031\n",
      "[29/50] content_loss = 0.073650\tcontent_acc = 0.976538\tstyle[0]_loss = 1.907450\tstyle[0]_acc = 0.370707\tstyle[1]_loss = 1.937168\tstyle[1]_acc = 0.380391\tstyle[2]_loss = 1.980603\tstyle[2]_acc = 0.397464\tstyle[3]_loss = 1.585208\tstyle[3]_acc = 0.524960\tstyle[4]_loss = 1.761393\tstyle[4]_acc = 0.464956\tstyle[5]_loss = 1.685754\tstyle[5]_acc = 0.511182\tstyle[6]_loss = 1.807045\tstyle[6]_acc = 0.426917\tstyle[7]_loss = 1.791912\tstyle[7]_acc = 0.419828\n",
      "[30/50] content_loss = 0.072830\tcontent_acc = 0.976837\tstyle[0]_loss = 1.904238\tstyle[0]_acc = 0.373403\tstyle[1]_loss = 1.933582\tstyle[1]_acc = 0.383387\tstyle[2]_loss = 1.977646\tstyle[2]_acc = 0.399661\tstyle[3]_loss = 1.580734\tstyle[3]_acc = 0.526857\tstyle[4]_loss = 1.757124\tstyle[4]_acc = 0.466753\tstyle[5]_loss = 1.680895\tstyle[5]_acc = 0.512380\tstyle[6]_loss = 1.803559\tstyle[6]_acc = 0.429812\tstyle[7]_loss = 1.788716\tstyle[7]_acc = 0.421526\n",
      "[31/50] content_loss = 0.072053\tcontent_acc = 0.977236\tstyle[0]_loss = 1.901219\tstyle[0]_acc = 0.374002\tstyle[1]_loss = 1.930207\tstyle[1]_acc = 0.385383\tstyle[2]_loss = 1.974864\tstyle[2]_acc = 0.402057\tstyle[3]_loss = 1.576528\tstyle[3]_acc = 0.528954\tstyle[4]_loss = 1.753110\tstyle[4]_acc = 0.469249\tstyle[5]_loss = 1.676320\tstyle[5]_acc = 0.514776\tstyle[6]_loss = 1.800270\tstyle[6]_acc = 0.431809\tstyle[7]_loss = 1.785717\tstyle[7]_acc = 0.424121\n",
      "[32/50] content_loss = 0.071321\tcontent_acc = 0.977636\tstyle[0]_loss = 1.898382\tstyle[0]_acc = 0.374501\tstyle[1]_loss = 1.927030\tstyle[1]_acc = 0.387480\tstyle[2]_loss = 1.972243\tstyle[2]_acc = 0.405451\tstyle[3]_loss = 1.572571\tstyle[3]_acc = 0.531450\tstyle[4]_loss = 1.749333\tstyle[4]_acc = 0.470847\tstyle[5]_loss = 1.672012\tstyle[5]_acc = 0.516973\tstyle[6]_loss = 1.797165\tstyle[6]_acc = 0.434105\tstyle[7]_loss = 1.782899\tstyle[7]_acc = 0.425120\n",
      "[33/50] content_loss = 0.070628\tcontent_acc = 0.977736\tstyle[0]_loss = 1.895715\tstyle[0]_acc = 0.375799\tstyle[1]_loss = 1.924036\tstyle[1]_acc = 0.389277\tstyle[2]_loss = 1.969776\tstyle[2]_acc = 0.407448\tstyle[3]_loss = 1.568846\tstyle[3]_acc = 0.533147\tstyle[4]_loss = 1.745777\tstyle[4]_acc = 0.472644\tstyle[5]_loss = 1.667954\tstyle[5]_acc = 0.518470\tstyle[6]_loss = 1.794234\tstyle[6]_acc = 0.436701\tstyle[7]_loss = 1.780250\tstyle[7]_acc = 0.426018\n",
      "[34/50] content_loss = 0.069977\tcontent_acc = 0.977835\tstyle[0]_loss = 1.893205\tstyle[0]_acc = 0.377696\tstyle[1]_loss = 1.921215\tstyle[1]_acc = 0.390875\tstyle[2]_loss = 1.967455\tstyle[2]_acc = 0.410144\tstyle[3]_loss = 1.565338\tstyle[3]_acc = 0.534445\tstyle[4]_loss = 1.742428\tstyle[4]_acc = 0.473842\tstyle[5]_loss = 1.664129\tstyle[5]_acc = 0.520966\tstyle[6]_loss = 1.791467\tstyle[6]_acc = 0.439197\tstyle[7]_loss = 1.777758\tstyle[7]_acc = 0.427416\n",
      "[35/50] content_loss = 0.069363\tcontent_acc = 0.977835\tstyle[0]_loss = 1.890845\tstyle[0]_acc = 0.379493\tstyle[1]_loss = 1.918556\tstyle[1]_acc = 0.393770\tstyle[2]_loss = 1.965274\tstyle[2]_acc = 0.412340\tstyle[3]_loss = 1.562033\tstyle[3]_acc = 0.535942\tstyle[4]_loss = 1.739272\tstyle[4]_acc = 0.475938\tstyle[5]_loss = 1.660524\tstyle[5]_acc = 0.522764\tstyle[6]_loss = 1.788853\tstyle[6]_acc = 0.441394\tstyle[7]_loss = 1.775413\tstyle[7]_acc = 0.428614\n",
      "[36/50] content_loss = 0.068784\tcontent_acc = 0.978235\tstyle[0]_loss = 1.888623\tstyle[0]_acc = 0.381090\tstyle[1]_loss = 1.916048\tstyle[1]_acc = 0.394968\tstyle[2]_loss = 1.963224\tstyle[2]_acc = 0.414637\tstyle[3]_loss = 1.558917\tstyle[3]_acc = 0.537340\tstyle[4]_loss = 1.736297\tstyle[4]_acc = 0.477736\tstyle[5]_loss = 1.657124\tstyle[5]_acc = 0.524561\tstyle[6]_loss = 1.786385\tstyle[6]_acc = 0.442792\tstyle[7]_loss = 1.773205\tstyle[7]_acc = 0.428115\n",
      "[37/50] content_loss = 0.068239\tcontent_acc = 0.978435\tstyle[0]_loss = 1.886533\tstyle[0]_acc = 0.382188\tstyle[1]_loss = 1.913683\tstyle[1]_acc = 0.397464\tstyle[2]_loss = 1.961300\tstyle[2]_acc = 0.416833\tstyle[3]_loss = 1.555978\tstyle[3]_acc = 0.539637\tstyle[4]_loss = 1.733492\tstyle[4]_acc = 0.479633\tstyle[5]_loss = 1.653917\tstyle[5]_acc = 0.525459\tstyle[6]_loss = 1.784053\tstyle[6]_acc = 0.443890\tstyle[7]_loss = 1.771122\tstyle[7]_acc = 0.428814\n",
      "[38/50] content_loss = 0.067726\tcontent_acc = 0.978834\tstyle[0]_loss = 1.884564\tstyle[0]_acc = 0.383586\tstyle[1]_loss = 1.911451\tstyle[1]_acc = 0.398962\tstyle[2]_loss = 1.959496\tstyle[2]_acc = 0.418231\tstyle[3]_loss = 1.553206\tstyle[3]_acc = 0.541134\tstyle[4]_loss = 1.730846\tstyle[4]_acc = 0.481330\tstyle[5]_loss = 1.650891\tstyle[5]_acc = 0.525559\tstyle[6]_loss = 1.781852\tstyle[6]_acc = 0.445487\tstyle[7]_loss = 1.769159\tstyle[7]_acc = 0.429812\n",
      "[39/50] content_loss = 0.067242\tcontent_acc = 0.978934\tstyle[0]_loss = 1.882711\tstyle[0]_acc = 0.384185\tstyle[1]_loss = 1.909344\tstyle[1]_acc = 0.399062\tstyle[2]_loss = 1.957805\tstyle[2]_acc = 0.420228\tstyle[3]_loss = 1.550588\tstyle[3]_acc = 0.542432\tstyle[4]_loss = 1.728349\tstyle[4]_acc = 0.482328\tstyle[5]_loss = 1.648036\tstyle[5]_acc = 0.526857\tstyle[6]_loss = 1.779772\tstyle[6]_acc = 0.447284\tstyle[7]_loss = 1.767306\tstyle[7]_acc = 0.430911\n",
      "[40/50] content_loss = 0.066787\tcontent_acc = 0.978934\tstyle[0]_loss = 1.880966\tstyle[0]_acc = 0.384784\tstyle[1]_loss = 1.907357\tstyle[1]_acc = 0.400060\tstyle[2]_loss = 1.956223\tstyle[2]_acc = 0.420927\tstyle[3]_loss = 1.548118\tstyle[3]_acc = 0.543331\tstyle[4]_loss = 1.725993\tstyle[4]_acc = 0.483926\tstyle[5]_loss = 1.645341\tstyle[5]_acc = 0.528355\tstyle[6]_loss = 1.777808\tstyle[6]_acc = 0.448482\tstyle[7]_loss = 1.765558\tstyle[7]_acc = 0.431709\n",
      "[41/50] content_loss = 0.066356\tcontent_acc = 0.979034\tstyle[0]_loss = 1.879322\tstyle[0]_acc = 0.384884\tstyle[1]_loss = 1.905480\tstyle[1]_acc = 0.401258\tstyle[2]_loss = 1.954747\tstyle[2]_acc = 0.421625\tstyle[3]_loss = 1.545784\tstyle[3]_acc = 0.545627\tstyle[4]_loss = 1.723768\tstyle[4]_acc = 0.484325\tstyle[5]_loss = 1.642797\tstyle[5]_acc = 0.529852\tstyle[6]_loss = 1.775953\tstyle[6]_acc = 0.450080\tstyle[7]_loss = 1.763907\tstyle[7]_acc = 0.432508\n",
      "[42/50] content_loss = 0.065951\tcontent_acc = 0.979133\tstyle[0]_loss = 1.877775\tstyle[0]_acc = 0.385583\tstyle[1]_loss = 1.903708\tstyle[1]_acc = 0.402556\tstyle[2]_loss = 1.953369\tstyle[2]_acc = 0.422424\tstyle[3]_loss = 1.543579\tstyle[3]_acc = 0.546825\tstyle[4]_loss = 1.721668\tstyle[4]_acc = 0.485523\tstyle[5]_loss = 1.640395\tstyle[5]_acc = 0.530751\tstyle[6]_loss = 1.774201\tstyle[6]_acc = 0.451378\tstyle[7]_loss = 1.762347\tstyle[7]_acc = 0.432608\n",
      "[43/50] content_loss = 0.065567\tcontent_acc = 0.979433\tstyle[0]_loss = 1.876317\tstyle[0]_acc = 0.385982\tstyle[1]_loss = 1.902034\tstyle[1]_acc = 0.403854\tstyle[2]_loss = 1.952086\tstyle[2]_acc = 0.423123\tstyle[3]_loss = 1.541496\tstyle[3]_acc = 0.548323\tstyle[4]_loss = 1.719684\tstyle[4]_acc = 0.486322\tstyle[5]_loss = 1.638126\tstyle[5]_acc = 0.531649\tstyle[6]_loss = 1.772547\tstyle[6]_acc = 0.452077\tstyle[7]_loss = 1.760873\tstyle[7]_acc = 0.433007\n",
      "[44/50] content_loss = 0.065204\tcontent_acc = 0.979832\tstyle[0]_loss = 1.874943\tstyle[0]_acc = 0.387181\tstyle[1]_loss = 1.900455\tstyle[1]_acc = 0.406150\tstyle[2]_loss = 1.950894\tstyle[2]_acc = 0.424920\tstyle[3]_loss = 1.539527\tstyle[3]_acc = 0.548922\tstyle[4]_loss = 1.717811\tstyle[4]_acc = 0.486621\tstyle[5]_loss = 1.635983\tstyle[5]_acc = 0.532149\tstyle[6]_loss = 1.770985\tstyle[6]_acc = 0.452875\tstyle[7]_loss = 1.759480\tstyle[7]_acc = 0.433806\n",
      "[45/50] content_loss = 0.064859\tcontent_acc = 0.979832\tstyle[0]_loss = 1.873649\tstyle[0]_acc = 0.386681\tstyle[1]_loss = 1.898962\tstyle[1]_acc = 0.406350\tstyle[2]_loss = 1.949787\tstyle[2]_acc = 0.426318\tstyle[3]_loss = 1.537666\tstyle[3]_acc = 0.550319\tstyle[4]_loss = 1.716041\tstyle[4]_acc = 0.486821\tstyle[5]_loss = 1.633959\tstyle[5]_acc = 0.533247\tstyle[6]_loss = 1.769511\tstyle[6]_acc = 0.453774\tstyle[7]_loss = 1.758163\tstyle[7]_acc = 0.434006\n",
      "[46/50] content_loss = 0.064533\tcontent_acc = 0.980232\tstyle[0]_loss = 1.872430\tstyle[0]_acc = 0.387380\tstyle[1]_loss = 1.897554\tstyle[1]_acc = 0.407548\tstyle[2]_loss = 1.948761\tstyle[2]_acc = 0.427416\tstyle[3]_loss = 1.535907\tstyle[3]_acc = 0.550819\tstyle[4]_loss = 1.714368\tstyle[4]_acc = 0.487620\tstyle[5]_loss = 1.632047\tstyle[5]_acc = 0.533746\tstyle[6]_loss = 1.768120\tstyle[6]_acc = 0.454073\tstyle[7]_loss = 1.756918\tstyle[7]_acc = 0.434605\n",
      "[47/50] content_loss = 0.064223\tcontent_acc = 0.980531\tstyle[0]_loss = 1.871280\tstyle[0]_acc = 0.388978\tstyle[1]_loss = 1.896223\tstyle[1]_acc = 0.408746\tstyle[2]_loss = 1.947813\tstyle[2]_acc = 0.427915\tstyle[3]_loss = 1.534243\tstyle[3]_acc = 0.553215\tstyle[4]_loss = 1.712788\tstyle[4]_acc = 0.488019\tstyle[5]_loss = 1.630239\tstyle[5]_acc = 0.534844\tstyle[6]_loss = 1.766806\tstyle[6]_acc = 0.454872\tstyle[7]_loss = 1.755739\tstyle[7]_acc = 0.437001\n",
      "[48/50] content_loss = 0.063930\tcontent_acc = 0.980431\tstyle[0]_loss = 1.870197\tstyle[0]_acc = 0.389477\tstyle[1]_loss = 1.894967\tstyle[1]_acc = 0.409744\tstyle[2]_loss = 1.946936\tstyle[2]_acc = 0.429213\tstyle[3]_loss = 1.532670\tstyle[3]_acc = 0.554313\tstyle[4]_loss = 1.711294\tstyle[4]_acc = 0.489117\tstyle[5]_loss = 1.628531\tstyle[5]_acc = 0.535443\tstyle[6]_loss = 1.765567\tstyle[6]_acc = 0.455970\tstyle[7]_loss = 1.754625\tstyle[7]_acc = 0.437899\n",
      "[49/50] content_loss = 0.063651\tcontent_acc = 0.980531\tstyle[0]_loss = 1.869174\tstyle[0]_acc = 0.391174\tstyle[1]_loss = 1.893780\tstyle[1]_acc = 0.409744\tstyle[2]_loss = 1.946127\tstyle[2]_acc = 0.429513\tstyle[3]_loss = 1.531182\tstyle[3]_acc = 0.555112\tstyle[4]_loss = 1.709881\tstyle[4]_acc = 0.489816\tstyle[5]_loss = 1.626916\tstyle[5]_acc = 0.536542\tstyle[6]_loss = 1.764398\tstyle[6]_acc = 0.456769\tstyle[7]_loss = 1.753571\tstyle[7]_acc = 0.438399\n",
      "[50/50] content_loss = 0.063386\tcontent_acc = 0.980331\tstyle[0]_loss = 1.868210\tstyle[0]_acc = 0.391274\tstyle[1]_loss = 1.892659\tstyle[1]_acc = 0.411042\tstyle[2]_loss = 1.945379\tstyle[2]_acc = 0.430411\tstyle[3]_loss = 1.529775\tstyle[3]_acc = 0.556310\tstyle[4]_loss = 1.708545\tstyle[4]_acc = 0.489217\tstyle[5]_loss = 1.625388\tstyle[5]_acc = 0.536841\tstyle[6]_loss = 1.763296\tstyle[6]_acc = 0.456270\tstyle[7]_loss = 1.752573\tstyle[7]_acc = 0.438598\n"
     ]
    }
   ],
   "source": [
    "content_losses = []\n",
    "content_accs = []\n",
    "for m in private_modules:\n",
    "    m[\"losses\"] = []\n",
    "    m[\"accs\"] = []\n",
    "\n",
    "for epoch in range(epochs):\n",
    "    mean_content_loss = 0.0\n",
    "    mean_content_acc = 0.0\n",
    "    for m in private_modules:\n",
    "        m[\"mean_loss\"] = 0.0\n",
    "        m[\"mean_acc\"] = 0.0\n",
    "\n",
    "    for i, (x, y) in enumerate(test_loader):\n",
    "        x, y = x.to(device), y.to(device)\n",
    "        # Get features from discriminators\n",
    "        with torch.no_grad():\n",
    "            _, content_features = global_model.contentD(x, return_h=True)\n",
    "            all_style_features = [m[\"styleD\"](x, return_h=True)[1] for m in private_modules]\n",
    "        # Get predictions from classifiers\n",
    "        content_pred = content_classifier(content_features)\n",
    "        content_y = content_pred.max(dim=1).indices\n",
    "        all_style_pred = [m[\"classifier\"](f) for m, f in zip(private_modules, all_style_features)]\n",
    "        all_style_y = [pred.max(dim=1).indices for pred in all_style_pred]\n",
    "        # Calculate loss and optimize\n",
    "        content_loss = loss_fn(content_pred, y)\n",
    "        all_style_loss = [loss_fn(pred, y) for pred in all_style_pred]\n",
    "        content_classifier_optim.zero_grad()\n",
    "        [m[\"classifier_optim\"].zero_grad() for m in private_modules]\n",
    "        content_loss.backward()\n",
    "        [loss.backward() for loss in all_style_loss]\n",
    "        content_classifier_optim.step()\n",
    "        [m[\"classifier_optim\"].step() for m in private_modules]\n",
    "        # Calculate accuracies\n",
    "        content_acc = (content_y == y).sum() / y.size(0)\n",
    "        all_style_acc = [(style_y == y).sum() / y.size(0) for style_y in all_style_y]\n",
    "        # accumulate mean losses and accs\n",
    "        mean_content_loss += content_loss.item() / len(test_loader)\n",
    "        mean_content_acc += content_acc.item() / len(test_loader)\n",
    "        for m, loss, acc in zip(private_modules, all_style_loss, all_style_acc):\n",
    "            m[\"mean_loss\"] += loss.item() / len(test_loader)\n",
    "            m[\"mean_acc\"] += acc.item() / len(test_loader)\n",
    "    # Record epoch mean loss and acc\n",
    "    content_losses.append(mean_content_loss)\n",
    "    content_accs.append(mean_content_acc)\n",
    "    for m in private_modules:\n",
    "        m[\"losses\"].append(m[\"mean_loss\"])\n",
    "        m[\"accs\"].append(m[\"mean_acc\"])\n",
    "    print(f\"[{epoch+1}/{epochs}] \"  #[{i+1}/{len(test_loader)}] \"\n",
    "          f\"content_loss = {mean_content_loss:4f}\\t\"\n",
    "          f\"content_acc = {mean_content_acc:4f}\\t\"\n",
    "          + \"\\t\".join(\n",
    "              f\"style[{m['id']}]_loss = {m['mean_loss']:4f}\\t\"\n",
    "              f\"style[{m['id']}]_acc = {m['mean_acc']:4f}\"\n",
    "              for m in private_modules\n",
    "          )\n",
    "         )\n",
    "    content_classifier_optim_sched.step()\n",
    "    [m[\"classifier_optim_sched\"].step() for m in private_modules]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAeoAAAEiCAYAAAA21pHjAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/NK7nSAAAACXBIWXMAAA9hAAAPYQGoP6dpAACDyElEQVR4nOzdd5wU9f348dfMbN/b6x3uuKP33hFBQRCxYC+oqDHGiMaaYhJ78iPRmK81lmgsUWOLvUVEQUEsNAWkl6Ndb1tu68z8/pi9uVvuDikHd8jn+XjMY3Zn3jP72bnynvnMZz4fSdd1HUEQBEEQOiW5owsgCIIgCELbRKIWBEEQhE5MJGpBEARB6MREohYEQRCETkwkakEQBEHoxESiFgRBEIROTCRqQRAEQejERKIWBEEQhE5MJGpBEARB6MREohYEQRCETkwkakGI27JlC7/4xS/o3r07DoeD5ORkJkyYwIMPPkgwGOzo4u2XO++8E0mS2pzKysoOeJ8vvfQSDzzwQPsX9ggqKiri1FNP7ehiCMJBsXR0AQShM3j//fc599xzsdvtXHrppQwcOJBIJMLixYv59a9/zdq1a3nyySc7upj77bHHHiMpKanF8tTU1APe10svvcSaNWu44YYbDr1ggiAcMJGohWPetm3buOCCC+jWrRuffvopeXl55rq5c+eyefNm3n///Ta31zSNSCSCw+E4EsXdL+eccw6ZmZlH/HNDoRA2mw1ZFpV1gtBexF+TcMy799578fv9PP300wlJulHPnj25/vrrzfeSJHHttdfy4osvMmDAAOx2Ox999BEAK1euZMaMGSQnJ5OUlMSUKVP46quvEvYXjUa566676NWrFw6Hg4yMDI477jjmz59vxpSVlXH55ZfTtWtX7HY7eXl5nHHGGWzfvr1dvvPChQuRJIlXX32VP//5z3Tt2hWHw8GUKVPYvHmzGTd58mTef/99SkpKzOrzoqKihH28/PLL/PGPf6RLly64XC68Xi8Ar732GiNGjMDpdJKZmcnFF1/M7t27E8px2WWXkZSUxNatW5k+fTput5v8/HzuvvtuGgf203WdoqIizjjjjBbfIxQKkZKSwi9+8YtDPiaxWIx77rmHHj16YLfbKSoq4ve//z3hcDghbtmyZUyfPp3MzEycTifFxcVcccUVCTEvv/wyI0aMwOPxkJyczKBBg3jwwQcPuYzCsUlcUQvHvHfffZfu3bszfvz4/d7m008/5dVXX+Xaa68lMzOToqIi1q5dy8SJE0lOTuY3v/kNVquVJ554gsmTJ7No0SLGjBkDGPeR582bx5VXXsno0aPxer0sW7aMFStWcNJJJwFw9tlns3btWq677jqKioqoqKhg/vz57Nixw0yU+1JTU9NimcViaVH1/Ze//AVZlrnllluor6/n3nvvZfbs2Xz99dcA/OEPf6C+vp5du3bxf//3fwAtqtTvuecebDYbt9xyC+FwGJvNxrPPPsvll1/OqFGjmDdvHuXl5Tz44IMsWbKElStXJpRDVVVOPvlkxo4dy7333stHH33EHXfcQSwW4+6770aSJC6++GLuvfdeampqSE9PN7d999138Xq9XHzxxT96TH7MlVdeyXPPPcc555zDzTffzNdff828efNYt24db775JgAVFRVMmzaNrKwsfve735Gamsr27dt54403zP3Mnz+fCy+8kClTpvDXv/4VgHXr1rFkyZKEEz5B2G+6IBzD6uvrdUA/44wz9nsbQJdlWV+7dm3C8lmzZuk2m03fsmWLuWzPnj26x+PRjz/+eHPZkCFD9JkzZ7a5/9raWh3Q77vvvv3/InF33HGHDrQ69enTx4z77LPPdEDv16+fHg6HzeUPPvigDuirV682l82cOVPv1q1bi89q3Ef37t31hoYGc3kkEtGzs7P1gQMH6sFg0Fz+3nvv6YB+++23m8vmzJmjA/p1111nLtM0TZ85c6Zus9n0yspKXdd1fcOGDTqgP/bYYwllOP300/WioiJd07R9Hpdu3brt85ivWrVKB/Qrr7wyYfktt9yiA/qnn36q67quv/nmmzqgf/vtt23u6/rrr9eTk5P1WCy2zzIJwv4SVd/CMa2xmtbj8RzQdpMmTaJ///7me1VV+fjjj5k1axbdu3c3l+fl5XHRRRexePFi87NSU1NZu3YtmzZtanXfTqcTm83GwoULqa2tPdCvBMB///tf5s+fnzA988wzLeIuv/xybDab+X7ixIkAbN26db8/a86cOTidTvP9smXLqKio4Jprrkm4bz9z5kz69u3b6v3+a6+91nzdeGshEonwySefANC7d2/GjBnDiy++aMbV1NTw4YcfMnv2bCRJ2u/ytuaDDz4A4KabbkpYfvPNNwOYZW6sCXjvvfeIRqOt7is1NZVAIJBwK0MQDoVI1MIxLTk5GQCfz3dA2xUXFye8r6yspKGhgT59+rSI7devH5qmsXPnTgDuvvtu6urq6N27N4MGDeLXv/4133//vRlvt9v561//yocffkhOTg7HH38899577wE9WnX88cczderUhGncuHEt4goLCxPep6WlARzQCcLex6KkpASg1WPRt29fc30jWZYTTm7ASMxAwj35Sy+9lCVLlpjbv/baa0SjUS655JL9LmtbSkpKkGWZnj17JizPzc0lNTXV/MxJkyZx9tlnc9ddd5GZmckZZ5zBM888k3Af+5prrqF3797MmDGDrl27csUVV5htGAThYIhELRzTkpOTyc/PZ82aNQe0XfMryAN1/PHHs2XLFv71r38xcOBAnnrqKYYPH85TTz1lxtxwww1s3LiRefPm4XA4uO222+jXrx8rV6486M9tjaIorS7X4w259sehHIsDccEFF2C1Ws2r6hdeeIGRI0e2ekJwsH7sylySJF5//XWWLl3Ktddey+7du7niiisYMWIEfr8fgOzsbFatWsU777zD6aefzmeffcaMGTOYM2dOu5VTOLaIRC0c80499VS2bNnC0qVLD3ofWVlZuFwuNmzY0GLd+vXrkWWZgoICc1l6ejqXX345//nPf9i5cyeDBw/mzjvvTNiuR48e3HzzzXz88cesWbOGSCTC/ffff9BlPFgHWq3crVs3gFaPxYYNG8z1jTRNa1HVvnHjRoCEhnPp6enMnDmTF198kZKSEpYsWdIuV9ONZdY0rcXtiPLycurq6lqUeezYsfz5z39m2bJlvPjii6xdu5aXX37ZXG+z2TjttNP4xz/+YXak8/zzzye0qBeE/SUStXDM+81vfoPb7ebKK6+kvLy8xfotW7b86KM1iqIwbdo03n777YTq2vLycl566SWOO+44s5q9uro6YdukpCR69uxpVp82NDQQCoUSYnr06IHH42nxqNCR4Ha7qa+v3+/4kSNHkp2dzeOPP55Q3g8//JB169Yxc+bMFts88sgj5mtd13nkkUewWq1MmTIlIe6SSy7hhx9+4Ne//jWKonDBBRccxDdq6ZRTTgFo0QPb3//+dwCzzLW1tS1qG4YOHQpgfte9f76yLDN48OCEGEE4EOLxLOGY16NHD1566SXOP/98+vXrl9Az2Zdffslrr73GZZdd9qP7+dOf/sT8+fM57rjj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c8YZZxxQuQ7UQbX6XrhwIWeeeSZer5c5c+bwr3/9C4Df//73rF+//rA3VT8UotW3IAg/JftqWSx0rPZq9X1QNzImT55MVVUVXq+XtLQ0c/lVV10lhlkTBEEQhHZ0UFXfwWCQcDhsJumSkhIeeOABNmzYQHZ2drsWUBAEQRCOZQeVqM844wyef/55AOrq6hgzZgz3338/s2bN4rHHHmvXAgqCIAjCseygEvWKFSuYOHEiAK+//jo5OTmUlJTw/PPP89BDD7VrAQVBEAThWHZQibqhoQGPxwPAxx9/zFlnnYUsy4wdO5aSkpJ2LaAgCIIgHMsOKlH37NmTt956i507d/K///2PadOmAVBRUSFaUguCIAhCOzqoRH377bdzyy23UFRUxOjRoxk3bhxgXF0PGzasXQsoCIIgCMeyg3o865xzzuG4446jtLSUIUOGmMunTJnCmWee2W6FEwRBEIRj3UF3CJubm0tubq45ilbXrl3N/r8FQRAEQWgfB1X1rWkad999NykpKXTr1o1u3bqRmprKPffc02GjiwiCIAjHtqKiIh544IGOLka7O6gr6j/84Q88/fTT/OUvf2HChAmAMfD2nXfeSSgU4s9//nO7FlIQBEE4dlx22WXU1dXx1ltvdXRROoWDStTPPfccTz31lDlqFhgdnXfp0oVrrrlGJGpBEARBaCcHVfVdU1ND3759Wyzv27cvNTU1h1woQRAE4afv9ddfZ9CgQTidTjIyMpg6dSq//vWvee6553j77beRJAlJkli4cCEnnnhii6EoKysrsdlsLFiwoNX919XVceWVV5KVlUVycjInnngi33333ZH4au3qoBL1kCFDWh1u7JFHHmHw4MGHXChBEAThEEUCbU/R0AHEBvcv9gCVlpZy4YUXcsUVV7Bu3ToWLlzIWWedxR133MF5553HySefTGlpKaWlpYwfP54rr7ySl156iXA4bO7jhRdeoEuXLpx44omtfsa5555LRUUFH374IcuXL2f48OFMmTLlqLugPKiq73vvvZeZM2fyySefmM9QL126lJ07d/LBBx+0awEFQRCEg/D/9jG+cq9pMPu1pvf39YRoQ+ux3Y6Dy99vev/AIGiobhl3Z/0BFa+0tJRYLMZZZ51Ft27dABg0aBAATqeTcDhMbm6uGX/WWWdx7bXX8vbbb3PeeecB8Oyzz3LZZZchSVKL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uq7r+l/+8hc9NTVVf/vtt/Xvv/9eP+OMM/Ti4mI9GAx2cMk7zi9/+Us9JSVFX7hwoV5aWmpODQ0NZszVV1+tFxYW6p9++qm+bNkyfdy4cfq4ceM6sNQd73e/+52+aNEifdu2bfr333+v/+53v9MlSdI//vhjXdfFMdtfzVt967o4bq25+eab9YULF+rbtm3TlyxZok+dOlXPzMzUKyoqdF0/PMdMJOpD8PDDD+uFhYW6zWbTR48erX/11VcdXaRO5bPPPtOBFtOcOXN0XTce0brtttv0nJwc3W6361OmTNE3bNjQsYXuYK0dL0B/5plnzJhgMKhfc801elpamu5yufQzzzxTLy0t7bhCdwJXXHGF3q1bN91ms+lZWVn6lClTzCSt6+KY7a+9E7U4bi2df/75el5enm6z2fQuXbro559/vr5582Zz/eE4ZmL0LEEQBEHoxMQ9akEQBEHoxESiFgRBEIROTCRqQRAEQejERKIWBEEQhE5MJGpBEARB6MREohYEQRCETkwkakEQBEHoxESiFgRBEIROTCRqQRAOG0mSeOuttzq6GIJwVBOJWhB+oi677DIkSWoxnXzyyR1dNEEQDoAYj1oQfsJOPvlknnnmmYRldru9g0ojCMLBEFfUgvATZrfbyc3NTZjS0tIAo1r6scceY8aMGTidTrp3787rr7+esP3q1as58cQTcTqdZGRkcNVVV+H3+xNi/vWvfzFgwADsdjt5eXlce+21Ceurqqo488wzcblc9OrVi3feecdcV1tby+zZs8nKysLpdNKrV68WJxaCcKwTiVoQjmG33XYbZ599Nt999x2zZ8/mggsuYN26dQAEAgGmT59OWloa3377La+99hqffPJJQiJ+7LHHmDt3LldddRWrV6/mnXfeoWfPngmfcdddd3Heeefx/fffc8oppzB79mxqamrMz//hhx/48MMPWbduHY899hiZmZlH7gAIwtHg0Ab8EgShs5ozZ46uKIrudrsTpj//+c+6rhtDal599dUJ24wZM0b/5S9/qeu6rj/55JN6Wlqa7vf7zfXvv/++LsuyOe56fn6+/oc//KHNMgD6H//4R/O93+/XAf3DDz/UdV3XTzvtNP3yyy9vny8sCD9R4h61IPyEnXDCCTz22GMJy9LT083X48aNS1g3btw4Vq1aBcC6desYMmQIbrfbXD9hwgQ0TWPDhg1IksSePXuYMmXKPsswePBg87Xb7SY5OZmKigoAfvnLX3L22WezYsUKpk2bxqxZsxg/fvxBfVdB+KkSiVoQfsLcbneLquj24nQ69yvOarUmvJckCU3TAJgxYwYlJSV88MEHzJ8/nylTpjB37lz+9re/tXt5BeFoJe5RC8Ix7Kuvvmrxvl+/fgD069eP7777jkAgYK5fsmQJsizTp08fPB4PRUVFLFiw4JDKkJWVxZw5c3jhhRd44IEHePLJJw9pf4LwUyOuqAXhJywcDlNWVpawzGKxmA22XnvtNUaOHMlxxx3Hiy++yDfffMPTTz8NwOzZs7njjjuYM2cOd955J5WVlVx33XVccskl5OTkAHDnnXdy9dVXk52dzYwZM/D5fCxZsuT/t2uHOA4CYRiGP0yTjsbMCUiKJEju0AQ8noTUYDA9Ahyj4zAVcJNKjgGKiiZN1mwqNtvZ7vvIEeRHvUN+VNf1S/Odz2clSaI4jrWuq67X6/OiAOCBUAMfbBxHWWu/nEVRpNvtJunxR7ZzTlVVyVqry+Wiw+EgSTLGaJomnU4npWkqY4zyPFfXdc9nlWWpZVnU972aplEYhiqK4uX5drud2rbVPM/a7/fKskzOuR94c+BzBNu2be8eAsDvC4JAwzDoeDy+exQA32BHDQCAxwg1AAAeY0cN/FNsvYC/gS9qAAA8RqgBAPAYoQYAwGOEGgAAjxFqAAA8RqgBAPAYoQYAwGOEGgAAjxFqAAA8dge5tnEqGnuVcAAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 500x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAeoAAAEiCAYAAAA21pHjAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/NK7nSAAAACXBIWXMAAA9hAAAPYQGoP6dpAACHG0lEQVR4nOzdeXwU5f3A8c/M7L2bbO47JNz3fYmIKKB41lu0rajUs1IPfm3VemtbrNajtlZb69FaPOqt1aqI4omAIPcdjhByn5u9d2fm98dsNglJIEAgQZ73i3ntZvaZ2WcnYb773JKu6zqCIAiCIPRIcndnQBAEQRCEjolALQiCIAg9mAjUgiAIgtCDiUAtCIIgCD2YCNSCIAiC0IOJQC0IgiAIPZgI1IIgCILQg4lALQiCIAg9mAjUgiAIgtCDiUAtCIIgCD2YCNSCcJT561//iiRJTJw4sbuzIgjCESCJub4F4egyefJkSktL2blzJ1u3bqVfv37dnSVBEA4jUaIWhKPIjh07+Oabb3j00UdJT09nwYIF3Z2ldvl8vu7OgiD8YIhALQhHkQULFpCcnMyZZ57JhRde2G6grq+v55ZbbqGwsBCr1UpeXh6zZ8+muro6niYYDHLvvfcyYMAAbDYb2dnZnH/++RQVFQGwePFiJEli8eLFrc69c+dOJEnihRdeiO+74oorcLlcFBUVccYZZ5CQkMBPfvITAL788ksuuugievXqhdVqJT8/n1tuuYVAINAm35s2beLiiy8mPT0du93OwIEDueOOOwD47LPPkCSJt956q81xL730EpIksWTJkgO+noJwNDB1dwYEQei8BQsWcP7552OxWLj00kt56qmnWL58OePHjwfA6/UyZcoUNm7cyJw5cxgzZgzV1dW8++67lJSUkJaWhqqqnHXWWSxatIhLLrmEm266icbGRhYuXMi6devo27fvAecrGo0yc+ZMTjjhBP74xz/icDgAeO211/D7/Vx//fWkpqaybNky/vznP1NSUsJrr70WP37NmjVMmTIFs9nMNddcQ2FhIUVFRbz33nv87ne/46STTiI/P58FCxZw3nnntbkmffv2ZdKkSYdwZQWhB9MFQTgqfPfddzqgL1y4UNd1Xdc0Tc/Ly9NvuummeJq7775bB/Q333yzzfGapum6ruvPPfecDuiPPvpoh2k+++wzHdA/++yzVq/v2LFDB/Tnn38+vu/yyy/XAf22225rcz6/399m3/z583VJkvRdu3bF95144ol6QkJCq30t86Prun777bfrVqtVr6+vj++rrKzUTSaTfs8997R5H0H4oRBV34JwlFiwYAGZmZmcfPLJAEiSxKxZs3jllVdQVRWAN954g5EjR7YpdTalb0qTlpbGL37xiw7THIzrr7++zT673R5/7vP5qK6u5vjjj0fXdb7//nsAqqqq+OKLL5gzZw69evXqMD+zZ88mFArx+uuvx/e9+uqrRKNRfvrTnx50vgWhpxOBWhCOAqqq8sorr3DyySezY8cOtm3bxrZt25g4cSIVFRUsWrQIgKKiIoYNG7bPcxUVFTFw4EBMpq5r+TKZTOTl5bXZX1xczBVXXEFKSgoul4v09HSmTp0KQENDAwDbt28H2G++Bw0axPjx41u1yy9YsIDjjjtO9HwXftBEG7UgHAU+/fRTysrKeOWVV3jllVfavL5gwQJOPfXULnu/jkrWTSX3vVmtVmRZbpP2lFNOoba2lltvvZVBgwbhdDrZs2cPV1xxBZqmHXC+Zs+ezU033URJSQmhUIhvv/2Wv/zlLwd8HkE4mohALQhHgQULFpCRkcGTTz7Z5rU333yTt956i6effpq+ffuybt26fZ6rb9++LF26lEgkgtlsbjdNcnIyYPQgb2nXrl2dzvPatWvZsmUL//znP5k9e3Z8/8KFC1ul69OnD8B+8w1wySWXMG/ePF5++WUCgQBms5lZs2Z1Ok+CcDQSVd+C0MMFAgHefPNNzjrrLC688MI229y5c2lsbOTdd9/lggsuYPXq1e0OY9JjcxtdcMEFVFdXt1sSbUpTUFCAoih88cUXrV7/61//2ul8K4rS6pxNz//0pz+1Speens6JJ57Ic889R3Fxcbv5aZKWlsbpp5/Ov//9bxYsWMBpp51GWlpap/MkCEcjUaIWhB7u3XffpbGxkR/96Eftvn7cccfFJz956aWXeP3117nooouYM2cOY8eOpba2lnfffZenn36akSNHMnv2bP71r38xb948li1bxpQpU/D5fHzyySf8/Oc/55xzzsHtdnPRRRfx5z//GUmS6Nu3L//973+prKzsdL4HDRpE3759+eUvf8mePXtITEzkjTfeoK6urk3aJ554ghNOOIExY8ZwzTXX0Lt3b3bu3Mn777/PqlWrWqWdPXs2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",
      "text/plain": [
       "<Figure size 500x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from matplotlib.lines import Line2D\n",
    "legend_elements = [Line2D([0], [0], color='C0', linestyle='solid',  label='content'),\n",
    "                   Line2D([0], [0], color='C1', linestyle='dashed', label='style')]\n",
    "\n",
    "plt.figure()\n",
    "plt.plot(np.array(moving_avg(content_losses)), label=\"content\", linestyle='solid')\n",
    "for m in private_modules:\n",
    "    plt.plot(np.array(moving_avg(m[\"losses\"])), label=f\"style{m['id']}\", linestyle='dashed')\n",
    "plt.title(\"Cross Entropy Loss\")\n",
    "plt.ylabel(\"Loss\")\n",
    "plt.xlabel(\"Epochs\")\n",
    "plt.legend(handles=legend_elements)\n",
    "plt.tight_layout()\n",
    "# plt.savefig(f\"results/{classifier_name}{'_cond' if conditional else ''}_loss_all_styles.pdf\")\n",
    "\n",
    "plt.figure()\n",
    "plt.plot(np.array(moving_avg(content_accs)), label=\"content\", linestyle='solid')\n",
    "for m in private_modules:\n",
    "    plt.plot(np.array(moving_avg(m[\"accs\"])), label=f\"style{m['id']}\", linestyle='dashed')\n",
    "plt.title(\"Accuracy\")\n",
    "plt.ylabel(\"Accuracy\")\n",
    "plt.xlabel(\"Epochs\")\n",
    "plt.legend(handles=legend_elements)\n",
    "plt.tight_layout()\n",
    "# plt.savefig(f\"results/{classifier_name}{'_cond' if conditional else ''}_acc_all_styles.pdf\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Predict style"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "global_model, private_modules = load_fedgan_all_styles(global_model, model_paths[-1], device=device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "520\n"
     ]
    }
   ],
   "source": [
    "content_classifier = make_classifier(global_model.contentD.num_features, output_dim=len(private_modules)).to(device)\n",
    "content_classifier_optim = torch.optim.Adam(content_classifier.parameters(), lr=lr)\n",
    "content_classifier_optim_sched = torch.optim.lr_scheduler.ExponentialLR(content_classifier_optim, gamma=lr_gamma)\n",
    "\n",
    "for m in private_modules:\n",
    "    m[\"classifier\"] = make_classifier(global_model.styleD.num_features, output_dim=1).to(device)\n",
    "    m[\"classifier_optim\"] = torch.optim.Adam(m[\"classifier\"].parameters(), lr=lr)\n",
    "    m[\"classifier_optim_sched\"] = torch.optim.lr_scheduler.ExponentialLR(m[\"classifier_optim\"], gamma=lr_gamma)\n",
    "\n",
    "style_linear = make_classifier(len(private_modules), output_dim=len(private_modules)).to(device)\n",
    "style_linear_optim = torch.optim.Adam(style_linear.parameters(), lr=lr)\n",
    "\n",
    "loss_fn = nn.CrossEntropyLoss().to(device)\n",
    "\n",
    "print(sum(p.numel() for p in content_classifier.parameters()))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[1/50] content_loss = 1.317177\tcontent_acc = 0.521765\tstyle_loss = 0.808620\tstyle_acc = 0.709964\t\n",
      "[2/50] content_loss = 0.920167\tcontent_acc = 0.654153\tstyle_loss = 0.492766\tstyle_acc = 0.805511\t\n",
      "[3/50] content_loss = 0.800729\tcontent_acc = 0.703275\tstyle_loss = 0.453636\tstyle_acc = 0.821785\t\n",
      "[4/50] content_loss = 0.736356\tcontent_acc = 0.728934\tstyle_loss = 0.422108\tstyle_acc = 0.832768\t\n",
      "[5/50] content_loss = 0.702946\tcontent_acc = 0.735024\tstyle_loss = 0.409865\tstyle_acc = 0.837560\t\n",
      "[6/50] content_loss = 0.663823\tcontent_acc = 0.753095\tstyle_loss = 0.369488\tstyle_acc = 0.857228\t\n",
      "[7/50] content_loss = 0.626783\tcontent_acc = 0.765675\tstyle_loss = 0.346619\tstyle_acc = 0.862320\t\n",
      "[8/50] content_loss = 0.618130\tcontent_acc = 0.767372\tstyle_loss = 0.345472\tstyle_acc = 0.867712\t\n",
      "[9/50] content_loss = 0.602658\tcontent_acc = 0.776458\tstyle_loss = 0.328172\tstyle_acc = 0.873702\t\n",
      "[10/50] content_loss = 0.600350\tcontent_acc = 0.774261\tstyle_loss = 0.320407\tstyle_acc = 0.874101\t\n",
      "[11/50] content_loss = 0.578699\tcontent_acc = 0.778055\tstyle_loss = 0.316237\tstyle_acc = 0.879293\t\n",
      "[12/50] content_loss = 0.572030\tcontent_acc = 0.784545\tstyle_loss = 0.308517\tstyle_acc = 0.879992\t\n",
      "[13/50] content_loss = 0.561390\tcontent_acc = 0.789038\tstyle_loss = 0.292106\tstyle_acc = 0.888379\t\n",
      "[14/50] content_loss = 0.541688\tcontent_acc = 0.798323\tstyle_loss = 0.279224\tstyle_acc = 0.896665\t\n",
      "[15/50] content_loss = 0.532340\tcontent_acc = 0.802017\tstyle_loss = 0.271809\tstyle_acc = 0.898762\t\n",
      "[16/50] content_loss = 0.532627\tcontent_acc = 0.799720\tstyle_loss = 0.272157\tstyle_acc = 0.898263\t\n",
      "[17/50] content_loss = 0.527364\tcontent_acc = 0.802316\tstyle_loss = 0.257390\tstyle_acc = 0.900060\t\n",
      "[18/50] content_loss = 0.520376\tcontent_acc = 0.809305\tstyle_loss = 0.255305\tstyle_acc = 0.906150\t\n",
      "[19/50] content_loss = 0.510369\tcontent_acc = 0.810903\tstyle_loss = 0.252246\tstyle_acc = 0.909345\t\n",
      "[20/50] content_loss = 0.505526\tcontent_acc = 0.810204\tstyle_loss = 0.244924\tstyle_acc = 0.908247\t\n",
      "[21/50] content_loss = 0.512145\tcontent_acc = 0.808107\tstyle_loss = 0.251260\tstyle_acc = 0.907248\t\n",
      "[22/50] content_loss = 0.497496\tcontent_acc = 0.813399\tstyle_loss = 0.239759\tstyle_acc = 0.912939\t\n",
      "[23/50] content_loss = 0.497708\tcontent_acc = 0.813498\tstyle_loss = 0.235111\tstyle_acc = 0.912740\t\n",
      "[24/50] content_loss = 0.497757\tcontent_acc = 0.810304\tstyle_loss = 0.230584\tstyle_acc = 0.914637\t\n",
      "[25/50] content_loss = 0.483306\tcontent_acc = 0.821785\tstyle_loss = 0.219865\tstyle_acc = 0.917033\t\n",
      "[26/50] content_loss = 0.484672\tcontent_acc = 0.819189\tstyle_loss = 0.224449\tstyle_acc = 0.915136\t\n",
      "[27/50] content_loss = 0.479343\tcontent_acc = 0.823582\tstyle_loss = 0.216468\tstyle_acc = 0.918530\t\n",
      "[28/50] content_loss = 0.497643\tcontent_acc = 0.810903\tstyle_loss = 0.213766\tstyle_acc = 0.919429\t\n",
      "[29/50] content_loss = 0.476838\tcontent_acc = 0.821086\tstyle_loss = 0.204348\tstyle_acc = 0.924920\t\n",
      "[30/50] content_loss = 0.483239\tcontent_acc = 0.816294\tstyle_loss = 0.206286\tstyle_acc = 0.924221\t\n",
      "[31/50] content_loss = 0.479653\tcontent_acc = 0.818890\tstyle_loss = 0.220401\tstyle_acc = 0.917831\t\n",
      "[32/50] content_loss = 0.467255\tcontent_acc = 0.823682\tstyle_loss = 0.205396\tstyle_acc = 0.920727\t\n",
      "[33/50] content_loss = 0.479099\tcontent_acc = 0.819688\tstyle_loss = 0.197283\tstyle_acc = 0.926817\t\n",
      "[34/50] content_loss = 0.466077\tcontent_acc = 0.823083\tstyle_loss = 0.196896\tstyle_acc = 0.926318\t\n",
      "[35/50] content_loss = 0.471922\tcontent_acc = 0.824181\tstyle_loss = 0.200237\tstyle_acc = 0.925220\t\n",
      "[36/50] content_loss = 0.469009\tcontent_acc = 0.825879\tstyle_loss = 0.198497\tstyle_acc = 0.929113\t\n",
      "[37/50] content_loss = 0.477882\tcontent_acc = 0.819189\tstyle_loss = 0.199880\tstyle_acc = 0.924022\t\n",
      "[38/50] content_loss = 0.475206\tcontent_acc = 0.821585\tstyle_loss = 0.197058\tstyle_acc = 0.927017\t\n",
      "[39/50] content_loss = 0.462090\tcontent_acc = 0.829273\tstyle_loss = 0.190348\tstyle_acc = 0.928914\t\n",
      "[40/50] content_loss = 0.469192\tcontent_acc = 0.826178\tstyle_loss = 0.197994\tstyle_acc = 0.927616\t\n",
      "[41/50] content_loss = 0.461300\tcontent_acc = 0.830871\tstyle_loss = 0.183928\tstyle_acc = 0.930212\t\n",
      "[42/50] content_loss = 0.453439\tcontent_acc = 0.832169\tstyle_loss = 0.185336\tstyle_acc = 0.931310\t\n",
      "[43/50] content_loss = 0.458352\tcontent_acc = 0.830970\tstyle_loss = 0.183109\tstyle_acc = 0.932009\t\n",
      "[44/50] content_loss = 0.466311\tcontent_acc = 0.826278\tstyle_loss = 0.199862\tstyle_acc = 0.926717\t\n",
      "[45/50] content_loss = 0.456747\tcontent_acc = 0.834065\tstyle_loss = 0.180802\tstyle_acc = 0.932408\t\n",
      "[46/50] content_loss = 0.474119\tcontent_acc = 0.821885\tstyle_loss = 0.196568\tstyle_acc = 0.927516\t\n",
      "[47/50] content_loss = 0.452160\tcontent_acc = 0.833367\tstyle_loss = 0.186433\tstyle_acc = 0.932109\t\n",
      "[48/50] content_loss = 0.441627\tcontent_acc = 0.834764\tstyle_loss = 0.177685\tstyle_acc = 0.934006\t\n",
      "[49/50] content_loss = 0.466509\tcontent_acc = 0.822684\tstyle_loss = 0.189370\tstyle_acc = 0.928614\t\n",
      "[50/50] content_loss = 0.463394\tcontent_acc = 0.826378\tstyle_loss = 0.177020\tstyle_acc = 0.933007\t\n"
     ]
    }
   ],
   "source": [
    "content_losses = []\n",
    "content_accs = []\n",
    "style_losses = []\n",
    "style_accs = []\n",
    "\n",
    "for epoch in range(epochs):\n",
    "    mean_content_loss = 0.0\n",
    "    mean_content_acc = 0.0\n",
    "    mean_style_loss = 0.0\n",
    "    mean_style_acc = 0.0\n",
    "\n",
    "    for i, (x, y) in enumerate(test_loader):\n",
    "\n",
    "        y = torch.randint(0, len(private_modules), (batch_size,)).to(device)  # y is the client now\n",
    "        x_list = []\n",
    "        for i in y:\n",
    "            global_latent = torch.randn(1, global_model.num_latents).to(device)\n",
    "            style_latent = torch.randn(1, global_model.num_latents).to(device)\n",
    "            style = private_modules[i][\"style_map\"](style_latent)\n",
    "            label = torch.randint(0, num_classes, (1,)).to(device).int() if conditional else None\n",
    "            xi = global_model.G(global_latent, cond=style, label=label)\n",
    "            x_list.append(xi)\n",
    "        x = torch.cat(x_list, dim=0)\n",
    "\n",
    "        # y = torch.randint(0, len(private_modules), (1,)).repeat(batch_size).to(device)\n",
    "        # client = y[0].item()\n",
    "        # global_latent = torch.randn(batch_size, global_model.num_latents).to(device)\n",
    "        # style_latent = torch.randn(batch_size, global_model.num_latents).to(device)\n",
    "        # style = private_modules[client][\"style_map\"](style_latent)\n",
    "        # label = torch.randint(0, num_classes, (batch_size,)).to(device).int() if conditional else None\n",
    "        # x = global_model.G(global_latent, cond=style, label=label)\n",
    "\n",
    "        # Get features from discriminators\n",
    "        with torch.no_grad():\n",
    "            _, content_features = global_model.contentD(x, return_h=True)\n",
    "            all_style_features = [m[\"styleD\"](x, return_h=True)[1] for m in private_modules]\n",
    "        # Get predictions from classifiers\n",
    "        content_pred = content_classifier(content_features)\n",
    "        content_y = content_pred.max(dim=1).indices\n",
    "        # stack predictions, get maximum out of all stacks per entry, then get maximum entry (i.e. get max probability)\n",
    "        style_pred = torch.stack([m[\"classifier\"](f) for m, f in zip(private_modules, all_style_features)], dim=1).squeeze()\n",
    "        style_pred = style_linear(style_pred)\n",
    "        style_y = style_pred.max(dim=1).indices\n",
    "\n",
    "        # Calculate loss and optimize\n",
    "        content_loss = loss_fn(content_pred, y)\n",
    "        style_loss = loss_fn(style_pred, y)\n",
    "        content_classifier_optim.zero_grad()\n",
    "        style_linear_optim.zero_grad()\n",
    "        [m[\"classifier_optim\"].zero_grad() for m in private_modules]\n",
    "        content_loss.backward()\n",
    "        style_loss.backward()\n",
    "        content_classifier_optim.step()\n",
    "        style_linear_optim.step()\n",
    "        [m[\"classifier_optim\"].step() for m in private_modules]\n",
    "        # Calculate accuracies\n",
    "        content_acc = (content_y == y).sum() / y.size(0)\n",
    "        style_acc = (style_y == y).sum() / y.size(0)\n",
    "        # accumulate mean losses and accs\n",
    "        mean_content_loss += content_loss.item() / len(test_loader)\n",
    "        mean_content_acc += content_acc.item() / len(test_loader)\n",
    "        mean_style_loss += style_loss.item() / len(test_loader)\n",
    "        mean_style_acc += style_acc.item() / len(test_loader)\n",
    "    # Record epoch mean loss and acc\n",
    "    content_losses.append(mean_content_loss)\n",
    "    content_accs.append(mean_content_acc)\n",
    "    style_losses.append(mean_style_loss)\n",
    "    style_accs.append(mean_style_acc)\n",
    "    print(f\"[{epoch+1}/{epochs}] \"  #[{i+1}/{len(test_loader)}] \"\n",
    "          f\"content_loss = {mean_content_loss:4f}\\t\"\n",
    "          f\"content_acc = {mean_content_acc:4f}\\t\"\n",
    "          f\"style_loss = {mean_style_loss:4f}\\t\"\n",
    "          f\"style_acc = {mean_style_acc:4f}\\t\"\n",
    "         )\n",
    "    content_classifier_optim_sched.step()\n",
    "    [m[\"classifier_optim_sched\"].step() for m in private_modules]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 500x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 500x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from matplotlib.lines import Line2D\n",
    "\n",
    "plt.figure()\n",
    "plt.plot(np.array(moving_avg(content_losses)), label=\"content\", linestyle='solid')\n",
    "plt.plot(np.array(moving_avg(style_losses)), label=\"style\", linestyle='dashed')\n",
    "plt.title(\"Cross Entropy Loss\")\n",
    "plt.ylabel(\"Loss\")\n",
    "plt.xlabel(\"Epochs\")\n",
    "plt.legend()\n",
    "plt.tight_layout()\n",
    "plt.savefig(f\"results/{classifier_name}{'_cond' if conditional else ''}_loss_predict_style.pdf\")\n",
    "\n",
    "plt.figure()\n",
    "plt.plot(np.array(moving_avg(content_accs)), label=\"content\", linestyle='solid')\n",
    "plt.plot(np.array(moving_avg(style_accs)), label=\"style\", linestyle='dashed')\n",
    "plt.title(\"Accuracy\")\n",
    "plt.ylabel(\"Accuracy\")\n",
    "plt.xlabel(\"Epochs\")\n",
    "plt.legend()\n",
    "plt.tight_layout()\n",
    "plt.savefig(f\"results/{classifier_name}{'_cond' if conditional else ''}_acc_predict_style.pdf\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Check model's accuracy vs. comm rounds"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[25, 50, 75, 100, 125, 150, 175, 200, 225]\n"
     ]
    }
   ],
   "source": [
    "global_models = {get_round(pth): load_fedgan_one_style(init_model().to(device), pth, device=device)\n",
    "                 for pth in model_paths}\n",
    "print(list(global_models.keys()))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "trainers = [{ \"id\": cr, \"contentD\": global_models[cr].contentD } for cr in global_models]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "for m in trainers:\n",
    "    m[\"classifier\"] = make_classifier(m[\"contentD\"].num_features).to(device)\n",
    "    m[\"classifier_optim\"] = torch.optim.Adam(m[\"classifier\"].parameters(), lr=lr)\n",
    "    m[\"classifier_optim_sched\"] = torch.optim.lr_scheduler.ExponentialLR(m[\"classifier_optim\"], gamma=lr_gamma)\n",
    "\n",
    "loss_fn = nn.CrossEntropyLoss().to(device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[1/50] model[25]_loss = 1.474826\tmodel[25]_acc = 0.662839\tmodel[50]_loss = 1.119587\tmodel[50]_acc = 0.766873\tmodel[75]_loss = 1.060489\tmodel[75]_acc = 0.774760\tmodel[100]_loss = 0.963989\tmodel[100]_acc = 0.802616\tmodel[125]_loss = 0.925903\tmodel[125]_acc = 0.800120\tmodel[150]_loss = 0.870466\tmodel[150]_acc = 0.821785\tmodel[175]_loss = 0.840073\tmodel[175]_acc = 0.819688\tmodel[200]_loss = 0.878302\tmodel[200]_acc = 0.806210\tmodel[225]_loss = 0.875433\tmodel[225]_acc = 0.799421\n",
      "[2/50] model[25]_loss = 0.742173\tmodel[25]_acc = 0.846346\tmodel[50]_loss = 0.443610\tmodel[50]_acc = 0.914537\tmodel[75]_loss = 0.403855\tmodel[75]_acc = 0.917232\tmodel[100]_loss = 0.335138\tmodel[100]_acc = 0.933506\tmodel[125]_loss = 0.324677\tmodel[125]_acc = 0.936701\tmodel[150]_loss = 0.300409\tmodel[150]_acc = 0.942292\tmodel[175]_loss = 0.293565\tmodel[175]_acc = 0.938399\tmodel[200]_loss = 0.297842\tmodel[200]_acc = 0.937300\tmodel[225]_loss = 0.288296\tmodel[225]_acc = 0.936402\n",
      "[3/50] model[25]_loss = 0.543672\tmodel[25]_acc = 0.875899\tmodel[50]_loss = 0.316469\tmodel[50]_acc = 0.930212\tmodel[75]_loss = 0.290046\tmodel[75]_acc = 0.934105\tmodel[100]_loss = 0.239059\tmodel[100]_acc = 0.947384\tmodel[125]_loss = 0.232008\tmodel[125]_acc = 0.948882\tmodel[150]_loss = 0.216074\tmodel[150]_acc = 0.951478\tmodel[175]_loss = 0.213167\tmodel[175]_acc = 0.950080\tmodel[200]_loss = 0.215059\tmodel[200]_acc = 0.950280\tmodel[225]_loss = 0.211776\tmodel[225]_acc = 0.947185\n",
      "[4/50] model[25]_loss = 0.450302\tmodel[25]_acc = 0.891474\tmodel[50]_loss = 0.260057\tmodel[50]_acc = 0.937500\tmodel[75]_loss = 0.237597\tmodel[75]_acc = 0.942891\tmodel[100]_loss = 0.195956\tmodel[100]_acc = 0.954173\tmodel[125]_loss = 0.190269\tmodel[125]_acc = 0.953075\tmodel[150]_loss = 0.178414\tmodel[150]_acc = 0.956869\tmodel[175]_loss = 0.176920\tmodel[175]_acc = 0.956869\tmodel[200]_loss = 0.178232\tmodel[200]_acc = 0.957069\tmodel[225]_loss = 0.176619\tmodel[225]_acc = 0.953774\n",
      "[5/50] model[25]_loss = 0.394564\tmodel[25]_acc = 0.901058\tmodel[50]_loss = 0.227248\tmodel[50]_acc = 0.943291\tmodel[75]_loss = 0.206200\tmodel[75]_acc = 0.948183\tmodel[100]_loss = 0.170717\tmodel[100]_acc = 0.958167\tmodel[125]_loss = 0.165856\tmodel[125]_acc = 0.958966\tmodel[150]_loss = 0.156334\tmodel[150]_acc = 0.960962\tmodel[175]_loss = 0.155757\tmodel[175]_acc = 0.961162\tmodel[200]_loss = 0.156814\tmodel[200]_acc = 0.961661\tmodel[225]_loss = 0.155784\tmodel[225]_acc = 0.960563\n",
      "[6/50] model[25]_loss = 0.356927\tmodel[25]_acc = 0.909145\tmodel[50]_loss = 0.205338\tmodel[50]_acc = 0.946985\tmodel[75]_loss = 0.184970\tmodel[75]_acc = 0.951078\tmodel[100]_loss = 0.153840\tmodel[100]_acc = 0.961562\tmodel[125]_loss = 0.149514\tmodel[125]_acc = 0.962660\tmodel[150]_loss = 0.141414\tmodel[150]_acc = 0.963458\tmodel[175]_loss = 0.141533\tmodel[175]_acc = 0.963359\tmodel[200]_loss = 0.142462\tmodel[200]_acc = 0.963458\tmodel[225]_loss = 0.141951\tmodel[225]_acc = 0.963259\n",
      "[7/50] model[25]_loss = 0.329503\tmodel[25]_acc = 0.913339\tmodel[50]_loss = 0.189418\tmodel[50]_acc = 0.949381\tmodel[75]_loss = 0.169525\tmodel[75]_acc = 0.954772\tmodel[100]_loss = 0.141599\tmodel[100]_acc = 0.964157\tmodel[125]_loss = 0.137662\tmodel[125]_acc = 0.964257\tmodel[150]_loss = 0.130468\tmodel[150]_acc = 0.965355\tmodel[175]_loss = 0.130952\tmodel[175]_acc = 0.964956\tmodel[200]_loss = 0.131811\tmodel[200]_acc = 0.965755\tmodel[225]_loss = 0.131849\tmodel[225]_acc = 0.965156\n",
      "[8/50] model[25]_loss = 0.308469\tmodel[25]_acc = 0.917532\tmodel[50]_loss = 0.177189\tmodel[50]_acc = 0.951877\tmodel[75]_loss = 0.157711\tmodel[75]_acc = 0.957468\tmodel[100]_loss = 0.132223\tmodel[100]_acc = 0.965555\tmodel[125]_loss = 0.128597\tmodel[125]_acc = 0.965954\tmodel[150]_loss = 0.122048\tmodel[150]_acc = 0.967053\tmodel[175]_loss = 0.122662\tmodel[175]_acc = 0.966953\tmodel[200]_loss = 0.123460\tmodel[200]_acc = 0.968251\tmodel[225]_loss = 0.123936\tmodel[225]_acc = 0.966753\n",
      "[9/50] model[25]_loss = 0.291734\tmodel[25]_acc = 0.920927\tmodel[50]_loss = 0.167422\tmodel[50]_acc = 0.953874\tmodel[75]_loss = 0.148336\tmodel[75]_acc = 0.959764\tmodel[100]_loss = 0.124761\tmodel[100]_acc = 0.967452\tmodel[125]_loss = 0.121391\tmodel[125]_acc = 0.967652\tmodel[150]_loss = 0.115327\tmodel[150]_acc = 0.968550\tmodel[175]_loss = 0.115967\tmodel[175]_acc = 0.968750\tmodel[200]_loss = 0.116717\tmodel[200]_acc = 0.969149\tmodel[225]_loss = 0.117477\tmodel[225]_acc = 0.967652\n",
      "[10/50] model[25]_loss = 0.278050\tmodel[25]_acc = 0.924022\tmodel[50]_loss = 0.159401\tmodel[50]_acc = 0.955471\tmodel[75]_loss = 0.140687\tmodel[75]_acc = 0.961761\tmodel[100]_loss = 0.118654\tmodel[100]_acc = 0.968750\tmodel[125]_loss = 0.115499\tmodel[125]_acc = 0.969649\tmodel[150]_loss = 0.109805\tmodel[150]_acc = 0.969649\tmodel[175]_loss = 0.110428\tmodel[175]_acc = 0.969249\tmodel[200]_loss = 0.111134\tmodel[200]_acc = 0.969649\tmodel[225]_loss = 0.112072\tmodel[225]_acc = 0.969549\n",
      "[11/50] model[25]_loss = 0.266624\tmodel[25]_acc = 0.926418\tmodel[50]_loss = 0.152673\tmodel[50]_acc = 0.957368\tmodel[75]_loss = 0.134308\tmodel[75]_acc = 0.963259\tmodel[100]_loss = 0.113548\tmodel[100]_acc = 0.969848\tmodel[125]_loss = 0.110580\tmodel[125]_acc = 0.970847\tmodel[150]_loss = 0.105169\tmodel[150]_acc = 0.970248\tmodel[175]_loss = 0.105759\tmodel[175]_acc = 0.969748\tmodel[200]_loss = 0.106435\tmodel[200]_acc = 0.970747\tmodel[225]_loss = 0.107464\tmodel[225]_acc = 0.969649\n",
      "[12/50] model[25]_loss = 0.256923\tmodel[25]_acc = 0.929014\tmodel[50]_loss = 0.146928\tmodel[50]_acc = 0.959565\tmodel[75]_loss = 0.128895\tmodel[75]_acc = 0.964856\tmodel[100]_loss = 0.109204\tmodel[100]_acc = 0.970847\tmodel[125]_loss = 0.106401\tmodel[125]_acc = 0.971046\tmodel[150]_loss = 0.101207\tmodel[150]_acc = 0.971346\tmodel[175]_loss = 0.101776\tmodel[175]_acc = 0.970847\tmodel[200]_loss = 0.102420\tmodel[200]_acc = 0.971446\tmodel[225]_loss = 0.103488\tmodel[225]_acc = 0.970248\n",
      "[13/50] model[25]_loss = 0.248574\tmodel[25]_acc = 0.930911\tmodel[50]_loss = 0.141951\tmodel[50]_acc = 0.960563\tmodel[75]_loss = 0.124234\tmodel[75]_acc = 0.965855\tmodel[100]_loss = 0.105454\tmodel[100]_acc = 0.971446\tmodel[125]_loss = 0.102798\tmodel[125]_acc = 0.972444\tmodel[150]_loss = 0.097778\tmodel[150]_acc = 0.972145\tmodel[175]_loss = 0.098338\tmodel[175]_acc = 0.971446\tmodel[200]_loss = 0.098960\tmodel[200]_acc = 0.972344\tmodel[225]_loss = 0.100023\tmodel[225]_acc = 0.970946\n",
      "[14/50] model[25]_loss = 0.241307\tmodel[25]_acc = 0.932009\tmodel[50]_loss = 0.137589\tmodel[50]_acc = 0.961262\tmodel[75]_loss = 0.120171\tmodel[75]_acc = 0.966454\tmodel[100]_loss = 0.102175\tmodel[100]_acc = 0.972145\tmodel[125]_loss = 0.099647\tmodel[125]_acc = 0.972544\tmodel[150]_loss = 0.094774\tmodel[150]_acc = 0.972843\tmodel[175]_loss = 0.095346\tmodel[175]_acc = 0.972644\tmodel[200]_loss = 0.095945\tmodel[200]_acc = 0.972344\tmodel[225]_loss = 0.096982\tmodel[225]_acc = 0.971845\n",
      "[15/50] model[25]_loss = 0.234921\tmodel[25]_acc = 0.934804\tmodel[50]_loss = 0.133728\tmodel[50]_acc = 0.962660\tmodel[75]_loss = 0.116594\tmodel[75]_acc = 0.966953\tmodel[100]_loss = 0.099276\tmodel[100]_acc = 0.972244\tmodel[125]_loss = 0.096860\tmodel[125]_acc = 0.973343\tmodel[150]_loss = 0.092120\tmodel[150]_acc = 0.973243\tmodel[175]_loss = 0.092715\tmodel[175]_acc = 0.972843\tmodel[200]_loss = 0.093291\tmodel[200]_acc = 0.973043\tmodel[225]_loss = 0.094291\tmodel[225]_acc = 0.971845\n",
      "[16/50] model[25]_loss = 0.229265\tmodel[25]_acc = 0.936701\tmodel[50]_loss = 0.130282\tmodel[50]_acc = 0.962560\tmodel[75]_loss = 0.113415\tmodel[75]_acc = 0.967352\tmodel[100]_loss = 0.096691\tmodel[100]_acc = 0.972943\tmodel[125]_loss = 0.094369\tmodel[125]_acc = 0.973842\tmodel[150]_loss = 0.089755\tmodel[150]_acc = 0.973542\tmodel[175]_loss = 0.090380\tmodel[175]_acc = 0.973343\tmodel[200]_loss = 0.090929\tmodel[200]_acc = 0.973243\tmodel[225]_loss = 0.091887\tmodel[225]_acc = 0.972544\n",
      "[17/50] model[25]_loss = 0.224219\tmodel[25]_acc = 0.937600\tmodel[50]_loss = 0.127183\tmodel[50]_acc = 0.963458\tmodel[75]_loss = 0.110571\tmodel[75]_acc = 0.967252\tmodel[100]_loss = 0.094370\tmodel[100]_acc = 0.973343\tmodel[125]_loss = 0.092130\tmodel[125]_acc = 0.974341\tmodel[150]_loss = 0.087634\tmodel[150]_acc = 0.974241\tmodel[175]_loss = 0.088286\tmodel[175]_acc = 0.973542\tmodel[200]_loss = 0.088805\tmodel[200]_acc = 0.973442\tmodel[225]_loss = 0.089722\tmodel[225]_acc = 0.973143\n",
      "[18/50] model[25]_loss = 0.219690\tmodel[25]_acc = 0.938299\tmodel[50]_loss = 0.124380\tmodel[50]_acc = 0.964058\tmodel[75]_loss = 0.108011\tmodel[75]_acc = 0.967851\tmodel[100]_loss = 0.092275\tmodel[100]_acc = 0.974042\tmodel[125]_loss = 0.090106\tmodel[125]_acc = 0.975040\tmodel[150]_loss = 0.085723\tmodel[150]_acc = 0.974042\tmodel[175]_loss = 0.086395\tmodel[175]_acc = 0.973542\tmodel[200]_loss = 0.086881\tmodel[200]_acc = 0.973442\tmodel[225]_loss = 0.087759\tmodel[225]_acc = 0.973143\n",
      "[19/50] model[25]_loss = 0.215602\tmodel[25]_acc = 0.939796\tmodel[50]_loss = 0.121830\tmodel[50]_acc = 0.964756\tmodel[75]_loss = 0.105695\tmodel[75]_acc = 0.968450\tmodel[100]_loss = 0.090379\tmodel[100]_acc = 0.974840\tmodel[125]_loss = 0.088270\tmodel[125]_acc = 0.975439\tmodel[150]_loss = 0.083994\tmodel[150]_acc = 0.974541\tmodel[175]_loss = 0.084675\tmodel[175]_acc = 0.973742\tmodel[200]_loss = 0.085128\tmodel[200]_acc = 0.973642\tmodel[225]_loss = 0.085969\tmodel[225]_acc = 0.973542\n",
      "[20/50] model[25]_loss = 0.211895\tmodel[25]_acc = 0.940595\tmodel[50]_loss = 0.119502\tmodel[50]_acc = 0.965555\tmodel[75]_loss = 0.103592\tmodel[75]_acc = 0.968650\tmodel[100]_loss = 0.088655\tmodel[100]_acc = 0.975240\tmodel[125]_loss = 0.086600\tmodel[125]_acc = 0.975539\tmodel[150]_loss = 0.082423\tmodel[150]_acc = 0.974840\tmodel[175]_loss = 0.083105\tmodel[175]_acc = 0.974241\tmodel[200]_loss = 0.083530\tmodel[200]_acc = 0.974141\tmodel[225]_loss = 0.084333\tmodel[225]_acc = 0.973942\n",
      "[21/50] model[25]_loss = 0.208519\tmodel[25]_acc = 0.941593\tmodel[50]_loss = 0.117366\tmodel[50]_acc = 0.966154\tmodel[75]_loss = 0.101673\tmodel[75]_acc = 0.969050\tmodel[100]_loss = 0.087083\tmodel[100]_acc = 0.975539\tmodel[125]_loss = 0.085070\tmodel[125]_acc = 0.975739\tmodel[150]_loss = 0.080987\tmodel[150]_acc = 0.975040\tmodel[175]_loss = 0.081665\tmodel[175]_acc = 0.974141\tmodel[200]_loss = 0.082070\tmodel[200]_acc = 0.974541\tmodel[225]_loss = 0.082835\tmodel[225]_acc = 0.974241\n",
      "[22/50] model[25]_loss = 0.205433\tmodel[25]_acc = 0.942592\tmodel[50]_loss = 0.115404\tmodel[50]_acc = 0.966354\tmodel[75]_loss = 0.099916\tmodel[75]_acc = 0.969249\tmodel[100]_loss = 0.085642\tmodel[100]_acc = 0.975439\tmodel[125]_loss = 0.083661\tmodel[125]_acc = 0.975739\tmodel[150]_loss = 0.079666\tmodel[150]_acc = 0.975439\tmodel[175]_loss = 0.080338\tmodel[175]_acc = 0.974141\tmodel[200]_loss = 0.080735\tmodel[200]_acc = 0.975040\tmodel[225]_loss = 0.081461\tmodel[225]_acc = 0.974341\n",
      "[23/50] model[25]_loss = 0.202601\tmodel[25]_acc = 0.943690\tmodel[50]_loss = 0.113597\tmodel[50]_acc = 0.967153\tmodel[75]_loss = 0.098300\tmodel[75]_acc = 0.969948\tmodel[100]_loss = 0.084316\tmodel[100]_acc = 0.975140\tmodel[125]_loss = 0.082355\tmodel[125]_acc = 0.976538\tmodel[150]_loss = 0.078439\tmodel[150]_acc = 0.975439\tmodel[175]_loss = 0.079106\tmodel[175]_acc = 0.974840\tmodel[200]_loss = 0.079508\tmodel[200]_acc = 0.975140\tmodel[225]_loss = 0.080195\tmodel[225]_acc = 0.974341\n",
      "[24/50] model[25]_loss = 0.199998\tmodel[25]_acc = 0.944688\tmodel[50]_loss = 0.111930\tmodel[50]_acc = 0.967252\tmodel[75]_loss = 0.096807\tmodel[75]_acc = 0.970248\tmodel[100]_loss = 0.083091\tmodel[100]_acc = 0.975639\tmodel[125]_loss = 0.081140\tmodel[125]_acc = 0.976837\tmodel[150]_loss = 0.077292\tmodel[150]_acc = 0.975938\tmodel[175]_loss = 0.077956\tmodel[175]_acc = 0.974940\tmodel[200]_loss = 0.078376\tmodel[200]_acc = 0.975639\tmodel[225]_loss = 0.079024\tmodel[225]_acc = 0.974441\n",
      "[25/50] model[25]_loss = 0.197598\tmodel[25]_acc = 0.944788\tmodel[50]_loss = 0.110392\tmodel[50]_acc = 0.967752\tmodel[75]_loss = 0.095422\tmodel[75]_acc = 0.970847\tmodel[100]_loss = 0.081956\tmodel[100]_acc = 0.975739\tmodel[125]_loss = 0.080006\tmodel[125]_acc = 0.977137\tmodel[150]_loss = 0.076216\tmodel[150]_acc = 0.976837\tmodel[175]_loss = 0.076873\tmodel[175]_acc = 0.975839\tmodel[200]_loss = 0.077325\tmodel[200]_acc = 0.976038\tmodel[225]_loss = 0.077932\tmodel[225]_acc = 0.975040\n",
      "[26/50] model[25]_loss = 0.195382\tmodel[25]_acc = 0.945487\tmodel[50]_loss = 0.108971\tmodel[50]_acc = 0.968051\tmodel[75]_loss = 0.094136\tmodel[75]_acc = 0.971845\tmodel[100]_loss = 0.080904\tmodel[100]_acc = 0.976038\tmodel[125]_loss = 0.078945\tmodel[125]_acc = 0.977137\tmodel[150]_loss = 0.075206\tmodel[150]_acc = 0.977336\tmodel[175]_loss = 0.075853\tmodel[175]_acc = 0.976038\tmodel[200]_loss = 0.076340\tmodel[200]_acc = 0.976338\tmodel[225]_loss = 0.076907\tmodel[225]_acc = 0.975040\n",
      "[27/50] model[25]_loss = 0.193331\tmodel[25]_acc = 0.945487\tmodel[50]_loss = 0.107657\tmodel[50]_acc = 0.968251\tmodel[75]_loss = 0.092937\tmodel[75]_acc = 0.971845\tmodel[100]_loss = 0.079925\tmodel[100]_acc = 0.976438\tmodel[125]_loss = 0.077951\tmodel[125]_acc = 0.977536\tmodel[150]_loss = 0.074254\tmodel[150]_acc = 0.977536\tmodel[175]_loss = 0.074888\tmodel[175]_acc = 0.976538\tmodel[200]_loss = 0.075412\tmodel[200]_acc = 0.976837\tmodel[225]_loss = 0.075939\tmodel[225]_acc = 0.975439\n",
      "[28/50] model[25]_loss = 0.191432\tmodel[25]_acc = 0.946186\tmodel[50]_loss = 0.106441\tmodel[50]_acc = 0.968750\tmodel[75]_loss = 0.091821\tmodel[75]_acc = 0.972045\tmodel[100]_loss = 0.079014\tmodel[100]_acc = 0.976538\tmodel[125]_loss = 0.077021\tmodel[125]_acc = 0.977536\tmodel[150]_loss = 0.073360\tmodel[150]_acc = 0.978035\tmodel[175]_loss = 0.073976\tmodel[175]_acc = 0.977236\tmodel[200]_loss = 0.074532\tmodel[200]_acc = 0.977536\tmodel[225]_loss = 0.075021\tmodel[225]_acc = 0.975639\n",
      "[29/50] model[25]_loss = 0.189669\tmodel[25]_acc = 0.946486\tmodel[50]_loss = 0.105315\tmodel[50]_acc = 0.969050\tmodel[75]_loss = 0.090780\tmodel[75]_acc = 0.972544\tmodel[100]_loss = 0.078164\tmodel[100]_acc = 0.976937\tmodel[125]_loss = 0.076153\tmodel[125]_acc = 0.978435\tmodel[150]_loss = 0.072519\tmodel[150]_acc = 0.978035\tmodel[175]_loss = 0.073115\tmodel[175]_acc = 0.977436\tmodel[200]_loss = 0.073700\tmodel[200]_acc = 0.977636\tmodel[225]_loss = 0.074151\tmodel[225]_acc = 0.976637\n",
      "[30/50] model[25]_loss = 0.188032\tmodel[25]_acc = 0.946885\tmodel[50]_loss = 0.104270\tmodel[50]_acc = 0.969149\tmodel[75]_loss = 0.089808\tmodel[75]_acc = 0.972644\tmodel[100]_loss = 0.077372\tmodel[100]_acc = 0.977037\tmodel[125]_loss = 0.075339\tmodel[125]_acc = 0.978634\tmodel[150]_loss = 0.071730\tmodel[150]_acc = 0.978035\tmodel[175]_loss = 0.072305\tmodel[175]_acc = 0.977935\tmodel[200]_loss = 0.072912\tmodel[200]_acc = 0.977736\tmodel[225]_loss = 0.073328\tmodel[225]_acc = 0.976937\n",
      "[31/50] model[25]_loss = 0.186509\tmodel[25]_acc = 0.947484\tmodel[50]_loss = 0.103300\tmodel[50]_acc = 0.969748\tmodel[75]_loss = 0.088903\tmodel[75]_acc = 0.973043\tmodel[100]_loss = 0.076632\tmodel[100]_acc = 0.977137\tmodel[125]_loss = 0.074578\tmodel[125]_acc = 0.978934\tmodel[150]_loss = 0.070991\tmodel[150]_acc = 0.978435\tmodel[175]_loss = 0.071542\tmodel[175]_acc = 0.977935\tmodel[200]_loss = 0.072165\tmodel[200]_acc = 0.978035\tmodel[225]_loss = 0.072548\tmodel[225]_acc = 0.977336\n",
      "[32/50] model[25]_loss = 0.185089\tmodel[25]_acc = 0.947784\tmodel[50]_loss = 0.102398\tmodel[50]_acc = 0.970248\tmodel[75]_loss = 0.088058\tmodel[75]_acc = 0.973542\tmodel[100]_loss = 0.075940\tmodel[100]_acc = 0.977835\tmodel[125]_loss = 0.073866\tmodel[125]_acc = 0.979034\tmodel[150]_loss = 0.070298\tmodel[150]_acc = 0.978934\tmodel[175]_loss = 0.070825\tmodel[175]_acc = 0.978035\tmodel[200]_loss = 0.071458\tmodel[200]_acc = 0.978035\tmodel[225]_loss = 0.071812\tmodel[225]_acc = 0.977436\n",
      "[33/50] model[25]_loss = 0.183765\tmodel[25]_acc = 0.947883\tmodel[50]_loss = 0.101556\tmodel[50]_acc = 0.970447\tmodel[75]_loss = 0.087268\tmodel[75]_acc = 0.973642\tmodel[100]_loss = 0.075293\tmodel[100]_acc = 0.978035\tmodel[125]_loss = 0.073201\tmodel[125]_acc = 0.979533\tmodel[150]_loss = 0.069647\tmodel[150]_acc = 0.979133\tmodel[175]_loss = 0.070151\tmodel[175]_acc = 0.978335\tmodel[200]_loss = 0.070790\tmodel[200]_acc = 0.978534\tmodel[225]_loss = 0.071116\tmodel[225]_acc = 0.977436\n",
      "[34/50] model[25]_loss = 0.182528\tmodel[25]_acc = 0.948183\tmodel[50]_loss = 0.100771\tmodel[50]_acc = 0.970547\tmodel[75]_loss = 0.086532\tmodel[75]_acc = 0.973742\tmodel[100]_loss = 0.074686\tmodel[100]_acc = 0.978335\tmodel[125]_loss = 0.072577\tmodel[125]_acc = 0.979732\tmodel[150]_loss = 0.069037\tmodel[150]_acc = 0.979633\tmodel[175]_loss = 0.069519\tmodel[175]_acc = 0.978634\tmodel[200]_loss = 0.070159\tmodel[200]_acc = 0.978734\tmodel[225]_loss = 0.070461\tmodel[225]_acc = 0.977736\n",
      "[35/50] model[25]_loss = 0.181370\tmodel[25]_acc = 0.948882\tmodel[50]_loss = 0.100036\tmodel[50]_acc = 0.970647\tmodel[75]_loss = 0.085843\tmodel[75]_acc = 0.974042\tmodel[100]_loss = 0.074116\tmodel[100]_acc = 0.978734\tmodel[125]_loss = 0.071992\tmodel[125]_acc = 0.979732\tmodel[150]_loss = 0.068465\tmodel[150]_acc = 0.980431\tmodel[175]_loss = 0.068926\tmodel[175]_acc = 0.978734\tmodel[200]_loss = 0.069565\tmodel[200]_acc = 0.978734\tmodel[225]_loss = 0.069843\tmodel[225]_acc = 0.977935\n",
      "[36/50] model[25]_loss = 0.180286\tmodel[25]_acc = 0.948982\tmodel[50]_loss = 0.099348\tmodel[50]_acc = 0.970647\tmodel[75]_loss = 0.085199\tmodel[75]_acc = 0.974241\tmodel[100]_loss = 0.073582\tmodel[100]_acc = 0.978634\tmodel[125]_loss = 0.071444\tmodel[125]_acc = 0.979633\tmodel[150]_loss = 0.067926\tmodel[150]_acc = 0.980431\tmodel[175]_loss = 0.068368\tmodel[175]_acc = 0.979133\tmodel[200]_loss = 0.069004\tmodel[200]_acc = 0.979133\tmodel[225]_loss = 0.069260\tmodel[225]_acc = 0.977935\n",
      "[37/50] model[25]_loss = 0.179269\tmodel[25]_acc = 0.949181\tmodel[50]_loss = 0.098700\tmodel[50]_acc = 0.970946\tmodel[75]_loss = 0.084595\tmodel[75]_acc = 0.974341\tmodel[100]_loss = 0.073078\tmodel[100]_acc = 0.979034\tmodel[125]_loss = 0.070930\tmodel[125]_acc = 0.980032\tmodel[150]_loss = 0.067420\tmodel[150]_acc = 0.980431\tmodel[175]_loss = 0.067844\tmodel[175]_acc = 0.979333\tmodel[200]_loss = 0.068474\tmodel[200]_acc = 0.979333\tmodel[225]_loss = 0.068712\tmodel[225]_acc = 0.978035\n",
      "[38/50] model[25]_loss = 0.178315\tmodel[25]_acc = 0.949281\tmodel[50]_loss = 0.098092\tmodel[50]_acc = 0.971146\tmodel[75]_loss = 0.084029\tmodel[75]_acc = 0.974241\tmodel[100]_loss = 0.072604\tmodel[100]_acc = 0.979233\tmodel[125]_loss = 0.070446\tmodel[125]_acc = 0.979932\tmodel[150]_loss = 0.066944\tmodel[150]_acc = 0.980631\tmodel[175]_loss = 0.067351\tmodel[175]_acc = 0.979233\tmodel[200]_loss = 0.067974\tmodel[200]_acc = 0.979433\tmodel[225]_loss = 0.068195\tmodel[225]_acc = 0.978335\n",
      "[39/50] model[25]_loss = 0.177418\tmodel[25]_acc = 0.949681\tmodel[50]_loss = 0.097520\tmodel[50]_acc = 0.971546\tmodel[75]_loss = 0.083498\tmodel[75]_acc = 0.974241\tmodel[100]_loss = 0.072156\tmodel[100]_acc = 0.979333\tmodel[125]_loss = 0.069991\tmodel[125]_acc = 0.980132\tmodel[150]_loss = 0.066494\tmodel[150]_acc = 0.980631\tmodel[175]_loss = 0.066887\tmodel[175]_acc = 0.979433\tmodel[200]_loss = 0.067503\tmodel[200]_acc = 0.979633\tmodel[225]_loss = 0.067708\tmodel[225]_acc = 0.978834\n",
      "[40/50] model[25]_loss = 0.176574\tmodel[25]_acc = 0.949681\tmodel[50]_loss = 0.096980\tmodel[50]_acc = 0.971945\tmodel[75]_loss = 0.082998\tmodel[75]_acc = 0.974441\tmodel[100]_loss = 0.071734\tmodel[100]_acc = 0.979333\tmodel[125]_loss = 0.069561\tmodel[125]_acc = 0.980232\tmodel[150]_loss = 0.066069\tmodel[150]_acc = 0.981030\tmodel[175]_loss = 0.066451\tmodel[175]_acc = 0.979533\tmodel[200]_loss = 0.067058\tmodel[200]_acc = 0.979732\tmodel[225]_loss = 0.067250\tmodel[225]_acc = 0.979233\n",
      "[41/50] model[25]_loss = 0.175780\tmodel[25]_acc = 0.949880\tmodel[50]_loss = 0.096470\tmodel[50]_acc = 0.972045\tmodel[75]_loss = 0.082528\tmodel[75]_acc = 0.974641\tmodel[100]_loss = 0.071335\tmodel[100]_acc = 0.979233\tmodel[125]_loss = 0.069156\tmodel[125]_acc = 0.979932\tmodel[150]_loss = 0.065669\tmodel[150]_acc = 0.981230\tmodel[175]_loss = 0.066039\tmodel[175]_acc = 0.980132\tmodel[200]_loss = 0.066638\tmodel[200]_acc = 0.979633\tmodel[225]_loss = 0.066817\tmodel[225]_acc = 0.978934\n",
      "[42/50] model[25]_loss = 0.175033\tmodel[25]_acc = 0.949980\tmodel[50]_loss = 0.095989\tmodel[50]_acc = 0.972344\tmodel[75]_loss = 0.082085\tmodel[75]_acc = 0.974641\tmodel[100]_loss = 0.070959\tmodel[100]_acc = 0.979732\tmodel[125]_loss = 0.068774\tmodel[125]_acc = 0.980032\tmodel[150]_loss = 0.065290\tmodel[150]_acc = 0.981230\tmodel[175]_loss = 0.065650\tmodel[175]_acc = 0.980132\tmodel[200]_loss = 0.066240\tmodel[200]_acc = 0.979832\tmodel[225]_loss = 0.066409\tmodel[225]_acc = 0.978934\n",
      "[43/50] model[25]_loss = 0.174328\tmodel[25]_acc = 0.950080\tmodel[50]_loss = 0.095535\tmodel[50]_acc = 0.972244\tmodel[75]_loss = 0.081668\tmodel[75]_acc = 0.974740\tmodel[100]_loss = 0.070604\tmodel[100]_acc = 0.979732\tmodel[125]_loss = 0.068414\tmodel[125]_acc = 0.980032\tmodel[150]_loss = 0.064932\tmodel[150]_acc = 0.981030\tmodel[175]_loss = 0.065281\tmodel[175]_acc = 0.980331\tmodel[200]_loss = 0.065864\tmodel[200]_acc = 0.980132\tmodel[225]_loss = 0.066023\tmodel[225]_acc = 0.978934\n",
      "[44/50] model[25]_loss = 0.173664\tmodel[25]_acc = 0.949880\tmodel[50]_loss = 0.095105\tmodel[50]_acc = 0.972544\tmodel[75]_loss = 0.081274\tmodel[75]_acc = 0.974840\tmodel[100]_loss = 0.070268\tmodel[100]_acc = 0.979832\tmodel[125]_loss = 0.068074\tmodel[125]_acc = 0.980232\tmodel[150]_loss = 0.064591\tmodel[150]_acc = 0.981230\tmodel[175]_loss = 0.064934\tmodel[175]_acc = 0.980331\tmodel[200]_loss = 0.065508\tmodel[200]_acc = 0.980032\tmodel[225]_loss = 0.065657\tmodel[225]_acc = 0.979233\n",
      "[45/50] model[25]_loss = 0.173038\tmodel[25]_acc = 0.950379\tmodel[50]_loss = 0.094700\tmodel[50]_acc = 0.972444\tmodel[75]_loss = 0.080904\tmodel[75]_acc = 0.975040\tmodel[100]_loss = 0.069950\tmodel[100]_acc = 0.979832\tmodel[125]_loss = 0.067753\tmodel[125]_acc = 0.980331\tmodel[150]_loss = 0.064270\tmodel[150]_acc = 0.981230\tmodel[175]_loss = 0.064604\tmodel[175]_acc = 0.980531\tmodel[200]_loss = 0.065171\tmodel[200]_acc = 0.980431\tmodel[225]_loss = 0.065310\tmodel[225]_acc = 0.979233\n",
      "[46/50] model[25]_loss = 0.172448\tmodel[25]_acc = 0.950978\tmodel[50]_loss = 0.094317\tmodel[50]_acc = 0.972843\tmodel[75]_loss = 0.080553\tmodel[75]_acc = 0.975439\tmodel[100]_loss = 0.069651\tmodel[100]_acc = 0.980032\tmodel[125]_loss = 0.067451\tmodel[125]_acc = 0.980331\tmodel[150]_loss = 0.063966\tmodel[150]_acc = 0.981430\tmodel[175]_loss = 0.064293\tmodel[175]_acc = 0.980731\tmodel[200]_loss = 0.064852\tmodel[200]_acc = 0.980431\tmodel[225]_loss = 0.064981\tmodel[225]_acc = 0.979932\n",
      "[47/50] model[25]_loss = 0.171890\tmodel[25]_acc = 0.951078\tmodel[50]_loss = 0.093955\tmodel[50]_acc = 0.972943\tmodel[75]_loss = 0.080224\tmodel[75]_acc = 0.975539\tmodel[100]_loss = 0.069368\tmodel[100]_acc = 0.979932\tmodel[125]_loss = 0.067166\tmodel[125]_acc = 0.980531\tmodel[150]_loss = 0.063678\tmodel[150]_acc = 0.981330\tmodel[175]_loss = 0.063995\tmodel[175]_acc = 0.980631\tmodel[200]_loss = 0.064550\tmodel[200]_acc = 0.980132\tmodel[225]_loss = 0.064670\tmodel[225]_acc = 0.980032\n",
      "[48/50] model[25]_loss = 0.171364\tmodel[25]_acc = 0.951078\tmodel[50]_loss = 0.093613\tmodel[50]_acc = 0.972843\tmodel[75]_loss = 0.079913\tmodel[75]_acc = 0.975439\tmodel[100]_loss = 0.069102\tmodel[100]_acc = 0.980032\tmodel[125]_loss = 0.066896\tmodel[125]_acc = 0.980731\tmodel[150]_loss = 0.063406\tmodel[150]_acc = 0.981430\tmodel[175]_loss = 0.063716\tmodel[175]_acc = 0.980731\tmodel[200]_loss = 0.064264\tmodel[200]_acc = 0.980331\tmodel[225]_loss = 0.064374\tmodel[225]_acc = 0.979932\n",
      "[49/50] model[25]_loss = 0.170867\tmodel[25]_acc = 0.951378\tmodel[50]_loss = 0.093289\tmodel[50]_acc = 0.973043\tmodel[75]_loss = 0.079620\tmodel[75]_acc = 0.975639\tmodel[100]_loss = 0.068851\tmodel[100]_acc = 0.980331\tmodel[125]_loss = 0.066643\tmodel[125]_acc = 0.980731\tmodel[150]_loss = 0.063149\tmodel[150]_acc = 0.981330\tmodel[175]_loss = 0.063450\tmodel[175]_acc = 0.980831\tmodel[200]_loss = 0.063994\tmodel[200]_acc = 0.980232\tmodel[225]_loss = 0.064093\tmodel[225]_acc = 0.980331\n",
      "[50/50] model[25]_loss = 0.170397\tmodel[25]_acc = 0.951278\tmodel[50]_loss = 0.092984\tmodel[50]_acc = 0.973343\tmodel[75]_loss = 0.079344\tmodel[75]_acc = 0.975439\tmodel[100]_loss = 0.068613\tmodel[100]_acc = 0.980431\tmodel[125]_loss = 0.066403\tmodel[125]_acc = 0.980631\tmodel[150]_loss = 0.062906\tmodel[150]_acc = 0.981729\tmodel[175]_loss = 0.063199\tmodel[175]_acc = 0.980731\tmodel[200]_loss = 0.063738\tmodel[200]_acc = 0.980431\tmodel[225]_loss = 0.063826\tmodel[225]_acc = 0.980232\n"
     ]
    }
   ],
   "source": [
    "for m in trainers:\n",
    "    m[\"losses\"] = []\n",
    "    m[\"accs\"] = []\n",
    "\n",
    "for epoch in range(epochs):\n",
    "    for m in trainers:\n",
    "        m[\"mean_loss\"] = 0.0\n",
    "        m[\"mean_acc\"] = 0.0\n",
    "\n",
    "    for i, (x, y) in enumerate(test_loader):\n",
    "        x, y = x.to(device), y.to(device)\n",
    "        # Get features from discriminators\n",
    "        with torch.no_grad():\n",
    "            all_features = [m[\"contentD\"](x, return_h=True)[1] for m in trainers]\n",
    "        # Get predictions from classifiers\n",
    "        all_pred = [m[\"classifier\"](f) for m, f in zip(trainers, all_features)]\n",
    "        all_y = [pred.max(dim=1).indices for pred in all_pred]\n",
    "        # Calculate loss and optimize\n",
    "        all_loss = [loss_fn(pred, y) for pred in all_pred]\n",
    "        [m[\"classifier_optim\"].zero_grad() for m in trainers]\n",
    "        [loss.backward() for loss in all_loss]\n",
    "        [m[\"classifier_optim\"].step() for m in trainers]\n",
    "        # Calculate accuracies\n",
    "        all_acc = [(y_hat == y).sum() / y.size(0) for y_hat in all_y]\n",
    "        # accumulate mean losses and accs\n",
    "        for m, loss, acc in zip(trainers, all_loss, all_acc):\n",
    "            m[\"mean_loss\"] += loss.item() / len(test_loader)\n",
    "            m[\"mean_acc\"] += acc.item() / len(test_loader)\n",
    "    # Record epoch mean loss and acc\n",
    "    for m in trainers:\n",
    "        m[\"losses\"].append(m[\"mean_loss\"])\n",
    "        m[\"accs\"].append(m[\"mean_acc\"])\n",
    "    print(f\"[{epoch+1}/{epochs}] \"  #[{i+1}/{len(test_loader)}] \"\n",
    "          + \"\\t\".join(\n",
    "              f\"model[{m['id']}]_loss = {m['mean_loss']:4f}\\t\"\n",
    "              f\"model[{m['id']}]_acc = {m['mean_acc']:4f}\"\n",
    "              for m in trainers\n",
    "          )\n",
    "         )\n",
    "    [m[\"classifier_optim_sched\"].step() for m in trainers]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>epoch</th>\n",
       "      <th>loss</th>\n",
       "      <th>acc</th>\n",
       "      <th>comm_round</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0</td>\n",
       "      <td>1.474826</td>\n",
       "      <td>0.662839</td>\n",
       "      <td>25</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1</td>\n",
       "      <td>0.742173</td>\n",
       "      <td>0.846346</td>\n",
       "      <td>25</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>2</td>\n",
       "      <td>0.543672</td>\n",
       "      <td>0.875899</td>\n",
       "      <td>25</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>3</td>\n",
       "      <td>0.450302</td>\n",
       "      <td>0.891474</td>\n",
       "      <td>25</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>4</td>\n",
       "      <td>0.394564</td>\n",
       "      <td>0.901058</td>\n",
       "      <td>25</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>445</th>\n",
       "      <td>45</td>\n",
       "      <td>0.064981</td>\n",
       "      <td>0.979932</td>\n",
       "      <td>225</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>446</th>\n",
       "      <td>46</td>\n",
       "      <td>0.064670</td>\n",
       "      <td>0.980032</td>\n",
       "      <td>225</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>447</th>\n",
       "      <td>47</td>\n",
       "      <td>0.064374</td>\n",
       "      <td>0.979932</td>\n",
       "      <td>225</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>448</th>\n",
       "      <td>48</td>\n",
       "      <td>0.064093</td>\n",
       "      <td>0.980331</td>\n",
       "      <td>225</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>449</th>\n",
       "      <td>49</td>\n",
       "      <td>0.063826</td>\n",
       "      <td>0.980232</td>\n",
       "      <td>225</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>450 rows × 4 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "     epoch      loss       acc  comm_round\n",
       "0        0  1.474826  0.662839          25\n",
       "1        1  0.742173  0.846346          25\n",
       "2        2  0.543672  0.875899          25\n",
       "3        3  0.450302  0.891474          25\n",
       "4        4  0.394564  0.901058          25\n",
       "..     ...       ...       ...         ...\n",
       "445     45  0.064981  0.979932         225\n",
       "446     46  0.064670  0.980032         225\n",
       "447     47  0.064374  0.979932         225\n",
       "448     48  0.064093  0.980331         225\n",
       "449     49  0.063826  0.980232         225\n",
       "\n",
       "[450 rows x 4 columns]"
      ]
     },
     "execution_count": 38,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Aggregate data into one dataframe\n",
    "dfs = []\n",
    "for m in trainers:\n",
    "    df = pd.DataFrame()\n",
    "    df[\"loss\"] = m[\"losses\"]\n",
    "    df[\"acc\"] = m[\"accs\"]\n",
    "    df[\"comm_round\"] = m[\"id\"]\n",
    "    df = df.reset_index()\n",
    "    dfs.append(df)\n",
    "\n",
    "data_df = pd.concat(dfs, ignore_index=True)\n",
    "data_df = data_df.rename(columns={\"index\": \"epoch\"})\n",
    "data_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAfIAAAEiCAYAAAACr1D/AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/NK7nSAAAACXBIWXMAAA9hAAAPYQGoP6dpAABmv0lEQVR4nO3deXgURfrA8W/PPbkvcgEhAZRLLhFCRAUFRUSFlV3RxSXitavgKnis7iqKx6LsiniguF7ob0UUFF1lRREBVy7lUkBEQAQEckDua66u3x+TaTImQAJJhsD7eZ5+pru6uqemjbzV1dVVmlJKIYQQQogWyRTqAgghhBDi+EkgF0IIIVowCeRCCCFECyaBXAghhGjBJJALIYQQLZgEciGEEKIFk0AuhBBCtGASyIUQQogWTAK5EEII0YJJIBdCCCFaMAnkQjTAzp07+eMf/0j79u1xOBxERUUxYMAAnnnmGSorK0NdvHp5+OGH0TTtiEtOTk6DzzlnzhxmzJjR+IVtRunp6Vx++eWhLoYQDWYJdQGEaCkWLlzI7373O+x2O2PHjuWss87C7Xbz1Vdfcc8997Blyxb+9a9/hbqY9fbiiy8SERFRKz0mJqbB55ozZw6bN2/mzjvvPPGCCSEaRAK5EPWwa9currnmGtq1a8cXX3xBSkqKsW/8+PHs2LGDhQsXHvF4Xddxu904HI7mKG69/Pa3vyUhIaHZv7eqqgqbzYbJJA2CQjQG+T9JiHqYNm0aZWVlvPrqq0FBPKBjx47ccccdxramaUyYMIG33nqLbt26YbfbWbRoEQAbNmxg2LBhREVFERERweDBg1m9enXQ+TweD1OmTOGMM87A4XAQHx/Peeedx+LFi408OTk5jBs3jjZt2mC320lJSWHEiBH8/PPPjfKbly1bhqZpvPvuuzz++OO0adMGh8PB4MGD2bFjh5Fv0KBBLFy4kN27dxvN8+np6UHnmDt3Lg888ACtW7cmLCyMkpISAObNm0efPn1wOp0kJCRw3XXXsW/fvqByXH/99URERPDTTz8xdOhQwsPDSU1N5ZFHHiEweaNSivT0dEaMGFHrd1RVVREdHc0f//jHE74mXq+XRx99lA4dOmC320lPT+evf/0rLpcrKN/atWsZOnQoCQkJOJ1OMjIyuOGGG4LyzJ07lz59+hAZGUlUVBTdu3fnmWeeOeEyitOP3JELUQ8fffQR7du359xzz633MV988QXvvvsuEyZMICEhgfT0dLZs2cL5559PVFQU9957L1arlZdeeolBgwaxfPlyMjMzAf9z7KlTp3LTTTfRr18/SkpKWLt2LevXr+fiiy8GYNSoUWzZsoXbb7+d9PR08vLyWLx4MXv27DEC6dEUFBTUSrNYLLWa1p944glMJhN33303xcXFTJs2jTFjxrBmzRoA/va3v1FcXMwvv/zC008/DVCryf7RRx/FZrNx991343K5sNlszJ49m3HjxtG3b1+mTp1Kbm4uzzzzDCtWrGDDhg1B5fD5fFx66aX079+fadOmsWjRIh566CG8Xi+PPPIImqZx3XXXMW3aNAoKCoiLizOO/eijjygpKeG666475jU5lptuuok33niD3/72t9x1112sWbOGqVOnsnXrVhYsWABAXl4el1xyCa1ateK+++4jJiaGn3/+mffff984z+LFi7n22msZPHgwTz75JABbt25lxYoVQRVCIepFCSGOqri4WAFqxIgR9T4GUCaTSW3ZsiUofeTIkcpms6mdO3caafv371eRkZHqggsuMNJ69uyphg8ffsTzFxYWKkD94x//qP8PqfbQQw8poM6lU6dORr6lS5cqQHXp0kW5XC4j/ZlnnlGA2rRpk5E2fPhw1a5du1rfFThH+/btVUVFhZHudrtVYmKiOuuss1RlZaWR/vHHHytATZ482UjLzs5WgLr99tuNNF3X1fDhw5XNZlP5+flKKaW2bdumAPXiiy8GleHKK69U6enpStf1o16Xdu3aHfWab9y4UQHqpptuCkq/++67FaC++OILpZRSCxYsUID65ptvjniuO+64Q0VFRSmv13vUMglRH9K0LsQxBJqBIyMjG3TcwIED6dq1q7Ht8/n47LPPGDlyJO3btzfSU1JS+P3vf89XX31lfFdMTAxbtmxh+/btdZ7b6XRis9lYtmwZhYWFDf1JALz33nssXrw4aHn99ddr5Rs3bhw2m83YPv/88wH46aef6v1d2dnZOJ1OY3vt2rXk5eVx2223BfUbGD58OJ07d66zv8GECROM9cCjC7fbzeeffw7AmWeeSWZmJm+99ZaRr6CggE8++YQxY8agaVq9y1uX//73vwBMmjQpKP2uu+4CMMocaEn4+OOP8Xg8dZ4rJiaG8vLyoEclQhwvCeRCHENUVBQApaWlDTouIyMjaDs/P5+Kigo6depUK2+XLl3QdZ29e/cC8Mgjj1BUVMSZZ55J9+7dueeee/juu++M/Ha7nSeffJJPPvmEpKQkLrjgAqZNm9agV8cuuOAChgwZErRkZWXVypeWlha0HRsbC9CgCsSvr8Xu3bsB6rwWnTt3NvYHmEymoMoP+AM3ENQnYOzYsaxYscI4ft68eXg8Hv7whz/Uu6xHsnv3bkwmEx07dgxKT05OJiYmxvjOgQMHMmrUKKZMmUJCQgIjRozg9ddfD3qOftttt3HmmWcybNgw2rRpww033GD0oRCioSSQC3EMUVFRpKamsnnz5gYdV/MOtKEuuOACdu7cyWuvvcZZZ53FK6+8wtlnn80rr7xi5Lnzzjv58ccfmTp1Kg6HgwcffJAuXbqwYcOG4/7eupjN5jrTVXVHs/o4kWvRENdccw1Wq9W4K//3v//NOeecU2eF4Xgd685e0zTmz5/PqlWrmDBhAvv27eOGG26gT58+lJWVAZCYmMjGjRv5z3/+w5VXXsnSpUsZNmwY2dnZjVZOcfqQQC5EPVx++eXs3LmTVatWHfc5WrVqRVhYGNu2bau174cffsBkMtG2bVsjLS4ujnHjxvH222+zd+9eevTowcMPPxx0XIcOHbjrrrv47LPP2Lx5M263m6eeeuq4y3i8Gtps3a5dO4A6r8W2bduM/QG6rtdqyv/xxx8Bgjr2xcXFMXz4cN566y12797NihUrGuVuPFBmXddrPe7Izc2lqKioVpn79+/P448/ztq1a3nrrbfYsmULc+fONfbbbDauuOIKXnjhBWOgoTfffDPojQAh6kMCuRD1cO+99xIeHs5NN91Ebm5urf07d+485qtDZrOZSy65hA8//DCoOTg3N5c5c+Zw3nnnGc34hw4dCjo2IiKCjh07Gs2zFRUVVFVVBeXp0KEDkZGRtV6Fag7h4eEUFxfXO/8555xDYmIis2bNCirvJ598wtatWxk+fHitY55//nljXSnF888/j9VqZfDgwUH5/vCHP/D9999zzz33YDabueaaa47jF9V22WWXAdQawW769OkARpkLCwtrtVb06tULwPitv/7vazKZ6NGjR1AeIepLXj8Toh46dOjAnDlzGD16NF26dAka2W3lypXMmzeP66+//pjneeyxx1i8eDHnnXcet912GxaLhZdeegmXy8W0adOMfF27dmXQoEH06dOHuLg41q5dy/z5840OXz/++CODBw/m6quvpmvXrlgsFhYsWEBubm69A9f8+fPrHNnt4osvJikpqX4XplqfPn145513mDRpEn379iUiIoIrrrjiiPmtVitPPvkk48aNY+DAgVx77bXG62fp6elMnDgxKL/D4WDRokVkZ2eTmZnJJ598wsKFC/nrX/9Kq1atgvIOHz6c+Ph45s2bx7Bhw0hMTKz379ixYwePPfZYrfTevXszfPhwsrOz+de//kVRUREDBw7k66+/5o033mDkyJFceOGFALzxxhu88MIL/OY3v6FDhw6Ulpby8ssvExUVZVQGbrrpJgoKCrjoooto06YNu3fv5rnnnqNXr1506dKl3uUVApDXz4RoiB9//FHdfPPNKj09XdlsNhUZGakGDBignnvuOVVVVWXkA9T48ePrPMf69evV0KFDVUREhAoLC1MXXnihWrlyZVCexx57TPXr10/FxMQop9OpOnfurB5//HHldruVUkodPHhQjR8/XnXu3FmFh4er6OholZmZqd59991j/oajvX4GqKVLlyqlDr86Nm/evKDjd+3apQD1+uuvG2llZWXq97//vYqJiVGA8Srakc4R8M4776jevXsru92u4uLi1JgxY9Qvv/wSlCc7O1uFh4ernTt3qksuuUSFhYWppKQk9dBDDymfz1fneW+77TYFqDlz5hzzegS0a9fuiNfkxhtvVEop5fF41JQpU1RGRoayWq2qbdu26v777w/6b79+/Xp17bXXqrS0NGW321ViYqK6/PLL1dq1a4088+fPV5dccolKTExUNptNpaWlqT/+8Y/qwIED9S6vEAGaUg3osSKEEM3s+uuvZ/78+UZHsfqYOHEir776Kjk5OYSFhTVh6YQIPXlGLoQ4pVRVVfHvf/+bUaNGSRAXpwV5Ri6EOCXk5eXx+eefM3/+fA4dOiRDnYrThgRyIcQp4fvvv2fMmDEkJiby7LPPGj3FhTjVyTNyIYQQogWTZ+RCCCFECyaBXAghhGjB5Bl5HXRdZ//+/URGRp7wjElCCCHE8VBKUVpaSmpqKibTke+7JZDXYf/+/UFjXgshhBChsnfvXtq0aXPE/RLI6xCYd3rv3r3G2NdCCCFEcyopKaFt27ZGTDqSkAbyL7/8kn/84x+sW7eOAwcOsGDBAkaOHHnE/MuWLTPGM67pwIED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gLF89dVXTVH8Bjk8L7kEciGEONk8+eSTvPjiizz//PNs3bqVJ598kmnTpvHcc88ZeaZNm8azzz7LrFmzWLNmDeHh4QwdOpSqqqoQljzEk6YMGzaMYcOG1Tv/jBkzgrb//ve/8+GHH/LRRx/Ru3dvI91isZwUk73XFCMd3oQQ4qS1cuVKRowYwfDhwwFIT0/n7bff5uuvvwb8d+MzZszggQceYMSIEQC8+eabJCUl8cEHH3DNNdeErOwt+hm5ruuUlpYSFxcXlL59+3ZSU1Np3749Y8aMYc+ePUc9j8vloqSkJGhpbIGJU2S8dSHE6UQpRWWVJyRLzWbxYzn33HNZsmQJP/74IwDffvstX331lXGzuWvXLnJychgyZIhxTHR0NJmZmaxatapxL1oDtehpTP/5z39SVlbG1VdfbaRlZmYye/ZsOnXqxIEDB5gyZQrnn38+mzdvJjIyss7zTJ06lSlTpjRpWaNlBjQhxGmoyuXlohueDcl3f/Han3E6rPXKe99991FSUkLnzp0xm834fD4ef/xxxowZA0BOTg4ASUlJQcclJSUZ+0KlxQbyOXPmMGXKFD788EMSExON9JpN9T169CAzM5N27drx7rvvcuONN9Z5rvvvv59JkyYZ2yUlJbRt27ZRyyszoAkhxMnr3Xff5a233mLOnDl069aNjRs3cuedd5Kamkp2dnaoi3dULTKQz507l5tuuol58+YFNXPUJSYmhjPPPJMdO3YcMY/dbsdutzd2MYNIZzchxOnIYbfwxWt/Dtl319c999zDfffdZzzr7t69O7t372bq1KlkZ2cb/a5yc3NJSUkxjsvNzaVXr16NWu6GanGB/O233+aGG25g7ty5RqeEoykrK2Pnzp384Q9/aIbSHZnR2U0CuRDiNKJpWr2bt0OpoqICkym425jZbEbXdQAyMjJITk5myZIlRuAuKSlhzZo13Hrrrc1d3CAhDeRlZWVBd8q7du1i48aNxMXFkZaWxv3338++fft48803AX9zenZ2Ns888wyZmZnGcwmn00l0dDQAd999N1dccQXt2rVj//79PPTQQ5jNZq699trm/4E1yDCtQghx8rriiit4/PHHSUtLo1u3bmzYsIHp06dzww03AP4KyZ133sljjz3GGWecQUZGBg8++CCpqamMHDkytIVXIbR06VIF1Fqys7OVUkplZ2ergQMH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vuGll16iR48eQely7erWrVs3Dhw4YCxfffWVsa/Rr5kSTaZfv35q/PjxxrbP51Opqalq6tSpISzVyQlQCxYsMLZ1XVfJycnqH//4h5FWVFSk7Ha7evvtt0NQwpNXXl6eAtTy5cuVUv7rZLVa1bx584w8W7duVYBatWpVqIp50omNjVWvvPKKXK96KC0tVWeccYZavHixGjhwoLrjjjuUUvK3diQPPfSQ6tmzZ537muKayR15EzmeudbFYTKvfP0VFxcDEBcXB8C6devweDxB165z586kpaXJtQN8Ph9z586lvLycrKwsuV71MH78eIYPHx50jUD+1o5m+/btpKam0r59e8aMGcOePXuAprlmIR+i9VR1PHOti8OOZ17505Gu69x5550MGDDAGKY4JycHm81GTExMUN7T/dpt2rSJrKwsqqqqiIiIYMGCBXTt2pWNGzfK9TqKuXPnsn79er755pta++RvrW6ZmZnMnj2bTp06ceDAAaZMmcL555/P5s2bm+SaSSAXogUbP348mzdvDnr+JurWqVMnNm7cSHFxMfPnzyc7O5vly5eHulgntb1793LHHXewePFimauiAYYNG2as9+jRg8zMTNq1a8e7776L0+ls9O+TpvUmcjxzrYvDas4rX5Ncv8MmTJjAxx9/zNKlS4Nm60tOTsbtdlNUVBSU/3S/djabjY4dO9KnTx+mTp1Kz549eeaZZ+R6HcW6devIy8vj7LPPxmKxYLFYWL58Oc8++ywWi4WkpCS5dvUQExPDmWeeyY4dO5rk700CeROpOdd6QGCu9cDc6eLIas4rHxCYV/50v35KKSZMmMCCBQv44osvyMjICNrfp08frFZr0LXbtm0be/bsOe2vXU26ruNyueR6HcXgwYPZtGkTGzduNJZzzjmHMWPGGOty7Y6trKyMnTt3kpKS0jR/b8fVRU7Uy9y5c5XdblezZ89W33//vbrllltUTEyMysnJCXXRTgqlpaVqw4YNasOGDQpQ06dPVxs2bFC7d+9WSin1xBNPqJiYGPXhhx+q7777To0YMUJlZGSoysrKEJc8tG699VYVHR2tli1bpg4cOGAsFRUVRp4//elPKi0tTX3xxRdq7dq1KisrS2VlZYWw1KF13333qeXLl6tdu3ap7777Tt13331K0zT12WefKaXkejVEzV7rSsm1q8tdd92lli1bpnbt2qVWrFihhgwZohISElReXp5SqvGvmQTyJvbcc8+ptLQ0ZbPZVL9+/dTq1atDXaSTxtKlSxVQa8nOzlZK+V9Be/DBB1VSUpKy2+1q8ODBatu2baEt9EmgrmsGqNdff93IU1lZqW677TYVGxurwsLC1G9+8xt14MCB0BU6xG644QbVrl07ZbPZVKtWrdTgwYONIK6UXK+G+HUgl2tX2+jRo1VKSoqy2WyqdevWavTo0WrHjh3G/sa+ZjL7mRBCCNGCyTNyIYQQogWTQC6EEEK0YBLIhRBCiBZMArkQQgjRgkkgF0IIIVowCeRCCCFECyaBXAghhGjBJJALIYQQLZgEciHESWPZsmVomlZrQgkhxJFJIBdCCCFaMAnkQgghRAsmgVwIYdB1nalTp5KRkYHT6aRnz57Mnz8fONzsvXDhQnr06IHD4aB///5s3rw56Bzvvfce3bp1w263k56ezlNPPRW03+Vy8Ze//IW2bdtit9vp2LEjr776alCedevWcc455xAWFsa5557Ltm3bmvaHC9GCSSAXQhimTp3Km2++yaxZs9iyZQsTJ07kuuuuY/ny5Uaee+65h6eeeopvvvmGVq1accUVV+DxeAB/AL766qu55ppr2LRpEw8//DAPPvggs2fPNo4fO3Ysb7/9Ns8++yxbt27lpZdeIiIiIqgcf/vb33jqqadYu3YtFouFG264oVl+vxAt0olP2CaEOBVUVVWpsLAwtXLlyqD0G2+8UV177bXGtLNz58419h06dEg5nU71zjvvKKWU+v3vf68uvvjioOPvuece1bVrV6WUUtu2bVOAWrx4cZ1lCHzH559/bqQtXLhQAaf9PPRCHInckQshANixYwcVFRVcfPHFREREGMubb77Jzp07jXxZWVnGelxcHJ06dWLr1q0AbN26lQEDBgSdd8CAAWzfvh2fz8fGjRsxm80MHDjwqGXp0aOHsZ6SkgJAXl7eCf9GIU5FllAXQAhxcigrKwNg4cKFtG7dOmif3W4PCubHy+l01iuf1Wo11jVNA/zP74UQtckduRACgK5du2K329mzZw8dO3YMWtq2bWvkW716tbFeWFjIjz/+SJcuXQDo0qULK1asCDrvihUrOPPMMzGbzXTv3h1d14OeuQshTozckQshAIiMjOTuu+9m4sSJ6LrOeeedR3FxMStWrCAqKop27doB8MgjjxAfH09SUhJ/+9vfSEhIYOTIkQDcdddd9O3bl0cffZTRo0ezatUqnn/+eV544QUA0tPTyc7O5oYbbuDZZ5+lZ8+e7N69m7y8PK6++upQ/XQhWrZQP6QXQpw8dF1XM2bMUJ06dVJWq1W1atVKDR06VC1fvtzoiPbRRx+pbt26KZvNpvr166e+/fbboHPMnz9fde3aVVmtVpWWlqb+8Y9/BO2vrKxUEydOVCkpKcpms6mOHTuq1157TSl1uLNbYWGhkX/Dhg0KULt27Wrqny9Ei6QppVSI6xJCiBZg2bJlXHjhhRQWFhITExPq4gghqskzciGEEKIFk0AuhBBCtGDStC6EEEK0YHJHLoQQQrRgEsiFEEKIFkwCuRBCCNGCSSAXQgghWjAJ5EIIIUQLJoFcCCGEaMEkkAshhBAtmARyIYQQogWTQC6EEEK0YP8POlOcU3ecz/oAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 500x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAeEAAAEiCAYAAADONmoUAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/NK7nSAAAACXBIWXMAAA9hAAAPYQGoP6dpAABV6klEQVR4nO3deZwU1b338U9V7z09PfsKDLssCqggI4pbRIkaXEBFYwIuWa4Bo5DEJYommlyMNzFGRclNNMYbDD6ucQsJQYEQAREERBHZZJBhNmC2nl6rzvNH9TS0M8AwCz3A7/1KpaurqrtPF+N855w6dY6mlFIIIYQQ4qjTU10AIYQQ4kQlISyEEEKkiISwEEIIkSISwkIIIUSKSAgLIYQQKSIhLIQQQqSIhLAQQgiRIhLCQgghRIpICAshhBApIiEshBBCpIiEsBDd2FNPPYWmaZSWlqa6KEKILqDJ2NFCdF9nn3025eXlfPHFF2zevJkBAwakukhCiE4kNWEhuqnt27fz/vvv8+ijj5KXl8e8efNSXaRWBQKBVBdBiGOWhLAQ3dS8efPIysrisssu4+qrr241hGtra5kxYwZ9+vTB5XLRs2dPpkyZQk1NTeKYUCjEz372M0466STcbjdFRUVMnDiRrVu3ArB48WI0TWPx4sVJ7/3FF1+gaRrPPfdcYtuNN96Iz+dj69atXHrppaSnp3PDDTcA8O9//5trrrmGkpISXC4XvXr1YsaMGQSDwRbl/uyzz7j22mvJy8vD4/EwaNAg7r33XgDee+89NE3jtddea/G6F154AU3TWL58+RGfTyG6I3uqCyCEaN28efOYOHEiTqeT66+/nqeffppVq1ZxxhlnANDY2Mg555zDxo0bufnmmzn99NOpqanhjTfe4MsvvyQ3NxfDMPjGN77BokWLuO6667j99ttpaGhg4cKFbNiwgf79+x9xuWKxGOPHj2fs2LH8+te/xuv1AvDSSy/R1NTErbfeSk5ODh988AFPPPEEX375JS+99FLi9evXr+ecc87B4XDwve99jz59+rB161befPNNfvnLX3L++efTq1cv5s2bx1VXXdXinPTv358xY8Z04MwK0Y0oIUS38+GHHypALVy4UCmllGmaqmfPnur2229PHHP//fcrQL366qstXm+aplJKqWeffVYB6tFHHz3oMe+9954C1HvvvZe0f/v27QpQf/rTnxLbpk6dqgB19913t3i/pqamFttmz56tNE1TO3bsSGw799xzVXp6etK2A8ujlFL33HOPcrlcqra2NrGtqqpK2e129cADD7T4HCGOVdIcLUQ3NG/ePAoKCrjgggsA0DSNyZMnM3/+fAzDAOCVV15hxIgRLWqLzcc3H5Obm8ttt9120GPa49Zbb22xzePxJNYDgQA1NTWcddZZKKX46KOPAKiurmbp0qXcfPPNlJSUHLQ8U6ZMIRwO8/LLLye2vfjii8RiMb71rW+1u9xCdDcSwkJ0M4ZhMH/+fC644AK2b9/Oli1b2LJlC6WlpVRWVrJo0SIAtm7dyimnnHLI99q6dSuDBg3Cbu+8K092u52ePXu22F5WVsaNN95IdnY2Pp+PvLw8zjvvPADq6uoA2LZtG8Bhyz148GDOOOOMpOvg8+bN48wzz5Qe4uK4IteEhehm3n33XXbv3s38+fOZP39+i/3z5s3j4osv7rTPO1iNuLnG/VUulwtd11sce9FFF7F3717uuusuBg8eTFpaGrt27eLGG2/ENM0jLteUKVO4/fbb+fLLLwmHw6xYsYInn3zyiN9HiO5MQliIbmbevHnk5+czZ86cFvteffVVXnvtNebOnUv//v3ZsGHDId+rf//+rFy5kmg0isPhaPWYrKwswOppfaAdO3a0ucwff/wxn3/+OX/+85+ZMmVKYvvChQuTjuvXrx/AYcsNcN111zFz5kz++te/EgwGcTgcTJ48uc1lEuJYIM3RQnQjwWCQV199lW984xtcffXVLZbp06fT0NDAG2+8waRJk1i3bl2rt/Ko+Bg8kyZNoqamptUaZPMxvXv3xmazsXTp0qT9Tz31VJvLbbPZkt6zef13v/td0nF5eXmce+65PPvss5SVlbVanma5ublccskl/OUvf2HevHl8/etfJzc3t81lEuJYIDVhIbqRN954g4aGBi6//PJW95955pmJgTteeOEFXn75Za655hpuvvlmRo4cyd69e3njjTeYO3cuI0aMYMqUKTz//PPMnDmTDz74gHPOOYdAIMC//vUvfvCDH3DFFVeQkZHBNddcwxNPPIGmafTv35+33nqLqqqqNpd78ODB9O/fnx//+Mfs2rULv9/PK6+8wr59+1oc+/jjjzN27FhOP/10vve979G3b1+++OIL3n77bdauXZt07JQpU7j66qsB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",
      "text/plain": [
       "<Figure size 500x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure()\n",
    "sns.lineplot(x=\"epoch\", y=\"loss\", hue=\"comm_round\", palette=\"viridis\", data=data_df)\n",
    "plt.title(\"Cross Entropy Loss\")\n",
    "plt.legend()\n",
    "plt.tight_layout()\n",
    "# plt.savefig(f\"results/{classifier_name}{'_cond' if conditional else ''}_loss_all_rounds.pdf\")\n",
    "\n",
    "plt.figure()\n",
    "sns.lineplot(x=\"epoch\", y=\"acc\", hue=\"comm_round\", palette=\"viridis\", data=data_df)\n",
    "plt.title(\"Accuracy\")\n",
    "plt.legend()\n",
    "plt.tight_layout()\n",
    "# plt.savefig(f\"results/{classifier_name}{'_cond' if conditional else ''}_acc_all_rounds.pdf\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# FID"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import subprocess\n",
    "from tqdm.notebook import tqdm\n",
    "from torchvision.utils import save_image\n",
    "\n",
    "# PADPAF_MODEL = \"../outputs/id=padpaf/task=damnist-fedgan/lr=0.001_0.01/seed=123/model/model.pth.tar\"\n",
    "PADPAF_MODEL = \"../outputs/id=damnist-padpaf/task=damnist-fedgan/lr=0.001_0.01/seed=123/model/model.pth.tar\"\n",
    "DITTO_MODEL = \"../outputs/id=damnist-ditto/task=damnist-fedgan/lr=0.001_0.01/seed=123/model/model.pth.tar\"\n",
    "DITTO_FEDPROX_MODEL = \"../outputs/id=damnist-ditto-fedprox/task=damnist-fedgan/lr=0.001_0.01/seed=123/model/model.pth.tar\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "global_model = init_model().to(device)\n",
    "global_model, private_modules = load_fedgan_all_styles(global_model, PADPAF_MODEL, device=device)\n",
    "train_dataset, test_dataset = load_data(dataset=dataset_name, path=data_path)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generating 4615 samples.\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "2314a0895bb348e996c5ffa01d7b440f",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/145 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Saving data to: samples/real_samples_0\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "93260468c04c4995a5a90231c1981eae",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/abdulla.almansoori/miniconda3/envs/torch/lib/python3.9/site-packages/torchvision/utils.py:68: UserWarning: The parameter 'range' is deprecated since 0.12 and will be removed in 0.14. Please use 'value_range' instead.\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Saving data to: samples/fake_samples_0\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "241537426ee642a4bcb43f575cf2063b",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generating 4615 samples.\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "79c30912108a4d4bacfdff35cea3754f",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/145 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Saving data to: samples/real_samples_1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "76c4ec9f6c744deab36b159417d0325c",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Saving data to: samples/fake_samples_1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "319d27b8d7174617ae841618fb99484c",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generating 4615 samples.\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "647a8ed056e14d449ff0ccbf9d9682a4",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/145 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Saving data to: samples/real_samples_2\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "336b911be1604129ada9095893b0140c",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Saving data to: samples/fake_samples_2\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "fccb5b1a17e340f2b2953e881fbef04f",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generating 4615 samples.\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "6ffbc45a8c5f4227be4e14f12e78ab15",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/145 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Saving data to: samples/real_samples_3\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "bb354e7b02434182aa1f67888b9a9797",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Saving data to: samples/fake_samples_3\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "51d55d7d94f54dc9a9a54e09521411bd",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generating 4615 samples.\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "3f7183684a494d568c97504eb190d0f1",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/145 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Saving data to: samples/real_samples_4\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "14b8cb85e50f4c4ca3e8389b09688fd3",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Saving data to: samples/fake_samples_4\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "56d903012a1f40a694b256547a1964e9",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generating 4615 samples.\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "27970663d78644cf858b23bdf7ecee10",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/145 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Saving data to: samples/real_samples_5\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "bb908496937f4dffb1860c8746d631d9",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Saving data to: samples/fake_samples_5\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "00b8bd50b73947938c4b079733149265",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generating 4615 samples.\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "1bc0a8d96a3c4213b51270ffb74ee3a1",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/145 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Saving data to: samples/real_samples_6\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "905b90a6a741408883be8fed112b61f7",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Saving data to: samples/fake_samples_6\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "86f8d207843046628b4274bf19e2772d",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generating 4615 samples.\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "5ad45f21fadf4a9a88db048d335be7db",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/145 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Saving data to: samples/real_samples_7\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "41ab57b427014612b2d9a08419871253",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Saving data to: samples/fake_samples_7\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "9630ef035eb6491abb80ee55838c856f",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "@torch.no_grad()\n",
    "def generate_samples(global_model, m, num_samples=100):\n",
    "    print(f\"Generating {num_samples} samples.\")\n",
    "    data = []\n",
    "    for _ in tqdm(range(num_samples // batch_size + 1)):\n",
    "        content_latent = torch.randn(batch_size, global_model.num_latents).to(device)\n",
    "        style_latent = torch.randn(batch_size, global_model.num_latents).to(device)\n",
    "        fake = global_model.G(content_latent, cond=m[\"style_map\"](style_latent))\n",
    "        data.append(fake)\n",
    "    return torch.cat(data)\n",
    "\n",
    "\n",
    "def save_samples(data, outdir=\"samples\"):\n",
    "    os.makedirs(outdir, exist_ok=True)\n",
    "    print(\"Saving data to:\", outdir)\n",
    "    for i, data_i in tqdm(enumerate(data)):\n",
    "        if len(data_i) == 2:\n",
    "            data_i = data_i[0].float()  # get img only\n",
    "        save_image(data_i, f\"{outdir}/{i:04}.png\", normalize=True, range=(-1,1))\n",
    "\n",
    "\n",
    "for m in private_modules:\n",
    "    client_dataset = [x for x in train_dataset[m['id']]]  # invoking __getitem__ to apply transform\n",
    "    client_samples = generate_samples(global_model, m, num_samples=len(client_dataset))\n",
    "    save_samples(client_dataset, f\"samples/real_samples_{m['id']}\")\n",
    "    save_samples(client_samples, f\"samples/fake_samples_{m['id']}\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Calculating FID for client 0\n",
      "FID:  63.54575127184171\n",
      "\n",
      "Calculating FID for client 1\n",
      "FID:  129.56570598455016\n",
      "\n",
      "Calculating FID for client 2\n",
      "FID:  330.60042418846706\n",
      "\n",
      "Calculating FID for client 3\n",
      "FID:  32.78653236965769\n",
      "\n",
      "Calculating FID for client 4\n",
      "FID:  39.58751201377473\n",
      "\n",
      "Calculating FID for client 5\n",
      "FID:  39.60559600363163\n",
      "\n",
      "Calculating FID for client 6\n"
     ]
    }
   ],
   "source": [
    "outputs = []\n",
    "for m in private_modules:\n",
    "    command = [\n",
    "        f\"python\", \"-m\",  \"pytorch_fid\",\n",
    "        f\"samples/real_samples_{m['id']}\",\n",
    "        f\"samples/fake_samples_{m['id']}\",\n",
    "    ]\n",
    "    if device != 'cpu':\n",
    "        command += [f\"--device=cuda:0\"]\n",
    "    print(f\"Calculating FID for client {m['id']}\")\n",
    "    p = subprocess.run(command, capture_output=True, text=True)\n",
    "    print(p.stdout)\n",
    "    outputs.append(p.stdout)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[8.221180777948575, 7.776566263148567, 13.855138416759871, 4.508440845395398, 6.63318500994427, 6.754396695400629, 7.20395903311649, 5.806540390906093]\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "7.594925929077487"
      ]
     },
     "execution_count": 68,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "fids = [float(out.split(\"FID:\")[1]) for out in outputs]  # extract fid from text\n",
    "mean_fid = sum(fids) / len(fids)\n",
    "print(fids)\n",
    "mean_fid"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Rerun on Ditto"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Calculating FID for client 6\n",
      "FID:  158.12504466704473\n",
      "\n",
      "Calculating FID for client 7\n",
      "FID:  143.839087002138\n",
      "\n",
      "[146.98316293071574, 194.42318905257162, 365.4686544205141, 133.12924537638227, 135.52366834841945, 133.794924364015, 158.12504466704473, 143.839087002138]\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "176.41087202022513"
      ]
     },
     "execution_count": 77,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "global_model = init_model().to(device)\n",
    "global_model, private_modules = load_fedgan_all_styles(global_model, DITTO_MODEL, device=device)\n",
    "train_dataset, test_dataset = load_data(dataset=dataset_name, path=data_path)\n",
    "\n",
    "\n",
    "# Generate and save samples\n",
    "for m in private_modules:\n",
    "    client_dataset = [x for x in train_dataset[m['id']]]  # invoking __getitem__ to apply transform\n",
    "    client_samples = generate_samples(global_model, m, num_samples=len(client_dataset))\n",
    "    save_samples(client_dataset, f\"samples/ditto_real_samples_{m['id']}\")\n",
    "    save_samples(client_samples, f\"samples/ditto_fake_samples_{m['id']}\")\n",
    "\n",
    "\n",
    "outputs = []\n",
    "for m in private_modules:\n",
    "    command = [\n",
    "        f\"python\", \"-m\",  \"pytorch_fid\",\n",
    "        f\"samples/ditto_real_samples_{m['id']}\",\n",
    "        f\"samples/ditto_fake_samples_{m['id']}\",\n",
    "    ]\n",
    "    if device != 'cpu':\n",
    "        command += [f\"--device=cuda:0\"]\n",
    "    print(f\"Calculating FID for client {m['id']}\")\n",
    "    p = subprocess.run(command, capture_output=True, text=True)\n",
    "    print(p.stdout)\n",
    "    outputs.append(p.stdout)\n",
    "\n",
    "fids = [float(out.split(\"FID:\")[1]) for out in outputs]  # extract fid from text\n",
    "mean_fid = sum(fids) / len(fids)\n",
    "print(fids)\n",
    "mean_fid"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generating 4615 samples.\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "461e290a46e34d469e23df5937cb8a99",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/145 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Saving data to: samples/ditto_fedprox_real_samples_0\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "78f5306c49534e66917d72e9e75e3d72",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/abdulla.almansoori/miniconda3/envs/torch/lib/python3.9/site-packages/torchvision/utils.py:68: UserWarning: The parameter 'range' is deprecated since 0.12 and will be removed in 0.14. Please use 'value_range' instead.\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Saving data to: samples/ditto_fedprox_fake_samples_0\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "74c17e7b53bf4c7f8a5e6a741c070082",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generating 4615 samples.\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "411d8c958ecd4291ac373464145d603c",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/145 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Saving data to: samples/ditto_fedprox_real_samples_1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "d92b9c61a9d2459baa22f49d5d45420f",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Saving data to: samples/ditto_fedprox_fake_samples_1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "c5e151e3fb874f10b5091446e5056b8e",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generating 4615 samples.\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "dba1363776d04bfca1bb221ef3c23323",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/145 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Saving data to: samples/ditto_fedprox_real_samples_2\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "b3313099d19f4b7592ecd8250f27b67f",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Saving data to: samples/ditto_fedprox_fake_samples_2\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "a2d4f6fa19b44e75b42275a72a47b715",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generating 4615 samples.\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "3ddfca50b23145859defaee6f19c2012",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/145 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Saving data to: samples/ditto_fedprox_real_samples_3\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "23d50c8254e54ec1ad527b783f4acaf2",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Saving data to: samples/ditto_fedprox_fake_samples_3\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "a18eec8280d1452c9ebf8b8a78b5972e",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generating 4615 samples.\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "e68920b8188042bdbf1eaa09b3c21fd3",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/145 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Saving data to: samples/ditto_fedprox_real_samples_4\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "26455a38fc8e403688be3a68d5818aa6",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Saving data to: samples/ditto_fedprox_fake_samples_4\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "eb280f21c9f14309bc8aa5a95149ec0f",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generating 4615 samples.\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "9ca28035f7524f8eb3f079f81625875e",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/145 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Saving data to: samples/ditto_fedprox_real_samples_5\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "e53c5d337bbd4e20aa71120eca4cf17c",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Saving data to: samples/ditto_fedprox_fake_samples_5\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "703116996980419e8d352b7ece61635b",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generating 4615 samples.\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "4b8425a656cd4dea881a862ee2aae64f",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/145 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Saving data to: samples/ditto_fedprox_real_samples_6\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "e280bb22828d41a2a414004f46028de2",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Saving data to: samples/ditto_fedprox_fake_samples_6\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "218064da80f24f00a4a2d3d096b3dccb",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generating 4615 samples.\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "05b33bf7de52401e94a555eed1e4eb3d",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/145 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Saving data to: samples/ditto_fedprox_real_samples_7\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "9b927786f0da41d98114f5c15cf69859",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Saving data to: samples/ditto_fedprox_fake_samples_7\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "24da353c2f8b4cd2af5b7285a0096e5e",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Calculating FID for client 0\n",
      "FID:  180.03117396767163\n",
      "\n",
      "Calculating FID for client 1\n",
      "FID:  150.7972724999185\n",
      "\n",
      "Calculating FID for client 2\n",
      "FID:  258.64791416729037\n",
      "\n",
      "Calculating FID for client 3\n",
      "FID:  162.18393158342565\n",
      "\n",
      "Calculating FID for client 4\n",
      "FID:  160.78812016624016\n",
      "\n",
      "Calculating FID for client 5\n",
      "FID:  142.0748966877652\n",
      "\n",
      "Calculating FID for client 6\n",
      "FID:  145.14792411220247\n",
      "\n",
      "Calculating FID for client 7\n",
      "FID:  167.41410688803091\n",
      "\n",
      "[180.03117396767163, 150.7972724999185, 258.64791416729037, 162.18393158342565, 160.78812016624016, 142.0748966877652, 145.14792411220247, 167.41410688803091]\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "170.88566750906813"
      ]
     },
     "execution_count": 89,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "global_model = init_model().to(device)\n",
    "global_model, private_modules = load_fedgan_all_styles(global_model, DITTO_FEDPROX_MODEL, device=device)\n",
    "train_dataset, test_dataset = load_data(dataset=dataset_name, path=data_path)\n",
    "\n",
    "\n",
    "# Generate and save samples\n",
    "for m in private_modules:\n",
    "    client_dataset = [x for x in train_dataset[m['id']]]  # invoking __getitem__ to apply transform\n",
    "    client_samples = generate_samples(global_model, m, num_samples=len(client_dataset))\n",
    "    save_samples(client_dataset, f\"samples/ditto_fedprox_real_samples_{m['id']}\")\n",
    "    save_samples(client_samples, f\"samples/ditto_fedprox_fake_samples_{m['id']}\")\n",
    "\n",
    "\n",
    "outputs = []\n",
    "for m in private_modules:\n",
    "    command = [\n",
    "        f\"python\", \"-m\",  \"pytorch_fid\",\n",
    "        f\"samples/ditto_fedprox_real_samples_{m['id']}\",\n",
    "        f\"samples/ditto_fedprox_fake_samples_{m['id']}\",\n",
    "    ]\n",
    "    if device != 'cpu':\n",
    "        command += [f\"--device=cuda:0\"]\n",
    "    print(f\"Calculating FID for client {m['id']}\")\n",
    "    p = subprocess.run(command, capture_output=True, text=True)\n",
    "    print(p.stdout)\n",
    "    outputs.append(p.stdout)\n",
    "\n",
    "fids = [float(out.split(\"FID:\")[1]) for out in outputs]  # extract fid from text\n",
    "mean_fid = sum(fids) / len(fids)\n",
    "print(fids)\n",
    "mean_fid"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "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": 4
}
