{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 9,
   "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": 10,
   "metadata": {},
   "outputs": [],
   "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": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "RUN_CELEBA = \"../outputs/id=padpaf-celeba*/task=celeba-fedgan/*/seed=123/model/*\"\n",
    "RUN_CELEBA_2D5 = \"../outputs/id=padpaf-celeba*2D5/task=celeba-fedgan/*/seed=123/model/*\"\n",
    "RUN_CELEBA_2D5_CONT = \"../outputs/id=padpaf-celeba*2D5-cont/task=celeba-fedgan/*/seed=123/model/*\"\n",
    "\n",
    "RUN_CELEBA = \"/home/abdulla.almansoori/projects/PaDPaF/outputs/id=padpaf/task=celeba-fedgan/lr=0.001_0.01/seed=123/model/*\"\n",
    "\n",
    "MODEL_PATHS = RUN_CELEBA"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "conditional = 'conditional' in MODEL_PATHS\n",
    "unseen = 'unseen' in MODEL_PATHS"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "/home/abdulla.almansoori/projects/PaDPaF/outputs/id=padpaf/task=celeba-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": [
    "## Init setting and model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [],
   "source": [
    "classifier_is_linear = True  # else: 2-layer nn with relu\n",
    "\n",
    "Logger.setup_logging(\"INFO\", logfile=\"\")\n",
    "Logger()\n",
    "\n",
    "image_size = 64\n",
    "channels = 3\n",
    "seed = 123\n",
    "dataset_name = \"celeba\"\n",
    "data_path = \"../data/\"\n",
    "num_workers = 0\n",
    "batch_size = 32\n",
    "device = \"cuda:0\" if torch.cuda.is_available() else \"cpu\"\n",
    "num_attr = 40\n",
    "num_identities = 10177 + 1\n",
    "\n",
    "batch_size = 256\n",
    "lr = 1e-1\n",
    "epochs = 50\n",
    "lr_gamma = 0.95"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "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": 16,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "2e0abb642e6841f785df48c4fc33a091",
       "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/datasets/utils.py:272: UserWarning: We detected some HTML elements in the downloaded file. This most likely means that the download triggered an unhandled API response by GDrive. Please report this to torchvision at https://github.com/pytorch/vision/issues including the response:\n",
      "\n",
      "<!DOCTYPE html><html><head><title>Google Drive - Virus scan warning</title><meta http-equiv=\"content-type\" content=\"text/html; charset=utf-8\"/><style nonce=\"N8zzfdsS0-WGr6gEK4rbDw\">.goog-link-button{position:relative;color:#15c;text-decoration:underline;cursor:pointer}.goog-link-button-disabled{color:#ccc;text-decoration:none;cursor:default}body{color:#222;font:normal 13px/1.4 arial,sans-serif;margin:0}.grecaptcha-badge{visibility:hidden}.uc-main{padding-top:50px;text-align:center}#uc-dl-icon{display:inline-block;margin-top:16px;padding-right:1em;vertical-align:top}#uc-text{display:inline-block;max-width:68ex;text-align:left}.uc-error-caption,.uc-warning-caption{color:#222;font-size:16px}#uc-download-link{text-decoration:none}.uc-name-size a{color:#15c;text-decoration:none}.uc-name-size a:visited{color:#61c;text-decoration:none}.uc-name-size a:active{color:#d14836;text-decoration:none}.uc-footer{color:#777;font-size:11px;padding-bottom:5ex;padding-top:5ex;text-align:center}.uc-footer a{color:#15c}.uc-footer a:visited{color:#61c}.uc-footer a:active{color:#d14836}.uc-footer-divider{color:#ccc;width:100%}.goog-inline-block{position:relative;display:-moz-inline-box;display:inline-block}* html .goog-inline-block{display:inline}*:first-child+html .goog-inline-block{display:inline}sentinel{}</style><link rel=\"icon\" href=\"//ssl.gstatic.com/docs/doclist/images/drive_2022q3_32dp.png\"/></head><body><div class=\"uc-main\"><div id=\"uc-dl-icon\" class=\"image-container\"><div class=\"drive-sprite-aux-download-file\"></div></div><div id=\"uc-text\"><p class=\"uc-warning-caption\">Google Drive can't scan this file for viruses.</p><p class=\"uc-warning-subcaption\"><span class=\"uc-name-size\"><a href=\"/open?id=0B7EVK8r0v71pZjFTYXZWM3FlRnM\">img_align_celeba.zip</a> (1.3G)</span> is too large for Google to scan for viruses. Would you still like to download this file?</p><form id=\"download-form\" action=\"https://drive.usercontent.google.com/download\" method=\"get\"><input type=\"submit\" id=\"uc-download-link\" class=\"goog-inline-block jfk-button jfk-button-action\" value=\"Download anyway\"/><input type=\"hidden\" name=\"id\" value=\"0B7EVK8r0v71pZjFTYXZWM3FlRnM\"><input type=\"hidden\" name=\"export\" value=\"download\"><input type=\"hidden\" name=\"confirm\" value=\"t\"><input type=\"hidden\" name=\"uuid\" value=\"8545ee74-2787-4fed-a14e-438839d2ce00\"></form></div></div><div class=\"uc-footer\"><hr class=\"uc-footer-divider\"></div></body></html>\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "ename": "RuntimeError",
     "evalue": "The MD5 checksum of the download file ../data/celeba/img_align_celeba.zip does not match the one on record.Please delete the file and try again. If the issue persists, please report this to torchvision at https://github.com/pytorch/vision/issues.",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mRuntimeError\u001b[0m                              Traceback (most recent call last)",
      "Input \u001b[0;32mIn [16]\u001b[0m, in \u001b[0;36m<cell line: 1>\u001b[0;34m()\u001b[0m\n\u001b[0;32m----> 1\u001b[0m _, 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\u001b[43m \u001b[49m\u001b[43mimage_size\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mimage_size\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mtarget_type\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[38;5;124;43midentity\u001b[39;49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[43m)\u001b[49m\n",
      "File \u001b[0;32m~/projects/PaDPaF/notebooks/../fl_sim/data_funcs/data_loader.py:88\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     86\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;124mceleba\u001b[39m\u001b[38;5;124m'\u001b[39m:\n\u001b[1;32m     87\u001b[0m     \u001b[38;5;28;01mif\u001b[39;00m load_trainset:\n\u001b[0;32m---> 88\u001b[0m         fl_dataset \u001b[38;5;241m=\u001b[39m \u001b[43mFLCelebA\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[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     89\u001b[0m         trainsets \u001b[38;5;241m=\u001b[39m [FLCelebAClient(\n\u001b[1;32m     90\u001b[0m             fl_dataset, client_id\u001b[38;5;241m=\u001b[39mclient_id)\n\u001b[1;32m     91\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     92\u001b[0m     fl_dataset \u001b[38;5;241m=\u001b[39m FLCelebA(root\u001b[38;5;241m=\u001b[39mpath, 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/celeba.py:66\u001b[0m, in \u001b[0;36mFLCelebA.__init__\u001b[0;34m(self, root, transform, target_transform, target_type, download, image_size)\u001b[0m\n\u001b[1;32m     62\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21m__init__\u001b[39m(\u001b[38;5;28mself\u001b[39m, root, 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, target_type\u001b[38;5;241m=\u001b[39m\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mattr\u001b[39m\u001b[38;5;124m'\u001b[39m,\n\u001b[1;32m     63\u001b[0m              download\u001b[38;5;241m=\u001b[39m\u001b[38;5;28;01mFalse\u001b[39;00m, image_size\u001b[38;5;241m=\u001b[39m\u001b[38;5;241m32\u001b[39m):\n\u001b[1;32m     65\u001b[0m     Logger\u001b[38;5;241m.\u001b[39mget()\u001b[38;5;241m.\u001b[39mdebug(\u001b[38;5;124mf\u001b[39m\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mTarget type = \u001b[39m\u001b[38;5;132;01m{\u001b[39;00mtarget_type\u001b[38;5;132;01m}\u001b[39;00m\u001b[38;5;124m\"\u001b[39m)\n\u001b[0;32m---> 66\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[43mtransform\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mtransform\u001b[49m\u001b[43m,\u001b[49m\n\u001b[1;32m     67\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     68\u001b[0m \u001b[43m                     \u001b[49m\u001b[43mtarget_type\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mtarget_type\u001b[49m\u001b[43m,\u001b[49m\n\u001b[1;32m     69\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     71\u001b[0m     \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mtransform \u001b[38;5;241m=\u001b[39m transforms\u001b[38;5;241m.\u001b[39mCompose([\n\u001b[1;32m     72\u001b[0m         \u001b[38;5;66;03m# transforms.ToPILImage(),\u001b[39;00m\n\u001b[1;32m     73\u001b[0m         transforms\u001b[38;5;241m.\u001b[39mRandomHorizontalFlip(),\n\u001b[0;32m   (...)\u001b[0m\n\u001b[1;32m     77\u001b[0m         transforms\u001b[38;5;241m.\u001b[39mNormalize(mean\u001b[38;5;241m=\u001b[39m[\u001b[38;5;241m0.5\u001b[39m], std\u001b[38;5;241m=\u001b[39m[\u001b[38;5;241m0.5\u001b[39m]),\n\u001b[1;32m     78\u001b[0m     ])\n\u001b[1;32m     79\u001b[0m     \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mtarget_transform \u001b[38;5;241m=\u001b[39m target_transform\n",
      "File \u001b[0;32m~/miniconda3/envs/torch/lib/python3.9/site-packages/torchvision/datasets/celeba.py:80\u001b[0m, in \u001b[0;36mCelebA.__init__\u001b[0;34m(self, root, split, target_type, transform, target_transform, download)\u001b[0m\n\u001b[1;32m     77\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;124mtarget_transform is specified but target_type is empty\u001b[39m\u001b[38;5;124m\"\u001b[39m)\n\u001b[1;32m     79\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m download:\n\u001b[0;32m---> 80\u001b[0m     \u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mdownload\u001b[49m\u001b[43m(\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m     82\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_integrity():\n\u001b[1;32m     83\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 or corrupted. You can use download=True to download it\u001b[39m\u001b[38;5;124m\"\u001b[39m)\n",
      "File \u001b[0;32m~/miniconda3/envs/torch/lib/python3.9/site-packages/torchvision/datasets/celeba.py:150\u001b[0m, in \u001b[0;36mCelebA.download\u001b[0;34m(self)\u001b[0m\n\u001b[1;32m    147\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m\n\u001b[1;32m    149\u001b[0m \u001b[38;5;28;01mfor\u001b[39;00m (file_id, md5, filename) \u001b[38;5;129;01min\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mfile_list:\n\u001b[0;32m--> 150\u001b[0m     \u001b[43mdownload_file_from_google_drive\u001b[49m\u001b[43m(\u001b[49m\u001b[43mfile_id\u001b[49m\u001b[43m,\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[43mroot\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[43mbase_folder\u001b[49m\u001b[43m)\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mfilename\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mmd5\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    152\u001b[0m extract_archive(os\u001b[38;5;241m.\u001b[39mpath\u001b[38;5;241m.\u001b[39mjoin(\u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mroot, \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mbase_folder, \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mimg_align_celeba.zip\u001b[39m\u001b[38;5;124m\"\u001b[39m))\n",
      "File \u001b[0;32m~/miniconda3/envs/torch/lib/python3.9/site-packages/torchvision/datasets/utils.py:280\u001b[0m, in \u001b[0;36mdownload_file_from_google_drive\u001b[0;34m(file_id, root, filename, md5)\u001b[0m\n\u001b[1;32m    272\u001b[0m             warnings\u001b[38;5;241m.\u001b[39mwarn(\n\u001b[1;32m    273\u001b[0m                 \u001b[38;5;124mf\u001b[39m\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mWe detected some HTML elements in the downloaded file. \u001b[39m\u001b[38;5;124m\"\u001b[39m\n\u001b[1;32m    274\u001b[0m                 \u001b[38;5;124mf\u001b[39m\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mThis most likely means that the download triggered an unhandled API response by GDrive. \u001b[39m\u001b[38;5;124m\"\u001b[39m\n\u001b[1;32m    275\u001b[0m                 \u001b[38;5;124mf\u001b[39m\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mPlease report this to torchvision at https://github.com/pytorch/vision/issues including \u001b[39m\u001b[38;5;124m\"\u001b[39m\n\u001b[1;32m    276\u001b[0m                 \u001b[38;5;124mf\u001b[39m\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mthe response:\u001b[39m\u001b[38;5;130;01m\\n\u001b[39;00m\u001b[38;5;130;01m\\n\u001b[39;00m\u001b[38;5;132;01m{\u001b[39;00mtext\u001b[38;5;132;01m}\u001b[39;00m\u001b[38;5;124m\"\u001b[39m\n\u001b[1;32m    277\u001b[0m             )\n\u001b[1;32m    279\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m md5 \u001b[38;5;129;01mand\u001b[39;00m \u001b[38;5;129;01mnot\u001b[39;00m check_md5(fpath, md5):\n\u001b[0;32m--> 280\u001b[0m     \u001b[38;5;28;01mraise\u001b[39;00m \u001b[38;5;167;01mRuntimeError\u001b[39;00m(\n\u001b[1;32m    281\u001b[0m         \u001b[38;5;124mf\u001b[39m\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mThe MD5 checksum of the download file \u001b[39m\u001b[38;5;132;01m{\u001b[39;00mfpath\u001b[38;5;132;01m}\u001b[39;00m\u001b[38;5;124m does not match the one on record.\u001b[39m\u001b[38;5;124m\"\u001b[39m\n\u001b[1;32m    282\u001b[0m         \u001b[38;5;124mf\u001b[39m\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mPlease delete the file and try again. \u001b[39m\u001b[38;5;124m\"\u001b[39m\n\u001b[1;32m    283\u001b[0m         \u001b[38;5;124mf\u001b[39m\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mIf the issue persists, please report this to torchvision at https://github.com/pytorch/vision/issues.\u001b[39m\u001b[38;5;124m\"\u001b[39m\n\u001b[1;32m    284\u001b[0m     )\n",
      "\u001b[0;31mRuntimeError\u001b[0m: The MD5 checksum of the download file ../data/celeba/img_align_celeba.zip does not match the one on record.Please delete the file and try again. If the issue persists, please report this to torchvision at https://github.com/pytorch/vision/issues."
     ]
    }
   ],
   "source": [
    "_, test_dataset = load_data(dataset=dataset_name, path=data_path, image_size=image_size, target_type='identity')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Load test dataset"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "ename": "NameError",
     "evalue": "name 'test_dataset' is not defined",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mNameError\u001b[0m                                 Traceback (most recent call last)",
      "Input \u001b[0;32mIn [9]\u001b[0m, in \u001b[0;36m<cell line: 1>\u001b[0;34m()\u001b[0m\n\u001b[0;32m----> 1\u001b[0m test_loader \u001b[38;5;241m=\u001b[39m DataLoader(\u001b[43mtest_dataset\u001b[49m, batch_size, shuffle\u001b[38;5;241m=\u001b[39m\u001b[38;5;28;01mFalse\u001b[39;00m, \u001b[38;5;241m*\u001b[39m\u001b[38;5;241m*\u001b[39mloader_kwargs)\n\u001b[1;32m      2\u001b[0m \u001b[38;5;28;01mfor\u001b[39;00m x, y \u001b[38;5;129;01min\u001b[39;00m test_loader:\n\u001b[1;32m      3\u001b[0m     x, y \u001b[38;5;241m=\u001b[39m x\u001b[38;5;241m.\u001b[39mto(device), y\u001b[38;5;241m.\u001b[39mto(device)\n",
      "\u001b[0;31mNameError\u001b[0m: name 'test_dataset' is not defined"
     ]
    }
   ],
   "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([iden.item() for iden in y[i:i+8]])\n",
    "    break"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Load model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "def init_styleD(num_features=128):\n",
    "     return ResNetDiscriminator(num_features=num_features, image_size=image_size, channels=channels)\n",
    "\n",
    "\n",
    "def init_style_map(num_latents=256):\n",
    "     return StyleVectorizer(num_latents, 8, lr_mul=0.1)\n",
    "\n",
    "    \n",
    "def init_model(num_latents=256, num_features=128):\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_attr if conditional else 0, embed_class=False)\n",
    "\n",
    "global_model = init_model().to(device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [],
   "source": [
    "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": [
    "## Train a linear classifier on content features and a one style features"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'linear_classifier'"
      ]
     },
     "execution_count": 23,
     "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_identities, 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": 24,
   "metadata": {},
   "outputs": [],
   "source": [
    "global_model = load_fedgan_one_style(global_model, model_paths[-1], style_id=0, device=device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "5221314\n"
     ]
    }
   ],
   "source": [
    "content_classifier = make_classifier(global_model.contentD.hidden_dim).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.hidden_dim).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][1/636] content_loss = 9.256179\tcontent_acc = 0.000000\tcontent_acc_10 = 0.000000\tcontent_acc_50 = 0.003906\tstyle_loss = 9.226106\tstyle_acc = 0.000000\tstyle_acc_10 = 0.003906\tstyle_acc_50 = 0.007812\n",
      "[1/50][64/636] content_loss = 14.536020\tcontent_acc = 0.000305\tcontent_acc_10 = 0.002441\tcontent_acc_50 = 0.012268\tstyle_loss = 11.454146\tstyle_acc = 0.000549\tstyle_acc_10 = 0.003418\tstyle_acc_50 = 0.011658\n",
      "[1/50][127/636] content_loss = 13.803983\tcontent_acc = 0.000554\tcontent_acc_10 = 0.004583\tcontent_acc_50 = 0.016548\tstyle_loss = 10.978277\tstyle_acc = 0.000953\tstyle_acc_10 = 0.005690\tstyle_acc_50 = 0.018301\n",
      "[1/50][190/636] content_loss = 13.555887\tcontent_acc = 0.001069\tcontent_acc_10 = 0.006312\tcontent_acc_50 = 0.021793\tstyle_loss = 10.788096\tstyle_acc = 0.001254\tstyle_acc_10 = 0.007340\tstyle_acc_50 = 0.023623\n",
      "[1/50][253/636] content_loss = 13.390570\tcontent_acc = 0.001698\tcontent_acc_10 = 0.008832\tcontent_acc_50 = 0.027236\tstyle_loss = 10.660392\tstyle_acc = 0.001868\tstyle_acc_10 = 0.009434\tstyle_acc_50 = 0.028641\n",
      "[1/50][316/636] content_loss = 13.239721\tcontent_acc = 0.002176\tcontent_acc_10 = 0.011101\tcontent_acc_50 = 0.032400\tstyle_loss = 10.559394\tstyle_acc = 0.002275\tstyle_acc_10 = 0.011311\tstyle_acc_50 = 0.033450\n",
      "[1/50][379/636] content_loss = 13.089481\tcontent_acc = 0.002690\tcontent_acc_10 = 0.013213\tcontent_acc_50 = 0.037692\tstyle_loss = 10.459569\tstyle_acc = 0.002896\tstyle_acc_10 = 0.013471\tstyle_acc_50 = 0.038300\n",
      "[1/50][442/636] content_loss = 12.965446\tcontent_acc = 0.003190\tcontent_acc_10 = 0.015713\tcontent_acc_50 = 0.042686\tstyle_loss = 10.375420\tstyle_acc = 0.003517\tstyle_acc_10 = 0.015218\tstyle_acc_50 = 0.042209\n",
      "[1/50][505/636] content_loss = 12.839396\tcontent_acc = 0.003821\tcontent_acc_10 = 0.018178\tcontent_acc_50 = 0.047602\tstyle_loss = 10.295606\tstyle_acc = 0.004270\tstyle_acc_10 = 0.017590\tstyle_acc_50 = 0.047324\n",
      "[1/50][568/636] content_loss = 12.741788\tcontent_acc = 0.004470\tcontent_acc_10 = 0.020178\tcontent_acc_50 = 0.051992\tstyle_loss = 10.229493\tstyle_acc = 0.004828\tstyle_acc_10 = 0.019311\tstyle_acc_50 = 0.051270\n",
      "[1/50][631/636] content_loss = 12.649664\tcontent_acc = 0.005175\tcontent_acc_10 = 0.022856\tcontent_acc_50 = 0.056693\tstyle_loss = 10.166376\tstyle_acc = 0.005293\tstyle_acc_10 = 0.021153\tstyle_acc_50 = 0.055195\n",
      "[1/50] content_loss = 12.642517\tcontent_acc = 0.005227\tcontent_acc_10 = 0.023023\tcontent_acc_50 = 0.057031\tstyle_loss = 10.161194\tstyle_acc = 0.005352\tstyle_acc_10 = 0.021344\tstyle_acc_50 = 0.055459\n",
      "[2/50][1/636] content_loss = 11.062611\tcontent_acc = 0.011719\tcontent_acc_10 = 0.062500\tcontent_acc_50 = 0.136719\tstyle_loss = 8.190372\tstyle_acc = 0.019531\tstyle_acc_10 = 0.058594\tstyle_acc_50 = 0.191406\n",
      "[2/50][64/636] content_loss = 10.990624\tcontent_acc = 0.017761\tcontent_acc_10 = 0.063049\tcontent_acc_50 = 0.127075\tstyle_loss = 8.223409\tstyle_acc = 0.029053\tstyle_acc_10 = 0.087830\tstyle_acc_50 = 0.179443\n",
      "[2/50][127/636] content_loss = 10.818454\tcontent_acc = 0.020269\tcontent_acc_10 = 0.067729\tcontent_acc_50 = 0.135304\tstyle_loss = 8.259527\tstyle_acc = 0.027744\tstyle_acc_10 = 0.086491\tstyle_acc_50 = 0.177381\n",
      "[2/50][190/636] content_loss = 10.744426\tcontent_acc = 0.021834\tcontent_acc_10 = 0.070292\tcontent_acc_50 = 0.139391\tstyle_loss = 8.293906\tstyle_acc = 0.028146\tstyle_acc_10 = 0.086349\tstyle_acc_50 = 0.178104\n",
      "[2/50][253/636] content_loss = 10.703371\tcontent_acc = 0.022913\tcontent_acc_10 = 0.072490\tcontent_acc_50 = 0.142493\tstyle_loss = 8.316638\tstyle_acc = 0.027900\tstyle_acc_10 = 0.086524\tstyle_acc_50 = 0.178035\n",
      "[2/50][316/636] content_loss = 10.659823\tcontent_acc = 0.023957\tcontent_acc_10 = 0.074874\tcontent_acc_50 = 0.145681\tstyle_loss = 8.329465\tstyle_acc = 0.028493\tstyle_acc_10 = 0.086964\tstyle_acc_50 = 0.178661\n",
      "[2/50][379/636] content_loss = 10.608355\tcontent_acc = 0.024850\tcontent_acc_10 = 0.076929\tcontent_acc_50 = 0.149324\tstyle_loss = 8.328132\tstyle_acc = 0.028910\tstyle_acc_10 = 0.088648\tstyle_acc_50 = 0.180461\n",
      "[2/50][442/636] content_loss = 10.561682\tcontent_acc = 0.025992\tcontent_acc_10 = 0.078691\tcontent_acc_50 = 0.152194\tstyle_loss = 8.323064\tstyle_acc = 0.029049\tstyle_acc_10 = 0.089534\tstyle_acc_50 = 0.181976\n",
      "[2/50][505/636] content_loss = 10.518136\tcontent_acc = 0.027003\tcontent_acc_10 = 0.080446\tcontent_acc_50 = 0.155283\tstyle_loss = 8.311571\tstyle_acc = 0.029695\tstyle_acc_10 = 0.091027\tstyle_acc_50 = 0.184313\n",
      "[2/50][568/636] content_loss = 10.483597\tcontent_acc = 0.027811\tcontent_acc_10 = 0.082224\tcontent_acc_50 = 0.157846\tstyle_loss = 8.306654\tstyle_acc = 0.030019\tstyle_acc_10 = 0.092134\tstyle_acc_50 = 0.185815\n",
      "[2/50][631/636] content_loss = 10.450359\tcontent_acc = 0.028922\tcontent_acc_10 = 0.084576\tcontent_acc_50 = 0.161097\tstyle_loss = 8.296545\tstyle_acc = 0.030656\tstyle_acc_10 = 0.093577\tstyle_acc_50 = 0.187865\n",
      "[2/50] content_loss = 10.446624\tcontent_acc = 0.028998\tcontent_acc_10 = 0.084774\tcontent_acc_50 = 0.161354\tstyle_loss = 8.295085\tstyle_acc = 0.030702\tstyle_acc_10 = 0.093651\tstyle_acc_50 = 0.188098\n",
      "[3/50][1/636] content_loss = 9.564588\tcontent_acc = 0.046875\tcontent_acc_10 = 0.132812\tcontent_acc_50 = 0.214844\tstyle_loss = 7.353480\tstyle_acc = 0.066406\tstyle_acc_10 = 0.132812\tstyle_acc_50 = 0.277344\n",
      "[3/50][64/636] content_loss = 9.635215\tcontent_acc = 0.046509\tcontent_acc_10 = 0.123718\tcontent_acc_50 = 0.217957\tstyle_loss = 7.351339\tstyle_acc = 0.058044\tstyle_acc_10 = 0.156799\tstyle_acc_50 = 0.285828\n",
      "[3/50][127/636] content_loss = 9.496266\tcontent_acc = 0.048690\tcontent_acc_10 = 0.128722\tcontent_acc_50 = 0.224286\tstyle_loss = 7.350308\tstyle_acc = 0.057886\tstyle_acc_10 = 0.157911\tstyle_acc_50 = 0.284910\n",
      "[3/50][190/636] content_loss = 9.451152\tcontent_acc = 0.049712\tcontent_acc_10 = 0.129975\tcontent_acc_50 = 0.227056\tstyle_loss = 7.366925\tstyle_acc = 0.058450\tstyle_acc_10 = 0.159087\tstyle_acc_50 = 0.286040\n",
      "[3/50][253/636] content_loss = 9.439349\tcontent_acc = 0.050457\tcontent_acc_10 = 0.130867\tcontent_acc_50 = 0.228323\tstyle_loss = 7.376149\tstyle_acc = 0.057930\tstyle_acc_10 = 0.159153\tstyle_acc_50 = 0.286283\n",
      "[3/50][316/636] content_loss = 9.418589\tcontent_acc = 0.051622\tcontent_acc_10 = 0.132380\tcontent_acc_50 = 0.230197\tstyle_loss = 7.385843\tstyle_acc = 0.057444\tstyle_acc_10 = 0.159340\tstyle_acc_50 = 0.286875\n",
      "[3/50][379/636] content_loss = 9.385808\tcontent_acc = 0.052265\tcontent_acc_10 = 0.134554\tcontent_acc_50 = 0.233468\tstyle_loss = 7.381106\tstyle_acc = 0.058181\tstyle_acc_10 = 0.160218\tstyle_acc_50 = 0.288990\n",
      "[3/50][442/636] content_loss = 9.359347\tcontent_acc = 0.053388\tcontent_acc_10 = 0.135870\tcontent_acc_50 = 0.234949\tstyle_loss = 7.380381\tstyle_acc = 0.058258\tstyle_acc_10 = 0.160015\tstyle_acc_50 = 0.289566\n",
      "[3/50][505/636] content_loss = 9.331204\tcontent_acc = 0.054254\tcontent_acc_10 = 0.138041\tcontent_acc_50 = 0.237601\tstyle_loss = 7.369305\tstyle_acc = 0.059073\tstyle_acc_10 = 0.161549\tstyle_acc_50 = 0.292071\n",
      "[3/50][568/636] content_loss = 9.308238\tcontent_acc = 0.055135\tcontent_acc_10 = 0.139332\tcontent_acc_50 = 0.239622\tstyle_loss = 7.365812\tstyle_acc = 0.059357\tstyle_acc_10 = 0.161986\tstyle_acc_50 = 0.293368\n",
      "[3/50][631/636] content_loss = 9.287394\tcontent_acc = 0.056272\tcontent_acc_10 = 0.141195\tcontent_acc_50 = 0.241884\tstyle_loss = 7.359646\tstyle_acc = 0.059937\tstyle_acc_10 = 0.162880\tstyle_acc_50 = 0.294653\n",
      "[3/50] content_loss = 9.284538\tcontent_acc = 0.056294\tcontent_acc_10 = 0.141346\tcontent_acc_50 = 0.242250\tstyle_loss = 7.358279\tstyle_acc = 0.059997\tstyle_acc_10 = 0.162970\tstyle_acc_50 = 0.295031\n",
      "[4/50][1/636] content_loss = 8.719844\tcontent_acc = 0.093750\tcontent_acc_10 = 0.167969\tcontent_acc_50 = 0.300781\tstyle_loss = 6.626195\tstyle_acc = 0.101562\tstyle_acc_10 = 0.226562\tstyle_acc_50 = 0.363281\n",
      "[4/50][64/636] content_loss = 8.677328\tcontent_acc = 0.073669\tcontent_acc_10 = 0.176941\tcontent_acc_50 = 0.290100\tstyle_loss = 6.654078\tstyle_acc = 0.089722\tstyle_acc_10 = 0.224670\tstyle_acc_50 = 0.381531\n",
      "[4/50][127/636] content_loss = 8.552536\tcontent_acc = 0.076649\tcontent_acc_10 = 0.181195\tcontent_acc_50 = 0.297152\tstyle_loss = 6.655754\tstyle_acc = 0.090551\tstyle_acc_10 = 0.222072\tstyle_acc_50 = 0.380044\n",
      "[4/50][190/636] content_loss = 8.525902\tcontent_acc = 0.078988\tcontent_acc_10 = 0.182977\tcontent_acc_50 = 0.299301\tstyle_loss = 6.666324\tstyle_acc = 0.091550\tstyle_acc_10 = 0.223417\tstyle_acc_50 = 0.379749\n",
      "[4/50][253/636] content_loss = 8.522045\tcontent_acc = 0.078866\tcontent_acc_10 = 0.183872\tcontent_acc_50 = 0.301538\tstyle_loss = 6.672384\tstyle_acc = 0.091449\tstyle_acc_10 = 0.222842\tstyle_acc_50 = 0.380250\n",
      "[4/50][316/636] content_loss = 8.507109\tcontent_acc = 0.080029\tcontent_acc_10 = 0.185213\tcontent_acc_50 = 0.303167\tstyle_loss = 6.676628\tstyle_acc = 0.091550\tstyle_acc_10 = 0.223299\tstyle_acc_50 = 0.380081\n",
      "[4/50][379/636] content_loss = 8.478267\tcontent_acc = 0.080485\tcontent_acc_10 = 0.187768\tcontent_acc_50 = 0.305759\tstyle_loss = 6.673083\tstyle_acc = 0.092122\tstyle_acc_10 = 0.224450\tstyle_acc_50 = 0.381400\n",
      "[4/50][442/636] content_loss = 8.460182\tcontent_acc = 0.080856\tcontent_acc_10 = 0.188437\tcontent_acc_50 = 0.307083\tstyle_loss = 6.669408\tstyle_acc = 0.092177\tstyle_acc_10 = 0.224777\tstyle_acc_50 = 0.382070\n",
      "[4/50][505/636] content_loss = 8.437155\tcontent_acc = 0.082116\tcontent_acc_10 = 0.190207\tcontent_acc_50 = 0.308563\tstyle_loss = 6.659452\tstyle_acc = 0.092884\tstyle_acc_10 = 0.226508\tstyle_acc_50 = 0.383818\n",
      "[4/50][568/636] content_loss = 8.419974\tcontent_acc = 0.082795\tcontent_acc_10 = 0.191379\tcontent_acc_50 = 0.310382\tstyle_loss = 6.656888\tstyle_acc = 0.092966\tstyle_acc_10 = 0.226810\tstyle_acc_50 = 0.384704\n",
      "[4/50][631/636] content_loss = 8.404346\tcontent_acc = 0.084049\tcontent_acc_10 = 0.193003\tcontent_acc_50 = 0.312172\tstyle_loss = 6.652489\tstyle_acc = 0.093304\tstyle_acc_10 = 0.227479\tstyle_acc_50 = 0.385747\n",
      "[4/50] content_loss = 8.402039\tcontent_acc = 0.084078\tcontent_acc_10 = 0.193193\tcontent_acc_50 = 0.312399\tstyle_loss = 6.651558\tstyle_acc = 0.093461\tstyle_acc_10 = 0.227646\tstyle_acc_50 = 0.385986\n",
      "[5/50][1/636] content_loss = 8.005916\tcontent_acc = 0.105469\tcontent_acc_10 = 0.226562\tcontent_acc_50 = 0.359375\tstyle_loss = 6.111516\tstyle_acc = 0.109375\tstyle_acc_10 = 0.281250\tstyle_acc_50 = 0.468750\n",
      "[5/50][64/636] content_loss = 7.938316\tcontent_acc = 0.101257\tcontent_acc_10 = 0.224304\tcontent_acc_50 = 0.355042\tstyle_loss = 6.105658\tstyle_acc = 0.120544\tstyle_acc_10 = 0.284180\tstyle_acc_50 = 0.460266\n",
      "[5/50][127/636] content_loss = 7.819696\tcontent_acc = 0.104546\tcontent_acc_10 = 0.232560\tcontent_acc_50 = 0.360790\tstyle_loss = 6.099867\tstyle_acc = 0.122601\tstyle_acc_10 = 0.283219\tstyle_acc_50 = 0.459430\n",
      "[5/50][190/636] content_loss = 7.791489\tcontent_acc = 0.106887\tcontent_acc_10 = 0.234272\tcontent_acc_50 = 0.364165\tstyle_loss = 6.103467\tstyle_acc = 0.123787\tstyle_acc_10 = 0.284951\tstyle_acc_50 = 0.459149\n",
      "[5/50][253/636] content_loss = 7.783636\tcontent_acc = 0.106766\tcontent_acc_10 = 0.234421\tcontent_acc_50 = 0.366292\tstyle_loss = 6.111120\tstyle_acc = 0.123610\tstyle_acc_10 = 0.284075\tstyle_acc_50 = 0.459023\n",
      "[5/50][316/636] content_loss = 7.773695\tcontent_acc = 0.108077\tcontent_acc_10 = 0.234981\tcontent_acc_50 = 0.367633\tstyle_loss = 6.114395\tstyle_acc = 0.123702\tstyle_acc_10 = 0.284254\tstyle_acc_50 = 0.458836\n",
      "[5/50][379/636] content_loss = 7.749442\tcontent_acc = 0.109777\tcontent_acc_10 = 0.237168\tcontent_acc_50 = 0.369671\tstyle_loss = 6.109316\tstyle_acc = 0.124567\tstyle_acc_10 = 0.285228\tstyle_acc_50 = 0.460216\n",
      "[5/50][442/636] content_loss = 7.732108\tcontent_acc = 0.110188\tcontent_acc_10 = 0.237804\tcontent_acc_50 = 0.370652\tstyle_loss = 6.105067\tstyle_acc = 0.124700\tstyle_acc_10 = 0.285642\tstyle_acc_50 = 0.460778\n",
      "[5/50][505/636] content_loss = 7.708031\tcontent_acc = 0.111177\tcontent_acc_10 = 0.239596\tcontent_acc_50 = 0.372463\tstyle_loss = 6.096023\tstyle_acc = 0.125781\tstyle_acc_10 = 0.287214\tstyle_acc_50 = 0.462067\n",
      "[5/50][568/636] content_loss = 7.693065\tcontent_acc = 0.111569\tcontent_acc_10 = 0.240454\tcontent_acc_50 = 0.373604\tstyle_loss = 6.092448\tstyle_acc = 0.126018\tstyle_acc_10 = 0.287756\tstyle_acc_50 = 0.462904\n",
      "[5/50][631/636] content_loss = 7.680328\tcontent_acc = 0.112687\tcontent_acc_10 = 0.241680\tcontent_acc_50 = 0.375316\tstyle_loss = 6.089681\tstyle_acc = 0.126201\tstyle_acc_10 = 0.288567\tstyle_acc_50 = 0.463760\n",
      "[5/50] content_loss = 7.678109\tcontent_acc = 0.112684\tcontent_acc_10 = 0.241857\tcontent_acc_50 = 0.375482\tstyle_loss = 6.089010\tstyle_acc = 0.126285\tstyle_acc_10 = 0.288636\tstyle_acc_50 = 0.463917\n",
      "[6/50][1/636] content_loss = 7.318993\tcontent_acc = 0.125000\tcontent_acc_10 = 0.273438\tcontent_acc_50 = 0.402344\tstyle_loss = 5.551606\tstyle_acc = 0.183594\tstyle_acc_10 = 0.351562\tstyle_acc_50 = 0.523438\n",
      "[6/50][64/636] content_loss = 7.263883\tcontent_acc = 0.131104\tcontent_acc_10 = 0.270447\tcontent_acc_50 = 0.415344\tstyle_loss = 5.647102\tstyle_acc = 0.153381\tstyle_acc_10 = 0.340027\tstyle_acc_50 = 0.524048\n",
      "[6/50][127/636] content_loss = 7.179821\tcontent_acc = 0.135058\tcontent_acc_10 = 0.274453\tcontent_acc_50 = 0.419691\tstyle_loss = 5.641935\tstyle_acc = 0.152651\tstyle_acc_10 = 0.339936\tstyle_acc_50 = 0.524975\n",
      "[6/50][190/636] content_loss = 7.161569\tcontent_acc = 0.135074\tcontent_acc_10 = 0.276583\tcontent_acc_50 = 0.420477\tstyle_loss = 5.650165\tstyle_acc = 0.155099\tstyle_acc_10 = 0.339638\tstyle_acc_50 = 0.524075\n",
      "[6/50][253/636] content_loss = 7.163902\tcontent_acc = 0.134526\tcontent_acc_10 = 0.276911\tcontent_acc_50 = 0.421535\tstyle_loss = 5.649719\tstyle_acc = 0.155339\tstyle_acc_10 = 0.339875\tstyle_acc_50 = 0.524117\n",
      "[6/50][316/636] content_loss = 7.152601\tcontent_acc = 0.135952\tcontent_acc_10 = 0.278852\tcontent_acc_50 = 0.423346\tstyle_loss = 5.648354\tstyle_acc = 0.156435\tstyle_acc_10 = 0.340474\tstyle_acc_50 = 0.523784\n",
      "[6/50][379/636] content_loss = 7.128808\tcontent_acc = 0.137059\tcontent_acc_10 = 0.280920\tcontent_acc_50 = 0.425998\tstyle_loss = 5.643480\tstyle_acc = 0.157868\tstyle_acc_10 = 0.341349\tstyle_acc_50 = 0.524530\n",
      "[6/50][442/636] content_loss = 7.107148\tcontent_acc = 0.137267\tcontent_acc_10 = 0.282213\tcontent_acc_50 = 0.427496\tstyle_loss = 5.639233\tstyle_acc = 0.157823\tstyle_acc_10 = 0.341664\tstyle_acc_50 = 0.525179\n",
      "[6/50][505/636] content_loss = 7.085132\tcontent_acc = 0.138668\tcontent_acc_10 = 0.283957\tcontent_acc_50 = 0.429332\tstyle_loss = 5.626547\tstyle_acc = 0.159019\tstyle_acc_10 = 0.343851\tstyle_acc_50 = 0.527119\n",
      "[6/50][568/636] content_loss = 7.072775\tcontent_acc = 0.139036\tcontent_acc_10 = 0.284984\tcontent_acc_50 = 0.430781\tstyle_loss = 5.623092\tstyle_acc = 0.159331\tstyle_acc_10 = 0.344424\tstyle_acc_50 = 0.527007\n",
      "[6/50][631/636] content_loss = 7.065248\tcontent_acc = 0.140037\tcontent_acc_10 = 0.286116\tcontent_acc_50 = 0.431644\tstyle_loss = 5.618725\tstyle_acc = 0.159624\tstyle_acc_10 = 0.345069\tstyle_acc_50 = 0.527647\n",
      "[6/50] content_loss = 7.062582\tcontent_acc = 0.140156\tcontent_acc_10 = 0.286276\tcontent_acc_50 = 0.431906\tstyle_loss = 5.618070\tstyle_acc = 0.159742\tstyle_acc_10 = 0.345265\tstyle_acc_50 = 0.527841\n",
      "[7/50][1/636] content_loss = 6.803639\tcontent_acc = 0.148438\tcontent_acc_10 = 0.332031\tcontent_acc_50 = 0.476563\tstyle_loss = 5.240106\tstyle_acc = 0.179688\tstyle_acc_10 = 0.386719\tstyle_acc_50 = 0.574219\n",
      "[7/50][64/636] content_loss = 6.713168\tcontent_acc = 0.157288\tcontent_acc_10 = 0.315430\tcontent_acc_50 = 0.467346\tstyle_loss = 5.267120\tstyle_acc = 0.186829\tstyle_acc_10 = 0.388916\tstyle_acc_50 = 0.577332\n",
      "[7/50][127/636] content_loss = 6.617739\tcontent_acc = 0.161294\tcontent_acc_10 = 0.322250\tcontent_acc_50 = 0.472625\tstyle_loss = 5.256282\tstyle_acc = 0.185501\tstyle_acc_10 = 0.388318\tstyle_acc_50 = 0.578894\n",
      "[7/50][190/636] content_loss = 6.609128\tcontent_acc = 0.161698\tcontent_acc_10 = 0.323026\tcontent_acc_50 = 0.473458\tstyle_loss = 5.259161\tstyle_acc = 0.187541\tstyle_acc_10 = 0.388651\tstyle_acc_50 = 0.578104\n",
      "[7/50][253/636] content_loss = 6.603853\tcontent_acc = 0.161654\tcontent_acc_10 = 0.323925\tcontent_acc_50 = 0.475605\tstyle_loss = 5.254770\tstyle_acc = 0.188102\tstyle_acc_10 = 0.389544\tstyle_acc_50 = 0.579684\n",
      "[7/50][316/636] content_loss = 6.593890\tcontent_acc = 0.163210\tcontent_acc_10 = 0.324145\tcontent_acc_50 = 0.476983\tstyle_loss = 5.253069\tstyle_acc = 0.189292\tstyle_acc_10 = 0.390056\tstyle_acc_50 = 0.579052\n",
      "[7/50][379/636] content_loss = 6.573550\tcontent_acc = 0.164124\tcontent_acc_10 = 0.325445\tcontent_acc_50 = 0.479685\tstyle_loss = 5.249285\tstyle_acc = 0.189726\tstyle_acc_10 = 0.391728\tstyle_acc_50 = 0.579537\n",
      "[7/50][442/636] content_loss = 6.553985\tcontent_acc = 0.164177\tcontent_acc_10 = 0.326349\tcontent_acc_50 = 0.481017\tstyle_loss = 5.242532\tstyle_acc = 0.190275\tstyle_acc_10 = 0.392286\tstyle_acc_50 = 0.580458\n",
      "[7/50][505/636] content_loss = 6.536205\tcontent_acc = 0.165563\tcontent_acc_10 = 0.327344\tcontent_acc_50 = 0.482766\tstyle_loss = 5.232973\tstyle_acc = 0.191491\tstyle_acc_10 = 0.393858\tstyle_acc_50 = 0.581675\n",
      "[7/50][568/636] content_loss = 6.523095\tcontent_acc = 0.166016\tcontent_acc_10 = 0.328551\tcontent_acc_50 = 0.483784\tstyle_loss = 5.228431\tstyle_acc = 0.191929\tstyle_acc_10 = 0.394263\tstyle_acc_50 = 0.582231\n",
      "[7/50][631/636] content_loss = 6.513675\tcontent_acc = 0.167102\tcontent_acc_10 = 0.329809\tcontent_acc_50 = 0.484858\tstyle_loss = 5.223584\tstyle_acc = 0.192694\tstyle_acc_10 = 0.395119\tstyle_acc_50 = 0.583152\n",
      "[7/50] content_loss = 6.511662\tcontent_acc = 0.167212\tcontent_acc_10 = 0.330020\tcontent_acc_50 = 0.485048\tstyle_loss = 5.222778\tstyle_acc = 0.192775\tstyle_acc_10 = 0.395277\tstyle_acc_50 = 0.583257\n",
      "[8/50][1/636] content_loss = 6.226233\tcontent_acc = 0.191406\tcontent_acc_10 = 0.343750\tcontent_acc_50 = 0.519531\tstyle_loss = 4.903055\tstyle_acc = 0.207031\tstyle_acc_10 = 0.425781\tstyle_acc_50 = 0.617188\n",
      "[8/50][64/636] content_loss = 6.195691\tcontent_acc = 0.186035\tcontent_acc_10 = 0.359802\tcontent_acc_50 = 0.516907\tstyle_loss = 4.896070\tstyle_acc = 0.221191\tstyle_acc_10 = 0.436951\tstyle_acc_50 = 0.627441\n",
      "[8/50][127/636] content_loss = 6.123829\tcontent_acc = 0.188054\tcontent_acc_10 = 0.363866\tcontent_acc_50 = 0.521715\tstyle_loss = 4.896308\tstyle_acc = 0.219703\tstyle_acc_10 = 0.436977\tstyle_acc_50 = 0.627922\n",
      "[8/50][190/636] content_loss = 6.103833\tcontent_acc = 0.188076\tcontent_acc_10 = 0.364515\tcontent_acc_50 = 0.522924\tstyle_loss = 4.899938\tstyle_acc = 0.221711\tstyle_acc_10 = 0.437150\tstyle_acc_50 = 0.626357\n",
      "[8/50][253/636] content_loss = 6.107423\tcontent_acc = 0.187762\tcontent_acc_10 = 0.364347\tcontent_acc_50 = 0.524071\tstyle_loss = 4.900508\tstyle_acc = 0.221174\tstyle_acc_10 = 0.437160\tstyle_acc_50 = 0.626945\n",
      "[8/50][316/636] content_loss = 6.097386\tcontent_acc = 0.189156\tcontent_acc_10 = 0.365704\tcontent_acc_50 = 0.525131\tstyle_loss = 4.900110\tstyle_acc = 0.221915\tstyle_acc_10 = 0.437290\tstyle_acc_50 = 0.626706\n",
      "[8/50][379/636] content_loss = 6.080642\tcontent_acc = 0.190314\tcontent_acc_10 = 0.367229\tcontent_acc_50 = 0.527158\tstyle_loss = 4.897964\tstyle_acc = 0.222831\tstyle_acc_10 = 0.437881\tstyle_acc_50 = 0.627288\n",
      "[8/50][442/636] content_loss = 6.065650\tcontent_acc = 0.190478\tcontent_acc_10 = 0.367930\tcontent_acc_50 = 0.528130\tstyle_loss = 4.893105\tstyle_acc = 0.223460\tstyle_acc_10 = 0.438552\tstyle_acc_50 = 0.627810\n",
      "[8/50][505/636] content_loss = 6.046331\tcontent_acc = 0.192195\tcontent_acc_10 = 0.369144\tcontent_acc_50 = 0.529796\tstyle_loss = 4.882211\tstyle_acc = 0.224660\tstyle_acc_10 = 0.440231\tstyle_acc_50 = 0.629734\n",
      "[8/50][568/636] content_loss = 6.036856\tcontent_acc = 0.192754\tcontent_acc_10 = 0.369938\tcontent_acc_50 = 0.531064\tstyle_loss = 4.880197\tstyle_acc = 0.224850\tstyle_acc_10 = 0.440732\tstyle_acc_50 = 0.630075\n",
      "[8/50][631/636] content_loss = 6.029205\tcontent_acc = 0.193536\tcontent_acc_10 = 0.370852\tcontent_acc_50 = 0.532166\tstyle_loss = 4.877431\tstyle_acc = 0.225201\tstyle_acc_10 = 0.441573\tstyle_acc_50 = 0.630572\n",
      "[8/50] content_loss = 6.027607\tcontent_acc = 0.193653\tcontent_acc_10 = 0.370981\tcontent_acc_50 = 0.532372\tstyle_loss = 4.877105\tstyle_acc = 0.225314\tstyle_acc_10 = 0.441687\tstyle_acc_50 = 0.630590\n",
      "[9/50][1/636] content_loss = 5.925736\tcontent_acc = 0.214844\tcontent_acc_10 = 0.375000\tcontent_acc_50 = 0.550781\tstyle_loss = 4.519490\tstyle_acc = 0.238281\tstyle_acc_10 = 0.472656\tstyle_acc_50 = 0.667969\n",
      "[9/50][64/636] content_loss = 5.784945\tcontent_acc = 0.208618\tcontent_acc_10 = 0.396118\tcontent_acc_50 = 0.563293\tstyle_loss = 4.609160\tstyle_acc = 0.252808\tstyle_acc_10 = 0.479858\tstyle_acc_50 = 0.666077\n",
      "[9/50][127/636] content_loss = 5.698667\tcontent_acc = 0.214751\tcontent_acc_10 = 0.400806\tcontent_acc_50 = 0.565822\tstyle_loss = 4.601126\tstyle_acc = 0.252891\tstyle_acc_10 = 0.480130\tstyle_acc_50 = 0.666861\n",
      "[9/50][190/636] content_loss = 5.681174\tcontent_acc = 0.215707\tcontent_acc_10 = 0.401748\tcontent_acc_50 = 0.567311\tstyle_loss = 4.604367\tstyle_acc = 0.253742\tstyle_acc_10 = 0.480263\tstyle_acc_50 = 0.666591\n",
      "[9/50][253/636] content_loss = 5.679957\tcontent_acc = 0.214720\tcontent_acc_10 = 0.402822\tcontent_acc_50 = 0.569216\tstyle_loss = 4.604175\tstyle_acc = 0.253119\tstyle_acc_10 = 0.480886\tstyle_acc_50 = 0.667598\n",
      "[9/50][316/636] content_loss = 5.675484\tcontent_acc = 0.215066\tcontent_acc_10 = 0.403852\tcontent_acc_50 = 0.569657\tstyle_loss = 4.599533\tstyle_acc = 0.253820\tstyle_acc_10 = 0.481482\tstyle_acc_50 = 0.667833\n",
      "[9/50][379/636] content_loss = 5.655091\tcontent_acc = 0.216524\tcontent_acc_10 = 0.405827\tcontent_acc_50 = 0.572219\tstyle_loss = 4.596722\tstyle_acc = 0.254370\tstyle_acc_10 = 0.482417\tstyle_acc_50 = 0.668206\n",
      "[9/50][442/636] content_loss = 5.638722\tcontent_acc = 0.216788\tcontent_acc_10 = 0.406913\tcontent_acc_50 = 0.573609\tstyle_loss = 4.594216\tstyle_acc = 0.254056\tstyle_acc_10 = 0.482987\tstyle_acc_50 = 0.668870\n",
      "[9/50][505/636] content_loss = 5.621992\tcontent_acc = 0.218657\tcontent_acc_10 = 0.408369\tcontent_acc_50 = 0.575054\tstyle_loss = 4.584127\tstyle_acc = 0.255639\tstyle_acc_10 = 0.484004\tstyle_acc_50 = 0.670104\n",
      "[9/50][568/636] content_loss = 5.610764\tcontent_acc = 0.219548\tcontent_acc_10 = 0.409297\tcontent_acc_50 = 0.575966\tstyle_loss = 4.580581\tstyle_acc = 0.256444\tstyle_acc_10 = 0.484313\tstyle_acc_50 = 0.670018\n",
      "[9/50][631/636] content_loss = 5.604692\tcontent_acc = 0.220217\tcontent_acc_10 = 0.410051\tcontent_acc_50 = 0.576726\tstyle_loss = 4.576949\tstyle_acc = 0.256642\tstyle_acc_10 = 0.484988\tstyle_acc_50 = 0.670395\n",
      "[9/50] content_loss = 5.603252\tcontent_acc = 0.220301\tcontent_acc_10 = 0.410161\tcontent_acc_50 = 0.576776\tstyle_loss = 4.576293\tstyle_acc = 0.256747\tstyle_acc_10 = 0.485056\tstyle_acc_50 = 0.670373\n",
      "[10/50][1/636] content_loss = 5.477361\tcontent_acc = 0.234375\tcontent_acc_10 = 0.417969\tcontent_acc_50 = 0.589844\tstyle_loss = 4.267499\tstyle_acc = 0.273438\tstyle_acc_10 = 0.496094\tstyle_acc_50 = 0.703125\n",
      "[10/50][64/636] content_loss = 5.345852\tcontent_acc = 0.239746\tcontent_acc_10 = 0.436096\tcontent_acc_50 = 0.605591\tstyle_loss = 4.339720\tstyle_acc = 0.281128\tstyle_acc_10 = 0.515625\tstyle_acc_50 = 0.702698\n",
      "[10/50][127/636] content_loss = 5.285397\tcontent_acc = 0.242926\tcontent_acc_10 = 0.439745\tcontent_acc_50 = 0.606730\tstyle_loss = 4.339055\tstyle_acc = 0.281742\tstyle_acc_10 = 0.515748\tstyle_acc_50 = 0.702571\n",
      "[10/50][190/636] content_loss = 5.277891\tcontent_acc = 0.243174\tcontent_acc_10 = 0.440810\tcontent_acc_50 = 0.607874\tstyle_loss = 4.344732\tstyle_acc = 0.281970\tstyle_acc_10 = 0.515132\tstyle_acc_50 = 0.700308\n",
      "[10/50][253/636] content_loss = 5.274830\tcontent_acc = 0.243052\tcontent_acc_10 = 0.441592\tcontent_acc_50 = 0.609946\tstyle_loss = 4.338999\tstyle_acc = 0.282423\tstyle_acc_10 = 0.516320\tstyle_acc_50 = 0.700809\n",
      "[10/50][316/636] content_loss = 5.273373\tcontent_acc = 0.243869\tcontent_acc_10 = 0.441802\tcontent_acc_50 = 0.609672\tstyle_loss = 4.337507\tstyle_acc = 0.283005\tstyle_acc_10 = 0.516119\tstyle_acc_50 = 0.700368\n",
      "[10/50][379/636] content_loss = 5.260875\tcontent_acc = 0.244836\tcontent_acc_10 = 0.442890\tcontent_acc_50 = 0.610643\tstyle_loss = 4.337120\tstyle_acc = 0.283961\tstyle_acc_10 = 0.516913\tstyle_acc_50 = 0.700167\n",
      "[10/50][442/636] content_loss = 5.245226\tcontent_acc = 0.244980\tcontent_acc_10 = 0.443333\tcontent_acc_50 = 0.612177\tstyle_loss = 4.332426\tstyle_acc = 0.284405\tstyle_acc_10 = 0.517446\tstyle_acc_50 = 0.701198\n",
      "[10/50][505/636] content_loss = 5.226917\tcontent_acc = 0.246836\tcontent_acc_10 = 0.445282\tcontent_acc_50 = 0.613869\tstyle_loss = 4.321645\tstyle_acc = 0.285713\tstyle_acc_10 = 0.519114\tstyle_acc_50 = 0.702692\n",
      "[10/50][568/636] content_loss = 5.216863\tcontent_acc = 0.247318\tcontent_acc_10 = 0.446179\tcontent_acc_50 = 0.614911\tstyle_loss = 4.318365\tstyle_acc = 0.285926\tstyle_acc_10 = 0.519242\tstyle_acc_50 = 0.702898\n",
      "[10/50][631/636] content_loss = 5.211323\tcontent_acc = 0.247648\tcontent_acc_10 = 0.447163\tcontent_acc_50 = 0.615795\tstyle_loss = 4.315439\tstyle_acc = 0.286382\tstyle_acc_10 = 0.519934\tstyle_acc_50 = 0.703168\n",
      "[10/50] content_loss = 5.210179\tcontent_acc = 0.247688\tcontent_acc_10 = 0.447358\tcontent_acc_50 = 0.615908\tstyle_loss = 4.314868\tstyle_acc = 0.286466\tstyle_acc_10 = 0.520038\tstyle_acc_50 = 0.703127\n",
      "[11/50][1/636] content_loss = 5.024335\tcontent_acc = 0.265625\tcontent_acc_10 = 0.476563\tcontent_acc_50 = 0.660156\tstyle_loss = 4.118057\tstyle_acc = 0.289062\tstyle_acc_10 = 0.539062\tstyle_acc_50 = 0.750000\n",
      "[11/50][64/636] content_loss = 4.993507\tcontent_acc = 0.261475\tcontent_acc_10 = 0.473083\tcontent_acc_50 = 0.641785\tstyle_loss = 4.130965\tstyle_acc = 0.309204\tstyle_acc_10 = 0.547607\tstyle_acc_50 = 0.731018\n",
      "[11/50][127/636] content_loss = 4.955081\tcontent_acc = 0.264548\tcontent_acc_10 = 0.474594\tcontent_acc_50 = 0.641732\tstyle_loss = 4.120140\tstyle_acc = 0.307486\tstyle_acc_10 = 0.547859\tstyle_acc_50 = 0.731391\n",
      "[11/50][190/636] content_loss = 4.941667\tcontent_acc = 0.264659\tcontent_acc_10 = 0.476254\tcontent_acc_50 = 0.641838\tstyle_loss = 4.117075\tstyle_acc = 0.309725\tstyle_acc_10 = 0.548581\tstyle_acc_50 = 0.729091\n",
      "[11/50][253/636] content_loss = 4.944916\tcontent_acc = 0.264081\tcontent_acc_10 = 0.476161\tcontent_acc_50 = 0.642817\tstyle_loss = 4.113849\tstyle_acc = 0.310076\tstyle_acc_10 = 0.550395\tstyle_acc_50 = 0.729558\n",
      "[11/50][316/636] content_loss = 4.933912\tcontent_acc = 0.266070\tcontent_acc_10 = 0.477663\tcontent_acc_50 = 0.644371\tstyle_loss = 4.105882\tstyle_acc = 0.311647\tstyle_acc_10 = 0.551276\tstyle_acc_50 = 0.729950\n",
      "[11/50][379/636] content_loss = 4.921926\tcontent_acc = 0.267336\tcontent_acc_10 = 0.478665\tcontent_acc_50 = 0.645778\tstyle_loss = 4.104894\tstyle_acc = 0.311902\tstyle_acc_10 = 0.551276\tstyle_acc_50 = 0.730098\n",
      "[11/50][442/636] content_loss = 4.906067\tcontent_acc = 0.267887\tcontent_acc_10 = 0.479364\tcontent_acc_50 = 0.647412\tstyle_loss = 4.097717\tstyle_acc = 0.311943\tstyle_acc_10 = 0.552734\tstyle_acc_50 = 0.731220\n",
      "[11/50][505/636] content_loss = 4.886963\tcontent_acc = 0.269415\tcontent_acc_10 = 0.481235\tcontent_acc_50 = 0.649582\tstyle_loss = 4.086619\tstyle_acc = 0.313838\tstyle_acc_10 = 0.554718\tstyle_acc_50 = 0.732635\n",
      "[11/50][568/636] content_loss = 4.876697\tcontent_acc = 0.269937\tcontent_acc_10 = 0.482264\tcontent_acc_50 = 0.651030\tstyle_loss = 4.082640\tstyle_acc = 0.314302\tstyle_acc_10 = 0.554935\tstyle_acc_50 = 0.733192\n",
      "[11/50][631/636] content_loss = 4.870558\tcontent_acc = 0.270794\tcontent_acc_10 = 0.483378\tcontent_acc_50 = 0.651576\tstyle_loss = 4.079134\tstyle_acc = 0.315081\tstyle_acc_10 = 0.555616\tstyle_acc_50 = 0.733360\n",
      "[11/50] content_loss = 4.869558\tcontent_acc = 0.270882\tcontent_acc_10 = 0.483407\tcontent_acc_50 = 0.651671\tstyle_loss = 4.078497\tstyle_acc = 0.315150\tstyle_acc_10 = 0.555712\tstyle_acc_50 = 0.733381\n",
      "[12/50][1/636] content_loss = 4.697502\tcontent_acc = 0.296875\tcontent_acc_10 = 0.531250\tcontent_acc_50 = 0.675781\tstyle_loss = 3.970909\tstyle_acc = 0.300781\tstyle_acc_10 = 0.539062\tstyle_acc_50 = 0.757812\n",
      "[12/50][64/636] content_loss = 4.662535\tcontent_acc = 0.287292\tcontent_acc_10 = 0.506958\tcontent_acc_50 = 0.676208\tstyle_loss = 3.902393\tstyle_acc = 0.335327\tstyle_acc_10 = 0.579407\tstyle_acc_50 = 0.758545\n",
      "[12/50][127/636] content_loss = 4.619785\tcontent_acc = 0.289462\tcontent_acc_10 = 0.509443\tcontent_acc_50 = 0.678365\tstyle_loss = 3.897227\tstyle_acc = 0.333784\tstyle_acc_10 = 0.579540\tstyle_acc_50 = 0.759504\n",
      "[12/50][190/636] content_loss = 4.613140\tcontent_acc = 0.290234\tcontent_acc_10 = 0.510238\tcontent_acc_50 = 0.677796\tstyle_loss = 3.900680\tstyle_acc = 0.334910\tstyle_acc_10 = 0.578063\tstyle_acc_50 = 0.757874\n",
      "[12/50][253/636] content_loss = 4.616177\tcontent_acc = 0.290236\tcontent_acc_10 = 0.511487\tcontent_acc_50 = 0.678437\tstyle_loss = 3.897638\tstyle_acc = 0.334872\tstyle_acc_10 = 0.579545\tstyle_acc_50 = 0.758276\n",
      "[12/50][316/636] content_loss = 4.613625\tcontent_acc = 0.291671\tcontent_acc_10 = 0.511793\tcontent_acc_50 = 0.678315\tstyle_loss = 3.894008\tstyle_acc = 0.336494\tstyle_acc_10 = 0.580115\tstyle_acc_50 = 0.758245\n",
      "[12/50][379/636] content_loss = 4.598256\tcontent_acc = 0.293824\tcontent_acc_10 = 0.513388\tcontent_acc_50 = 0.679265\tstyle_loss = 3.891308\tstyle_acc = 0.337628\tstyle_acc_10 = 0.580465\tstyle_acc_50 = 0.757854\n",
      "[12/50][442/636] content_loss = 4.582961\tcontent_acc = 0.294727\tcontent_acc_10 = 0.514282\tcontent_acc_50 = 0.681269\tstyle_loss = 3.884867\tstyle_acc = 0.338200\tstyle_acc_10 = 0.581740\tstyle_acc_50 = 0.757945\n",
      "[12/50][505/636] content_loss = 4.569429\tcontent_acc = 0.295970\tcontent_acc_10 = 0.515602\tcontent_acc_50 = 0.682619\tstyle_loss = 3.876315\tstyle_acc = 0.339728\tstyle_acc_10 = 0.583215\tstyle_acc_50 = 0.759282\n",
      "[12/50][568/636] content_loss = 4.560616\tcontent_acc = 0.296607\tcontent_acc_10 = 0.516657\tcontent_acc_50 = 0.683759\tstyle_loss = 3.871297\tstyle_acc = 0.340504\tstyle_acc_10 = 0.583950\tstyle_acc_50 = 0.759614\n",
      "[12/50][631/636] content_loss = 4.552902\tcontent_acc = 0.297934\tcontent_acc_10 = 0.517761\tcontent_acc_50 = 0.684689\tstyle_loss = 3.867710\tstyle_acc = 0.341385\tstyle_acc_10 = 0.584780\tstyle_acc_50 = 0.759670\n",
      "[12/50] content_loss = 4.551656\tcontent_acc = 0.298111\tcontent_acc_10 = 0.517857\tcontent_acc_50 = 0.684763\tstyle_loss = 3.867176\tstyle_acc = 0.341425\tstyle_acc_10 = 0.584873\tstyle_acc_50 = 0.759695\n",
      "[13/50][1/636] content_loss = 4.392466\tcontent_acc = 0.335938\tcontent_acc_10 = 0.523438\tcontent_acc_50 = 0.691406\tstyle_loss = 3.653103\tstyle_acc = 0.339844\tstyle_acc_10 = 0.605469\tstyle_acc_50 = 0.816406\n",
      "[13/50][64/636] content_loss = 4.348706\tcontent_acc = 0.316284\tcontent_acc_10 = 0.538147\tcontent_acc_50 = 0.706177\tstyle_loss = 3.718903\tstyle_acc = 0.360413\tstyle_acc_10 = 0.608337\tstyle_acc_50 = 0.779236\n",
      "[13/50][127/636] content_loss = 4.322935\tcontent_acc = 0.318682\tcontent_acc_10 = 0.540324\tcontent_acc_50 = 0.706847\tstyle_loss = 3.717702\tstyle_acc = 0.361374\tstyle_acc_10 = 0.606976\tstyle_acc_50 = 0.779435\n",
      "[13/50][190/636] content_loss = 4.317035\tcontent_acc = 0.318380\tcontent_acc_10 = 0.541776\tcontent_acc_50 = 0.706373\tstyle_loss = 3.718680\tstyle_acc = 0.362479\tstyle_acc_10 = 0.606456\tstyle_acc_50 = 0.777447\n",
      "[13/50][253/636] content_loss = 4.321307\tcontent_acc = 0.317255\tcontent_acc_10 = 0.542428\tcontent_acc_50 = 0.707186\tstyle_loss = 3.712516\tstyle_acc = 0.363714\tstyle_acc_10 = 0.607754\tstyle_acc_50 = 0.778841\n",
      "[13/50][316/636] content_loss = 4.320237\tcontent_acc = 0.318075\tcontent_acc_10 = 0.543216\tcontent_acc_50 = 0.707847\tstyle_loss = 3.709738\tstyle_acc = 0.363825\tstyle_acc_10 = 0.608436\tstyle_acc_50 = 0.778530\n",
      "[13/50][379/636] content_loss = 4.307537\tcontent_acc = 0.319529\tcontent_acc_10 = 0.544432\tcontent_acc_50 = 0.708351\tstyle_loss = 3.708591\tstyle_acc = 0.364219\tstyle_acc_10 = 0.608581\tstyle_acc_50 = 0.778199\n",
      "[13/50][442/636] content_loss = 4.291239\tcontent_acc = 0.320392\tcontent_acc_10 = 0.545903\tcontent_acc_50 = 0.710584\tstyle_loss = 3.702453\tstyle_acc = 0.364713\tstyle_acc_10 = 0.609561\tstyle_acc_50 = 0.778696\n",
      "[13/50][505/636] content_loss = 4.276060\tcontent_acc = 0.321798\tcontent_acc_10 = 0.547509\tcontent_acc_50 = 0.712206\tstyle_loss = 3.692346\tstyle_acc = 0.366352\tstyle_acc_10 = 0.611231\tstyle_acc_50 = 0.779788\n",
      "[13/50][568/636] content_loss = 4.267807\tcontent_acc = 0.322644\tcontent_acc_10 = 0.548863\tcontent_acc_50 = 0.713351\tstyle_loss = 3.687534\tstyle_acc = 0.366864\tstyle_acc_10 = 0.611885\tstyle_acc_50 = 0.780026\n",
      "[13/50][631/636] content_loss = 4.262061\tcontent_acc = 0.323748\tcontent_acc_10 = 0.549846\tcontent_acc_50 = 0.713983\tstyle_loss = 3.684315\tstyle_acc = 0.367435\tstyle_acc_10 = 0.612297\tstyle_acc_50 = 0.780321\n",
      "[13/50] content_loss = 4.261272\tcontent_acc = 0.323944\tcontent_acc_10 = 0.549896\tcontent_acc_50 = 0.713953\tstyle_loss = 3.683645\tstyle_acc = 0.367638\tstyle_acc_10 = 0.612416\tstyle_acc_50 = 0.780281\n",
      "[14/50][1/636] content_loss = 4.132753\tcontent_acc = 0.324219\tcontent_acc_10 = 0.578125\tcontent_acc_50 = 0.738281\tstyle_loss = 3.594077\tstyle_acc = 0.328125\tstyle_acc_10 = 0.628906\tstyle_acc_50 = 0.792969\n",
      "[14/50][64/636] content_loss = 4.083502\tcontent_acc = 0.339355\tcontent_acc_10 = 0.569824\tcontent_acc_50 = 0.735535\tstyle_loss = 3.545611\tstyle_acc = 0.384583\tstyle_acc_10 = 0.635498\tstyle_acc_50 = 0.797668\n",
      "[14/50][127/636] content_loss = 4.066440\tcontent_acc = 0.341966\tcontent_acc_10 = 0.570559\tcontent_acc_50 = 0.734006\tstyle_loss = 3.545382\tstyle_acc = 0.382720\tstyle_acc_10 = 0.634381\tstyle_acc_50 = 0.799520\n",
      "[14/50][190/636] content_loss = 4.062117\tcontent_acc = 0.340995\tcontent_acc_10 = 0.570950\tcontent_acc_50 = 0.734519\tstyle_loss = 3.547872\tstyle_acc = 0.384539\tstyle_acc_10 = 0.633738\tstyle_acc_50 = 0.797595\n",
      "[14/50][253/636] content_loss = 4.056350\tcontent_acc = 0.340724\tcontent_acc_10 = 0.572706\tcontent_acc_50 = 0.736042\tstyle_loss = 3.538076\tstyle_acc = 0.386688\tstyle_acc_10 = 0.634727\tstyle_acc_50 = 0.798728\n",
      "[14/50][316/636] content_loss = 4.053619\tcontent_acc = 0.341513\tcontent_acc_10 = 0.572983\tcontent_acc_50 = 0.735883\tstyle_loss = 3.531607\tstyle_acc = 0.388363\tstyle_acc_10 = 0.635544\tstyle_acc_50 = 0.799298\n",
      "[14/50][379/636] content_loss = 4.040473\tcontent_acc = 0.343224\tcontent_acc_10 = 0.574559\tcontent_acc_50 = 0.736622\tstyle_loss = 3.528785\tstyle_acc = 0.389419\tstyle_acc_10 = 0.635678\tstyle_acc_50 = 0.799359\n",
      "[14/50][442/636] content_loss = 4.025298\tcontent_acc = 0.344351\tcontent_acc_10 = 0.576137\tcontent_acc_50 = 0.738741\tstyle_loss = 3.522118\tstyle_acc = 0.390077\tstyle_acc_10 = 0.636560\tstyle_acc_50 = 0.800065\n",
      "[14/50][505/636] content_loss = 4.011181\tcontent_acc = 0.345738\tcontent_acc_10 = 0.577429\tcontent_acc_50 = 0.740184\tstyle_loss = 3.512008\tstyle_acc = 0.391847\tstyle_acc_10 = 0.638513\tstyle_acc_50 = 0.801183\n",
      "[14/50][568/636] content_loss = 4.002577\tcontent_acc = 0.347134\tcontent_acc_10 = 0.578545\tcontent_acc_50 = 0.741410\tstyle_loss = 3.509684\tstyle_acc = 0.392571\tstyle_acc_10 = 0.638926\tstyle_acc_50 = 0.801173\n",
      "[14/50][631/636] content_loss = 3.997920\tcontent_acc = 0.347960\tcontent_acc_10 = 0.579617\tcontent_acc_50 = 0.741971\tstyle_loss = 3.506123\tstyle_acc = 0.393083\tstyle_acc_10 = 0.639381\tstyle_acc_50 = 0.801499\n",
      "[14/50] content_loss = 3.997577\tcontent_acc = 0.348097\tcontent_acc_10 = 0.579618\tcontent_acc_50 = 0.741836\tstyle_loss = 3.505741\tstyle_acc = 0.393183\tstyle_acc_10 = 0.639371\tstyle_acc_50 = 0.801429\n",
      "[15/50][1/636] content_loss = 3.971758\tcontent_acc = 0.347656\tcontent_acc_10 = 0.570312\tcontent_acc_50 = 0.750000\tstyle_loss = 3.440165\tstyle_acc = 0.394531\tstyle_acc_10 = 0.652344\tstyle_acc_50 = 0.812500\n",
      "[15/50][64/636] content_loss = 3.859371\tcontent_acc = 0.362671\tcontent_acc_10 = 0.595642\tcontent_acc_50 = 0.755127\tstyle_loss = 3.391492\tstyle_acc = 0.405762\tstyle_acc_10 = 0.654968\tstyle_acc_50 = 0.813354\n",
      "[15/50][127/636] content_loss = 3.835138\tcontent_acc = 0.363497\tcontent_acc_10 = 0.596734\tcontent_acc_50 = 0.756859\tstyle_loss = 3.392934\tstyle_acc = 0.405050\tstyle_acc_10 = 0.655758\tstyle_acc_50 = 0.814345\n",
      "[15/50][190/636] content_loss = 3.821689\tcontent_acc = 0.364391\tcontent_acc_10 = 0.599054\tcontent_acc_50 = 0.757833\tstyle_loss = 3.391826\tstyle_acc = 0.408183\tstyle_acc_10 = 0.654708\tstyle_acc_50 = 0.812932\n",
      "[15/50][253/636] content_loss = 3.824172\tcontent_acc = 0.364347\tcontent_acc_10 = 0.599895\tcontent_acc_50 = 0.758600\tstyle_loss = 3.388956\tstyle_acc = 0.408798\tstyle_acc_10 = 0.656049\tstyle_acc_50 = 0.814306\n",
      "[15/50][316/636] content_loss = 3.815818\tcontent_acc = 0.366347\tcontent_acc_10 = 0.600932\tcontent_acc_50 = 0.759148\tstyle_loss = 3.382181\tstyle_acc = 0.408698\tstyle_acc_10 = 0.657239\tstyle_acc_50 = 0.815356\n",
      "[15/50][379/636] content_loss = 3.806484\tcontent_acc = 0.367919\tcontent_acc_10 = 0.602284\tcontent_acc_50 = 0.760173\tstyle_loss = 3.380909\tstyle_acc = 0.409692\tstyle_acc_10 = 0.657322\tstyle_acc_50 = 0.814963\n",
      "[15/50][442/636] content_loss = 3.793085\tcontent_acc = 0.369494\tcontent_acc_10 = 0.603631\tcontent_acc_50 = 0.761807\tstyle_loss = 3.373881\tstyle_acc = 0.410704\tstyle_acc_10 = 0.658292\tstyle_acc_50 = 0.815620\n",
      "[15/50][505/636] content_loss = 3.776567\tcontent_acc = 0.371411\tcontent_acc_10 = 0.605817\tcontent_acc_50 = 0.763312\tstyle_loss = 3.362032\tstyle_acc = 0.413034\tstyle_acc_10 = 0.660667\tstyle_acc_50 = 0.816909\n",
      "[15/50][568/636] content_loss = 3.768712\tcontent_acc = 0.372373\tcontent_acc_10 = 0.606638\tcontent_acc_50 = 0.764373\tstyle_loss = 3.358769\tstyle_acc = 0.413891\tstyle_acc_10 = 0.660816\tstyle_acc_50 = 0.817362\n",
      "[15/50][631/636] content_loss = 3.764738\tcontent_acc = 0.373081\tcontent_acc_10 = 0.607252\tcontent_acc_50 = 0.764932\tstyle_loss = 3.355151\tstyle_acc = 0.414805\tstyle_acc_10 = 0.661233\tstyle_acc_50 = 0.817539\n",
      "[15/50] content_loss = 3.763852\tcontent_acc = 0.373237\tcontent_acc_10 = 0.607343\tcontent_acc_50 = 0.764994\tstyle_loss = 3.354649\tstyle_acc = 0.414953\tstyle_acc_10 = 0.661273\tstyle_acc_50 = 0.817510\n",
      "[16/50][1/636] content_loss = 3.606332\tcontent_acc = 0.367188\tcontent_acc_10 = 0.625000\tcontent_acc_50 = 0.769531\tstyle_loss = 3.170736\tstyle_acc = 0.425781\tstyle_acc_10 = 0.699219\tstyle_acc_50 = 0.835938\n",
      "[16/50][64/636] content_loss = 3.620589\tcontent_acc = 0.389038\tcontent_acc_10 = 0.627197\tcontent_acc_50 = 0.782227\tstyle_loss = 3.248769\tstyle_acc = 0.431580\tstyle_acc_10 = 0.677124\tstyle_acc_50 = 0.830872\n",
      "[16/50][127/636] content_loss = 3.600068\tcontent_acc = 0.390717\tcontent_acc_10 = 0.628353\tcontent_acc_50 = 0.781773\tstyle_loss = 3.245180\tstyle_acc = 0.430364\tstyle_acc_10 = 0.677350\tstyle_acc_50 = 0.831016\n",
      "[16/50][190/636] content_loss = 3.598216\tcontent_acc = 0.390584\tcontent_acc_10 = 0.628228\tcontent_acc_50 = 0.782155\tstyle_loss = 3.250003\tstyle_acc = 0.430839\tstyle_acc_10 = 0.676357\tstyle_acc_50 = 0.828742\n",
      "[16/50][253/636] content_loss = 3.601177\tcontent_acc = 0.389606\tcontent_acc_10 = 0.628644\tcontent_acc_50 = 0.782562\tstyle_loss = 3.247621\tstyle_acc = 0.431448\tstyle_acc_10 = 0.677186\tstyle_acc_50 = 0.829731\n",
      "[16/50][316/636] content_loss = 3.593271\tcontent_acc = 0.390885\tcontent_acc_10 = 0.628931\tcontent_acc_50 = 0.783228\tstyle_loss = 3.241326\tstyle_acc = 0.432271\tstyle_acc_10 = 0.677957\tstyle_acc_50 = 0.830276\n",
      "[16/50][379/636] content_loss = 3.582442\tcontent_acc = 0.392903\tcontent_acc_10 = 0.630267\tcontent_acc_50 = 0.783992\tstyle_loss = 3.239687\tstyle_acc = 0.433058\tstyle_acc_10 = 0.678183\tstyle_acc_50 = 0.830094\n",
      "[16/50][442/636] content_loss = 3.566455\tcontent_acc = 0.394381\tcontent_acc_10 = 0.632105\tcontent_acc_50 = 0.785969\tstyle_loss = 3.231649\tstyle_acc = 0.434486\tstyle_acc_10 = 0.679316\tstyle_acc_50 = 0.830927\n",
      "[16/50][505/636] content_loss = 3.552541\tcontent_acc = 0.395978\tcontent_acc_10 = 0.633323\tcontent_acc_50 = 0.787392\tstyle_loss = 3.220857\tstyle_acc = 0.436239\tstyle_acc_10 = 0.681312\tstyle_acc_50 = 0.831869\n",
      "[16/50][568/636] content_loss = 3.545698\tcontent_acc = 0.396849\tcontent_acc_10 = 0.634092\tcontent_acc_50 = 0.788155\tstyle_loss = 3.218468\tstyle_acc = 0.436977\tstyle_acc_10 = 0.681579\tstyle_acc_50 = 0.831928\n",
      "[16/50][631/636] content_loss = 3.544314\tcontent_acc = 0.397478\tcontent_acc_10 = 0.634385\tcontent_acc_50 = 0.788053\tstyle_loss = 3.215378\tstyle_acc = 0.437760\tstyle_acc_10 = 0.681743\tstyle_acc_50 = 0.832384\n",
      "[16/50] content_loss = 3.544067\tcontent_acc = 0.397623\tcontent_acc_10 = 0.634379\tcontent_acc_50 = 0.787954\tstyle_loss = 3.214796\tstyle_acc = 0.437913\tstyle_acc_10 = 0.681719\tstyle_acc_50 = 0.832350\n",
      "[17/50][1/636] content_loss = 3.560059\tcontent_acc = 0.375000\tcontent_acc_10 = 0.640625\tcontent_acc_50 = 0.796875\tstyle_loss = 3.104317\tstyle_acc = 0.421875\tstyle_acc_10 = 0.695312\tstyle_acc_50 = 0.863281\n",
      "[17/50][64/636] content_loss = 3.419200\tcontent_acc = 0.412292\tcontent_acc_10 = 0.652466\tcontent_acc_50 = 0.800049\tstyle_loss = 3.114053\tstyle_acc = 0.449585\tstyle_acc_10 = 0.694031\tstyle_acc_50 = 0.846497\n",
      "[17/50][127/636] content_loss = 3.402547\tcontent_acc = 0.412986\tcontent_acc_10 = 0.653143\tcontent_acc_50 = 0.800627\tstyle_loss = 3.111649\tstyle_acc = 0.451372\tstyle_acc_10 = 0.695897\tstyle_acc_50 = 0.845380\n",
      "[17/50][190/636] content_loss = 3.393532\tcontent_acc = 0.414597\tcontent_acc_10 = 0.653289\tcontent_acc_50 = 0.801480\tstyle_loss = 3.113379\tstyle_acc = 0.453701\tstyle_acc_10 = 0.696217\tstyle_acc_50 = 0.844058\n",
      "[17/50][253/636] content_loss = 3.391872\tcontent_acc = 0.414356\tcontent_acc_10 = 0.653502\tcontent_acc_50 = 0.802896\tstyle_loss = 3.107830\tstyle_acc = 0.454360\tstyle_acc_10 = 0.697582\tstyle_acc_50 = 0.844800\n",
      "[17/50][316/636] content_loss = 3.388375\tcontent_acc = 0.415249\tcontent_acc_10 = 0.654050\tcontent_acc_50 = 0.802945\tstyle_loss = 3.102363\tstyle_acc = 0.455523\tstyle_acc_10 = 0.697946\tstyle_acc_50 = 0.845048\n",
      "[17/50][379/636] content_loss = 3.379755\tcontent_acc = 0.416814\tcontent_acc_10 = 0.655044\tcontent_acc_50 = 0.803791\tstyle_loss = 3.102217\tstyle_acc = 0.455805\tstyle_acc_10 = 0.697456\tstyle_acc_50 = 0.844843\n",
      "[17/50][442/636] content_loss = 3.368603\tcontent_acc = 0.417933\tcontent_acc_10 = 0.656056\tcontent_acc_50 = 0.805050\tstyle_loss = 3.098086\tstyle_acc = 0.456377\tstyle_acc_10 = 0.697902\tstyle_acc_50 = 0.845358\n",
      "[17/50][505/636] content_loss = 3.354751\tcontent_acc = 0.419539\tcontent_acc_10 = 0.657635\tcontent_acc_50 = 0.806165\tstyle_loss = 3.087113\tstyle_acc = 0.458725\tstyle_acc_10 = 0.699938\tstyle_acc_50 = 0.846457\n",
      "[17/50][568/636] content_loss = 3.348821\tcontent_acc = 0.420218\tcontent_acc_10 = 0.658485\tcontent_acc_50 = 0.807033\tstyle_loss = 3.084090\tstyle_acc = 0.459218\tstyle_acc_10 = 0.700078\tstyle_acc_50 = 0.846735\n",
      "[17/50][631/636] content_loss = 3.346626\tcontent_acc = 0.420767\tcontent_acc_10 = 0.659023\tcontent_acc_50 = 0.807046\tstyle_loss = 3.081628\tstyle_acc = 0.459730\tstyle_acc_10 = 0.700475\tstyle_acc_50 = 0.846827\n",
      "[17/50] content_loss = 3.346619\tcontent_acc = 0.420819\tcontent_acc_10 = 0.658941\tcontent_acc_50 = 0.807000\tstyle_loss = 3.081524\tstyle_acc = 0.459794\tstyle_acc_10 = 0.700487\tstyle_acc_50 = 0.846678\n",
      "[18/50][1/636] content_loss = 3.254012\tcontent_acc = 0.453125\tcontent_acc_10 = 0.687500\tcontent_acc_50 = 0.820312\tstyle_loss = 3.072588\tstyle_acc = 0.460937\tstyle_acc_10 = 0.703125\tstyle_acc_50 = 0.851562\n",
      "[18/50][64/636] content_loss = 3.230243\tcontent_acc = 0.436340\tcontent_acc_10 = 0.672668\tcontent_acc_50 = 0.818542\tstyle_loss = 2.998110\tstyle_acc = 0.472900\tstyle_acc_10 = 0.714661\tstyle_acc_50 = 0.857300\n",
      "[18/50][127/636] content_loss = 3.223155\tcontent_acc = 0.433840\tcontent_acc_10 = 0.673321\tcontent_acc_50 = 0.818406\tstyle_loss = 2.997532\tstyle_acc = 0.470503\tstyle_acc_10 = 0.715797\tstyle_acc_50 = 0.856976\n",
      "[18/50][190/636] content_loss = 3.212664\tcontent_acc = 0.434539\tcontent_acc_10 = 0.673787\tcontent_acc_50 = 0.819285\tstyle_loss = 3.002287\tstyle_acc = 0.471608\tstyle_acc_10 = 0.713096\tstyle_acc_50 = 0.855016\n",
      "[18/50][253/636] content_loss = 3.206990\tcontent_acc = 0.436543\tcontent_acc_10 = 0.675025\tcontent_acc_50 = 0.820807\tstyle_loss = 2.995618\tstyle_acc = 0.472625\tstyle_acc_10 = 0.715122\tstyle_acc_50 = 0.856333\n",
      "[18/50][316/636] content_loss = 3.204229\tcontent_acc = 0.437599\tcontent_acc_10 = 0.675200\tcontent_acc_50 = 0.820584\tstyle_loss = 2.991389\tstyle_acc = 0.473546\tstyle_acc_10 = 0.715252\tstyle_acc_50 = 0.856853\n",
      "[18/50][379/636] content_loss = 3.197520\tcontent_acc = 0.439417\tcontent_acc_10 = 0.676472\tcontent_acc_50 = 0.820828\tstyle_loss = 2.990645\tstyle_acc = 0.473007\tstyle_acc_10 = 0.715081\tstyle_acc_50 = 0.856726\n",
      "[18/50][442/636] content_loss = 3.184912\tcontent_acc = 0.440832\tcontent_acc_10 = 0.678468\tcontent_acc_50 = 0.822663\tstyle_loss = 2.984724\tstyle_acc = 0.474053\tstyle_acc_10 = 0.715781\tstyle_acc_50 = 0.856936\n",
      "[18/50][505/636] content_loss = 3.169977\tcontent_acc = 0.442590\tcontent_acc_10 = 0.680554\tcontent_acc_50 = 0.824358\tstyle_loss = 2.974856\tstyle_acc = 0.476207\tstyle_acc_10 = 0.717706\tstyle_acc_50 = 0.857712\n",
      "[18/50][568/636] content_loss = 3.162199\tcontent_acc = 0.444061\tcontent_acc_10 = 0.681840\tcontent_acc_50 = 0.825120\tstyle_loss = 2.971639\tstyle_acc = 0.476452\tstyle_acc_10 = 0.717959\tstyle_acc_50 = 0.858068\n",
      "[18/50][631/636] content_loss = 3.161783\tcontent_acc = 0.444167\tcontent_acc_10 = 0.681854\tcontent_acc_50 = 0.825166\tstyle_loss = 2.968547\tstyle_acc = 0.477033\tstyle_acc_10 = 0.718509\tstyle_acc_50 = 0.858162\n",
      "[18/50] content_loss = 3.161314\tcontent_acc = 0.444307\tcontent_acc_10 = 0.681904\tcontent_acc_50 = 0.825161\tstyle_loss = 2.968159\tstyle_acc = 0.477200\tstyle_acc_10 = 0.718446\tstyle_acc_50 = 0.858067\n",
      "[19/50][1/636] content_loss = 3.060431\tcontent_acc = 0.437500\tcontent_acc_10 = 0.699219\tcontent_acc_50 = 0.843750\tstyle_loss = 2.855734\tstyle_acc = 0.472656\tstyle_acc_10 = 0.734375\tstyle_acc_50 = 0.886719\n",
      "[19/50][64/636] content_loss = 3.074335\tcontent_acc = 0.457336\tcontent_acc_10 = 0.695740\tcontent_acc_50 = 0.835754\tstyle_loss = 2.903470\tstyle_acc = 0.487915\tstyle_acc_10 = 0.726318\tstyle_acc_50 = 0.867554\n",
      "[19/50][127/636] content_loss = 3.059649\tcontent_acc = 0.457124\tcontent_acc_10 = 0.696297\tcontent_acc_50 = 0.835292\tstyle_loss = 2.900709\tstyle_acc = 0.487020\tstyle_acc_10 = 0.727485\tstyle_acc_50 = 0.866542\n",
      "[19/50][190/636] content_loss = 3.049246\tcontent_acc = 0.456805\tcontent_acc_10 = 0.697656\tcontent_acc_50 = 0.836246\tstyle_loss = 2.899907\tstyle_acc = 0.488220\tstyle_acc_10 = 0.727159\tstyle_acc_50 = 0.866016\n",
      "[19/50][253/636] content_loss = 3.045032\tcontent_acc = 0.457711\tcontent_acc_10 = 0.698447\tcontent_acc_50 = 0.837343\tstyle_loss = 2.891759\tstyle_acc = 0.489702\tstyle_acc_10 = 0.728740\tstyle_acc_50 = 0.867049\n",
      "[19/50][316/636] content_loss = 3.039902\tcontent_acc = 0.458712\tcontent_acc_10 = 0.698551\tcontent_acc_50 = 0.837643\tstyle_loss = 2.884912\tstyle_acc = 0.491001\tstyle_acc_10 = 0.729542\tstyle_acc_50 = 0.867880\n",
      "[19/50][379/636] content_loss = 3.034921\tcontent_acc = 0.460195\tcontent_acc_10 = 0.699301\tcontent_acc_50 = 0.837937\tstyle_loss = 2.884502\tstyle_acc = 0.490940\tstyle_acc_10 = 0.730005\tstyle_acc_50 = 0.867260\n",
      "[19/50][442/636] content_loss = 3.024025\tcontent_acc = 0.461812\tcontent_acc_10 = 0.700942\tcontent_acc_50 = 0.839057\tstyle_loss = 2.877582\tstyle_acc = 0.492373\tstyle_acc_10 = 0.731061\tstyle_acc_50 = 0.867815\n",
      "[19/50][505/636] content_loss = 3.010811\tcontent_acc = 0.463877\tcontent_acc_10 = 0.702212\tcontent_acc_50 = 0.840432\tstyle_loss = 2.867217\tstyle_acc = 0.494493\tstyle_acc_10 = 0.732952\tstyle_acc_50 = 0.868642\n",
      "[19/50][568/636] content_loss = 3.004197\tcontent_acc = 0.465078\tcontent_acc_10 = 0.702809\tcontent_acc_50 = 0.841040\tstyle_loss = 2.862748\tstyle_acc = 0.495454\tstyle_acc_10 = 0.733522\tstyle_acc_50 = 0.869209\n",
      "[19/50][631/636] content_loss = 3.003092\tcontent_acc = 0.465302\tcontent_acc_10 = 0.703057\tcontent_acc_50 = 0.841138\tstyle_loss = 2.861453\tstyle_acc = 0.495970\tstyle_acc_10 = 0.733775\tstyle_acc_50 = 0.868896\n",
      "[19/50] content_loss = 3.002822\tcontent_acc = 0.465385\tcontent_acc_10 = 0.703001\tcontent_acc_50 = 0.841129\tstyle_loss = 2.860946\tstyle_acc = 0.496063\tstyle_acc_10 = 0.733765\tstyle_acc_50 = 0.868894\n",
      "[20/50][1/636] content_loss = 2.933239\tcontent_acc = 0.500000\tcontent_acc_10 = 0.703125\tcontent_acc_50 = 0.871094\tstyle_loss = 2.769476\tstyle_acc = 0.500000\tstyle_acc_10 = 0.742188\tstyle_acc_50 = 0.886719\n",
      "[20/50][64/636] content_loss = 2.915561\tcontent_acc = 0.477783\tcontent_acc_10 = 0.716797\tcontent_acc_50 = 0.849365\tstyle_loss = 2.793376\tstyle_acc = 0.507263\tstyle_acc_10 = 0.745728\tstyle_acc_50 = 0.876160\n",
      "[20/50][127/636] content_loss = 2.903142\tcontent_acc = 0.477731\tcontent_acc_10 = 0.716874\tcontent_acc_50 = 0.848487\tstyle_loss = 2.794151\tstyle_acc = 0.505752\tstyle_acc_10 = 0.746063\tstyle_acc_50 = 0.875523\n",
      "[20/50][190/636] content_loss = 2.892497\tcontent_acc = 0.479770\tcontent_acc_10 = 0.716961\tcontent_acc_50 = 0.851234\tstyle_loss = 2.797005\tstyle_acc = 0.507134\tstyle_acc_10 = 0.742804\tstyle_acc_50 = 0.874363\n",
      "[20/50][253/636] content_loss = 2.886420\tcontent_acc = 0.480222\tcontent_acc_10 = 0.718657\tcontent_acc_50 = 0.851532\tstyle_loss = 2.792761\tstyle_acc = 0.508337\tstyle_acc_10 = 0.743932\tstyle_acc_50 = 0.875278\n"
     ]
    }
   ],
   "source": [
    "content_losses = []\n",
    "content_accs = []\n",
    "content_accs_10 = []\n",
    "content_accs_50 = []\n",
    "style_losses = []\n",
    "style_accs = []\n",
    "style_accs_10 = []\n",
    "style_accs_50 = []\n",
    "for epoch in range(epochs):\n",
    "    mean_content_loss = 0.0\n",
    "    mean_content_acc = 0.0\n",
    "    mean_content_acc_10 = 0.0\n",
    "    mean_content_acc_50 = 0.0\n",
    "    mean_style_loss = 0.0\n",
    "    mean_style_acc = 0.0\n",
    "    mean_style_acc_10 = 0.0\n",
    "    mean_style_acc_50 = 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",
    "        content_y_10 = content_pred.topk(10, dim=1).indices\n",
    "        content_y_50 = content_pred.topk(50, dim=1).indices\n",
    "        style_pred = style_classifier(style_features)\n",
    "        style_y = style_pred.max(dim=1).indices\n",
    "        style_y_10 = style_pred.topk(10, dim=1).indices\n",
    "        style_y_50 = style_pred.topk(50, 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",
    "        content_acc_10 = (content_y_10 == y.view(-1,1).repeat(1,10)).any(dim=1).sum() / y.size(0)\n",
    "        content_acc_50 = (content_y_50 == y.view(-1,1).repeat(1,50)).any(dim=1).sum() / y.size(0)\n",
    "        style_acc = (style_y == y).sum() / y.size(0)\n",
    "        style_acc_10 = (style_y_10 == y.view(-1,1).repeat(1,10)).any(dim=1).sum() / y.size(0)\n",
    "        style_acc_50 = (style_y_50 == y.view(-1,1).repeat(1,50)).any(dim=1).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_content_acc_10 += content_acc_10.item() / len(test_loader)\n",
    "        mean_content_acc_50 += content_acc_50.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",
    "        mean_style_acc_10 += style_acc_10.item() / len(test_loader)\n",
    "        mean_style_acc_50 += style_acc_50.item() / len(test_loader)\n",
    "        if i % (len(test_loader) // 10) == 0:\n",
    "            correction = len(test_loader) / (i+1)\n",
    "            print(f\"[{epoch+1}/{epochs}][{i+1}/{len(test_loader)}] \"\n",
    "                  f\"content_loss = {mean_content_loss*correction:4f}\\t\"\n",
    "                  f\"content_acc = {mean_content_acc*correction:4f}\\t\"\n",
    "                  f\"content_acc_10 = {mean_content_acc_10*correction:4f}\\t\"\n",
    "                  f\"content_acc_50 = {mean_content_acc_50*correction:4f}\\t\"\n",
    "                  f\"style_loss = {mean_style_loss*correction:4f}\\t\"\n",
    "                  f\"style_acc = {mean_style_acc*correction:4f}\\t\"\n",
    "                  f\"style_acc_10 = {mean_style_acc_10*correction:4f}\\t\"\n",
    "                  f\"style_acc_50 = {mean_style_acc_50*correction:4f}\"\n",
    "            )\n",
    "    # Record epoch mean loss and acc\n",
    "    content_losses.append(mean_content_loss)\n",
    "    content_accs.append(mean_content_acc)\n",
    "    content_accs_10.append(mean_content_acc_10)\n",
    "    content_accs_50.append(mean_content_acc_50)\n",
    "    style_losses.append(mean_style_loss)\n",
    "    style_accs.append(mean_style_acc)\n",
    "    style_accs_10.append(mean_style_acc_10)\n",
    "    style_accs_50.append(mean_style_acc_50)\n",
    "    print(f\"[{epoch+1}/{epochs}] \"\n",
    "          f\"content_loss = {mean_content_loss:4f}\\t\"\n",
    "          f\"content_acc = {mean_content_acc:4f}\\t\"\n",
    "          f\"content_acc_10 = {mean_content_acc_10:4f}\\t\"\n",
    "          f\"content_acc_50 = {mean_content_acc_50:4f}\\t\"\n",
    "          f\"style_loss = {mean_style_loss:4f}\\t\"\n",
    "          f\"style_acc = {mean_style_acc:4f}\\t\"\n",
    "          f\"style_acc_10 = {mean_style_acc_10:4f}\\t\"\n",
    "          f\"style_acc_50 = {mean_style_acc_50:4f}\"\n",
    "    )\n",
    "    content_classifier_optim_sched.step()\n",
    "    style_classifier_optim_sched.step()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "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/celeba_{classifier_name}{'_cond' if conditional else ''}_loss_one_style0.pdf\")\n",
    "\n",
    "plt.figure()\n",
    "plt.plot(np.array(moving_avg(content_accs)), label=\"content, top 1\", color='C0', linestyle='solid')\n",
    "plt.plot(np.array(moving_avg(content_accs_10)), label=\"content, top 10\", color='C2', linestyle='solid')\n",
    "plt.plot(np.array(moving_avg(content_accs_50)), label=\"content, top 50\", color='C4', linestyle='solid')\n",
    "plt.plot(np.array(moving_avg(style_accs)), label=\"style, top 1\", color='C1', linestyle='dashed')\n",
    "plt.plot(np.array(moving_avg(style_accs_10)), label=\"style, top 10\", color='C3', linestyle='dashed')\n",
    "plt.plot(np.array(moving_avg(style_accs_50)), label=\"style, top 50\", color='C5', linestyle='dashed')\n",
    "plt.title(\"Accuracy\")\n",
    "plt.ylabel(\"Accuracy\")\n",
    "plt.xlabel(\"Epochs\")\n",
    "plt.legend(prop={'size': 8})\n",
    "plt.tight_layout()\n",
    "plt.savefig(f\"results/celeba_{classifier_name}{'_cond' if conditional else ''}_acc_one_style0.pdf\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "jp-MarkdownHeadingCollapsed": true,
    "tags": []
   },
   "source": [
    "## Train a classifier on all style features"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "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": 26,
   "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": 27,
   "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": 28,
   "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/PqlWrWqWdPXs2F154IQAPPPBA5y+kIByturPLuSAI+3f22WfrNptN9/l8Haa54oordLPZrFdXV+s1NTX63Llz9dzcXN1iseh5eXn65ZdfrldXV8fT+/1+/Y477tB79+6tm81mPSsrS7/wwgv1oqKieJqqqir9ggsu0B0Oh56cnKxfe+21+rp169odnuV0OtvN14YNG/QZM2boLpdLT0tL06+++mp99erVbc6h67q+bt06/bzzztOTkpJ0m82mDxw4UL/rrrvanDMUCunJycm62+3WA4FAJ6+iIBy9xFzfgiAcVaLRKDk5OZx99tk8++yz3Z0dQTjsRBu1IAhHlbfffpuqqqpWHdQE4YdMlKgFQTgqLF26lDVr1vDAAw+QlpbGypUruztLgnBEiBK1IAhHhaeeeorrr7+ejIwM/vWvf3V3dgThiBElakEQBEHowUSJWhAEQRB6MBGoBUEQBKEHO+YmPNE0jdLSUhISEg5ppSBBEARBOFi6rtPY2EhOTk6befL3dswF6tLSUvLz87s7G4IgCILA7t272115rqVuDdRffPEFDz/8MCtWrKCsrIy33nqLc889d5/HLF68mHnz5rF+/Xry8/O58847ueKKKzr9ngkJCYBxcRITEw8h94IgCIJwcDweD/n5+fGYtC/dGqh9Ph8jR45kzpw5nH/++ftNv2PHDs4880yuu+46FixYwKJFi7jqqqvIzs5m5syZnXrPpuruxMREEagFQRCEbtWZJthuDdSnn346p59+eqfTP/300/Tu3ZtHHnkEgMGDB/PVV1/x2GOPdTpQC4IgCMLR5Kjq9b1kyRJmzJjRat/MmTNZsmRJh8eEQiE8Hk+rTRAEQRCOFkdVoC4vLyczM7PVvszMTDweD4FAoN1j5s+fj9vtjm+iI5kgCIJwNDmqAvXBuP3222loaIhvu3fv7u4sCYIgCEKnHVXDs7KysqioqGi1r6KigsTEROx2e7vHWK1WrFbrkcieIAiCIHS5oypQT5o0iQ8++KDVvoULFzJp0qRuypEgCMKRoes6mg6qpqPpxqbroMdeMx6bEnfifDQf33T+lufQaX5x7/1Nx2ma8VyN56c5j035bH409jel2RdN141zaq0/c8vPrmnEr0HT+2u68TkA4n2pJQnJeIjtl4zPFvtMeuxJyywZ6SUkCeTY8bIkgfGPC8bkIctHbsKsbg3UXq+Xbdu2xX/esWMHq1atIiUlhV69enH77bezZ8+e+Eo51113HX/5y1/49a9/zZw5c/j000/5z3/+w/vvv99dH0EQOk2P32ha3Oxiz5tuMJoOtLOv5U2TFjec2L3D+Dl2Q+lI040uoumoqk5U04hqOtHY86b3a3XDj+Vzv58NiKpN59danV+NvUdHN1VN01F1UGPpNU1v9dh8cyZ2g27xXCd2vB5/TW3a1+Kmru61X42nbbrmevxz7B2QgFYBsfn32Znr0vw7j+cn9r6q1vT71ZuDXtN7tfy8Lf5uhJ7h/DH7nqCkq3VroP7uu+84+eST4z/PmzcPgMsvv5wXXniBsrIyiouL46/37t2b999/n1tuuYU//elP5OXl8Y9//EMMzTpK6bpOJHZzj2paLGAYz5u+ke99w27aF45qhFWNcFQjFFWNn1vs0/Xmb+V67AbddOOLak3HafHjQmrzPjWWFzV+Q9Vb/azF7trxG6zeIujqsUCo6UTVWCCMPRc3WuFo0/RFsOWXQGNfc2lTbnqUm59LkoQiN70uocjGJkugyFL8+H1pPiZ2vCQhy8T3tXzvlu/X8rwtvwzHf4Y2JWxJav5cLb9EN/0f15vuI7Gfj/Tk08fcMpcejwe3201DQ4OY8CQmFFXxh1R84Sj+sIo3FMUfMh59oSi+cJTGYOx5KIo3pBKIRImoLUo/eutgFlU1wqpOOKoSUZsDayQWFEXgOjCyZNwsm/67ti71dl7Tzc8cezQpMiZZwiRL8aq8ljdiaL5Rd+bcJlnCpEgocvN5TUrzzbbVjT1245Viz01NeYrlxdTiJm2SpVi6tkFBlkCO3chbvocSO48iSa1fb9oXO66parPpZm185uZqzqbPHk9Dy+u0f/JeAacp3y3zKknNwbAp2Ei0DUztBawm7f3e9qdNABbrHxwxBxKLjqo2aqGZruvU+yPU+sPU+cLU+SPU+cLGz7F9jcEooViJMxTRmp9HNUIRjUBExR82Am5PEr/hy83fxJtu/E0/W0wyFkXGYpKxmlo/mhUZRWq+sSt73eQVWWpzjHEuJXZ8i4AhNQeephtk003TKFEANN1sjZueSZGMPMQDVYu8Nx0rE78ptywFNJ+3ZfDY/82z6Rv/vogbsSAcnUSgPgrU+sJsLm9ka2Wj8VjhZXNFIw2BSJe+j9Uk47KacFgVnBYTTquxuVr87LI27VcwxYJnvPTTMrhKsWDaKhAaQdRikjHHApjS4hizIscDnnBgJGn/VYmCIBydRKDuQWq8IbZWetla6WVbRSNbK71sqWik2hvu8JgEm4lkh4Vkp4UUhzn+PNlhJtFuxmZSsJqNkqPVpBiPZhmLomC3KDitCk6rCYdZwaT84IfVC4IgHHVEoO4mVY0hPtlYwbo9DUZgrvRS6+s4IOen2BmYmUD/zITYo4u+6S5sZuUI5loQBEE40kSgPoKqGkN8uL6cD9aUsXRHTZvOVJIEecl2+mck0D/DRb8MFwMyE+iX4cJpFb8qQRCEY5G4+x9m1d4QH64r54O1ZXy7vXVwHpnn5vh+aQzIdNE/I4E+6U4cFvErEQRBEJqJqHAY3fHWWl5eVtwmOJ8xPJszhmeTn+LovswJgiAIRwURqA+TCk+QBUuNyVpG5Lk5UwRnQRAE4SCIQH2YfLGlCjBK0O/MPaGbcyMIgiAcrcR4nMPk81igPnFAejfnRBAEQTiaiUB9GKiazlfbqgERqAVBEIRDIwL1YbB2TwP1/ggJVhOj8pO6OzuCIAjCUUwE6sOgqX36+H6pmMVsX4IgCMIhEFHkMPhCtE8LgiAIXUQE6i7mCUb4fnc9ACf2F4FaEARBODQiUHexb7ZVo2o6fdKdYsy0IAiCcMhEoO5in2+J9fYWpWlBEAShC4hA3YV0XY+3T08V7dOCIAhCFxCBugsVVfnYUx/AoshM7JPS3dkRBEEQfgBEoO5CTaXp8b2TxSpYgiAIQpcQgboLfbE1NixLtE8LgiAIXUQE6i4SjKh8u70GEOOnBUEQhK4jAnUX+W5nHcGIRkaClUFZCd2dHUEQBOEHQgTqLhKv9h6QjiRJ3ZwbQRAE4YdCBOouIqYNFQRBEA4HEai7QHlDkE3ljUgSTOmX1t3ZEQRBEH5ARKDuAk3V3iNy3SQ7Ld2cG0EQBOGHRATqLiCqvQVBEITDRQTqQ6RqOl9ti83vLQK1IAiC0MVEoD5Ea/c0UO+PkGAzMTo/qbuzIwiCIPzAiEB9iJqqvSf3TcOkiMspCIIgdC0RWQ6RaJ8WBEEQDicRqA9BQyDC97vrAThxgBiWJQiCIHS9bg/UTz75JIWFhdhsNiZOnMiyZcv2mf7xxx9n4MCB2O128vPzueWWWwgGg0cot619s60aVdPpk+4kL9nRLXkQBEEQfti6NVC/+uqrzJs3j3vuuYeVK1cycuRIZs6cSWVlZbvpX3rpJW677TbuueceNm7cyLPPPsurr77Kb37zmyOcc4NYLUsQBEE43Lo1UD/66KNcffXVXHnllQwZMoSnn34ah8PBc8891276b775hsmTJ/PjH/+YwsJCTj31VC699NL9lsIPl+U76wCYKtqnBUEQhMOk2wJ1OBxmxYoVzJgxozkzssyMGTNYsmRJu8ccf/zxrFixIh6Yt2/fzgcffMAZZ5zR4fuEQiE8Hk+rrau8f+MJLLhqIsf1Se2ycwqCIAhCS6bueuPq6mpUVSUzM7PV/szMTDZt2tTuMT/+8Y+prq7mhBNOQNd1otEo11133T6rvufPn899993XpXlvYjUpTBZzewuCIAiHUbd3JjsQixcv5ve//z1//etfWblyJW+++Sbvv/8+DzzwQIfH3H777TQ0NMS33bt3H8EcC4IgCMKh6bYSdVpaGoqiUFFR0Wp/RUUFWVlZ7R5z1113cdlll3HVVVcBMHz4cHw+H9dccw133HEHstz2e4fVasVqtXb9BxAEQRCEI6DbStQWi4WxY8eyaNGi+D5N01i0aBGTJk1q9xi/398mGCuKAoCu64cvs4IgCILQTbqtRA0wb948Lr/8csaNG8eECRN4/PHH8fl8XHnllQDMnj2b3Nxc5s+fD8DZZ5/No48+yujRo5k4cSLbtm3jrrvu4uyzz44HbEEQBEH4IenWQD1r1iyqqqq4++67KS8vZ9SoUXz44YfxDmbFxcWtStB33nknkiRx5513smfPHtLT0zn77LP53e9+110fQRAEQRAOK0k/xuqMPR4PbrebhoYGEhMTuzs7giAIwjHoQGLRUdXrWxAEQRCONSJQC4IgCEIPJgK1IAiCIPRgIlALgiAIQg8mArUgCIIg9GAiUAuCIAhCDyYCtSAIgiD0YCJQC4IgCEIPJgK1IAiCIPRgIlALgiAIQg8mArUgCIIg9GAiUAuCIAhCDyYCtSAIgiD0YCJQC4IgCEIPJgK1IAiCIPRgIlALgiAIQg8mArUgCIIg9GAHHKgLCwu5//77KS4uPhz5EQRBEAShhQMO1DfffDNvvvkmffr04ZRTTuGVV14hFAodjrwJgiAIwjHvoAL1qlWrWLZsGYMHD+YXv/gF2dnZzJ07l5UrVx6OPAqCIAjCMUvSdV0/lBNEIhH++te/cuuttxKJRBg+fDg33ngjV155JZIkdVU+u4zH48HtdtPQ0EBiYmJ3Z0cQBEE4Bh1ILDId7JtEIhHeeustnn/+eRYuXMhxxx3Hz372M0pKSvjNb37DJ598wksvvXSwpxcEQRAEgYMI1CtXruT555/n5ZdfRpZlZs+ezWOPPcagQYPiac477zzGjx/fpRkVBEEQhGPRAQfq8ePHc8opp/DUU09x7rnnYjab26Tp3bs3l1xySZdkUBAEQRCOZQccqLdv305BQcE+0zidTp5//vmDzpQgCIIgCIYD7vVdWVnJ0qVL2+xfunQp3333XZdkShAEQRAEwwEH6htuuIHdu3e32b9nzx5uuOGGLsmUIAiCIAiGAw7UGzZsYMyYMW32jx49mg0bNnRJpgRBEARBMBxwoLZarVRUVLTZX1ZWhsl00KO9BEEQBEFoxwEH6lNPPZXbb7+dhoaG+L76+np+85vfcMopp3Rp5gRBEAThWHfAReA//vGPnHjiiRQUFDB69GgAVq1aRWZmJi+++GKXZ1AQBEEQjmUHHKhzc3NZs2YNCxYsYPXq1djtdq688kouvfTSdsdUC4IgCIJw8A6qUdnpdHLNNdd0dV4EQRAEQdjLAbdRN9mwYQMffvgh7777bqvtQD355JMUFhZis9mYOHEiy5Yt22f6+vp6brjhBrKzs7FarQwYMIAPPvjgYD+GIAiCIPRoBzUz2XnnncfatWuRJImmxbeaVspSVbXT53r11VeZN28eTz/9NBMnTuTxxx9n5syZbN68mYyMjDbpw+Ewp5xyChkZGbz++uvk5uaya9cukpKSDvRjCIIgCMJR4YBL1DfddBO9e/emsrISh8PB+vXr+eKLLxg3bhyLFy8+oHM9+uijXH311Vx55ZUMGTKEp59+GofDwXPPPddu+ueee47a2lrefvttJk+eTGFhIVOnTmXkyJEH+jEEQRAE4ahwwIF6yZIl3H///aSlpSHLMrIsc8IJJzB//nxuvPHGTp8nHA6zYsUKZsyY0ZwZWWbGjBksWbKk3WPeffddJk2axA033EBmZibDhg3j97///T5L8aFQCI/H02oTBEEQhKPFAQdqVVVJSEgAIC0tjdLSUgAKCgrYvHlzp89TXV2NqqpkZma22p+ZmUl5eXm7x2zfvp3XX38dVVX54IMPuOuuu3jkkUf47W9/2+H7zJ8/H7fbHd/y8/M7nUdBEARB6G4H3EY9bNgwVq9eTe/evZk4cSIPPfQQFouFv//97/Tp0+dw5DFO0zQyMjL4+9//jqIojB07lj179vDwww9zzz33tHvM7bffzrx58+I/ezweEawFQRCEo8YBB+o777wTn88HwP33389ZZ53FlClTSE1N5dVXX+30edLS0lAUpc10pBUVFWRlZbV7THZ2NmazGUVR4vsGDx5MeXk54XAYi8XS5hir1YrVau10vgRBEAShJzngqu+ZM2dy/vnnA9CvXz82bdpEdXU1lZWVTJs2rdPnsVgsjB07lkWLFsX3aZrGokWLmDRpUrvHTJ48mW3btqFpWnzfli1byM7ObjdIC4IgCMLR7oACdSQSwWQysW7dulb7U1JS4sOzDsS8efN45pln+Oc//8nGjRu5/vrr8fl8XHnllQDMnj2b22+/PZ7++uuvp7a2lptuuoktW7bw/vvv8/vf/14srykIgiD8YB1Q1bfZbKZXr14HNFZ6X2bNmkVVVRV333035eXljBo1ig8//DDeway4uBhZbv4ukZ+fz0cffcQtt9zCiBEjyM3N5aabbuLWW2/tkvwIgiAIQk8j6U0zlnTSs88+y5tvvsmLL75ISkrK4crXYePxeHC73TQ0NJCYmNjd2REEQRCOQQcSiw64M9lf/vIXtm3bRk5ODgUFBTidzlavr1y58kBPKQiCIAhCBw44UJ977rmHIRuCIAiCILTngKu+j3ai6lsQBOGHJRyIEvBGCPkjhAJRomENNaKhRlTUqM6QE3LiaTcvLaemxIuqamiqjhbVUFs8nvqzoSgmo2/Ut28XsX1VFdGwRjSqIcsSVzw4uUvyfFirvgVBEAShJTWqEQmpRMMq0bBGJKyiRXWQILOwOQiVbasn4I2gRjUj+MXSRyNGB+XxZ/aOp/3ufzup3t2IpuroOsajpqFpgK5z7rwx8bQfPbOO4g21HeZv0PHZyLIxMmnn2mq2fVe5z8/SFKj9njB15f74a03nONIOOFDLsrzPoVhd1SNcEARB6Dq6rqNFdVRViwfKkD9KOBABJHL6J8XTLvvvDhprg6hhlWhEIxoxSqjRsIo9wcJZc5sXQvrP75dTVdzY7nvaE8zMeXhK/OclbxdRtq2h3bRmq9IqUJdtq6d4fcfBV9P0eOC0OkyYzDJWhwmr04zJomAyyyhmGcUko6s6xNIWDk/DlWRFNskoihR7lJEVCcUkoSjNI41GzejFwOOyUMwyJrNxTl3XD2o48qE44ED91ltvtfo5Eonw/fff889//pP77ruvyzImCIJwLPLUBAj5o4T8USLBKJGwSjRklFhtLjMDJzbP3Pj5y5vxe8LNJdMWgdWdbudHN46Kp/333d/iqQq0+57JWQ5+fO9x8Z+LVlZSW+prN60zqfVMj4qpOWjJsoTJqmCyGMHP5jK3Spua40LXQFYkTBYFs0U2gqpFxmxVWqUdNjWPwuFpSLKErEhIUuxRBrPVBLoOGO89Y87QTpd2B07ManUN9yUlxwk495vucDvgQH3OOee02XfhhRcydOhQXn31VX72s591ScYEQRB6Kl3XYwHSCI6RkGoE1LBGNBZQ8wc3D19d8tY2QoGmqmGVSKj5uNQ8F9NnD46nffWBZYSD7ddMZhQmtgoyO9dU460LtZvWZG49n5WitA5ksiIZJVCHmcR0e6vXRpycR9AXwWRWjNKkpblEaba1Dqhn/HyEEaAtSrzKuCNTfzxwn6+31HtEWoev6ZoOqoYWiqBHdWSHKV5iVj0hojVBoxSt6bG0sUdNx9rbjZJozGQZLvUS3FiLHtXiWzytDq5J2VjyjEWoQrs8+L4tI2VW5z9DV+myNurjjjuOa665pqtOJwiC0GU01ajmDfoi8cegL4IzyUr+ICOgqlGNT/+1kXAwFnhjWzSkEo2o5A9O4ZQ5Q+Pn/OdtX9NRV9z8wcmtAvW6L0oJB6LtppX2Kgk6k6yYAlGsdhMWu8koeVqN0qc709Eq7fizeqNFNRSzUSptKp2azApWe+vb+/m/GoskS/Hq3vZKoLqqoYc1hkzOiecrWh9E9YSNABbV0FWdwLpq9NjP9mFpyLHScHBbHeGdHuO1WIBEbw6SidN7oSQaJXL/qkr8q6paBUk9okHsPVJnD8GS4wKg8as9eD7eFQugsfO2kH7tCKy93QAE1lZT/9729n8xQOqVQ7EnGr+bSKkXz8JdHaa1DUqOB2q1IYR/bfXRG6gDgQBPPPEEubm5XXE6QRCEODWioWl6vGpUjWgUb6wlHIgSCamEA1FCgSjh2JbZ282Ik/MAozfwP2//usMSat8xGfFALcsSW5ZVtJsOIOiLxJ9LkoTZqqDpYI5V2xpBUsFslUmL3dybjD4lH13HKJXuVd3rSLQYAVLVIaq1qoKONoTQgy0CvA6Rcp/xBUHXGTK5uTdzqNiDWhNE80TQI0bQa1hXhR7W0CMqSWf3RYqVeD2Lio1gG9HQwmo8TVMAzL7rOBSnUW3d+HkJviVlHV4Xa2EistUokQe31uP9vKTDtM7jcuKBOloTJLip4zZoPdq8pgOajh7uoP+TZHzBaCK7LJjS7SBLxpcNJfYY+1m2NYc9U7oD54Qs47qYZSSTHE+LBObM5mpvc46LpBZt6EfSAQfq5OTkVg3puq7T2NiIw+Hg3//+d5dmThCEo5+m6UYQDUaJxEqr4WAUR6KVtDyjxBTyR1j23g5jiI0vQsBrlHiD3giRkMqQydmcfJlRPRyNanzw1zUdvp8a1eOB2mxVCIeab/AWuwmb04TNacbqNMffH4yS7QkX9zeqd60KZpspFoRNmCwyVkdze6uu6Vz12Inxe2F4dyNqQwgtpKKHVbSQSsNHO9Fj7z3uR33jx9a+toVQUb2RLqwSVnX2NBUQZYm8358QT9vwbhGB9TUdftbc301GinV+8n5TSmBVVYdp3TML44FabQgRKWu/DRowgmIsUCtOM0qy1QhiigQmGUlpfk6L6m5rrwT0iVlGnloGScm4vkqLNmvboBSURIuRJ5OMZJaRTFLsfWRMGc21B85xmdiHphrnlCUkRYqlN96nZUxyjEzHMTK9w8/WkrUgEWtB54bpmtPsmNPs+094GBxwoH7sscdaXRRZlklPT2fixIkkJyd3aeYEQeiZImGVgCeMP7YFGo0tLS+BwljbYmNtkNfmLyfojbRbRdwy+AKs+azjkljLErHZqpBRmIjFpmCxmYzHWDWx1WEiObu5FCTJEj+59zisThNWuwlJktBDKlogihaMogWiBDbUGIFJkhg5rXmt+sYv9xCt8hvp/FF8/giNfuMYyaKQc8fEeNr6D7YT3uFpP/MmiaQWgVrzRVDr229XbmpTbap2lmwmo/01fsuVWjw3Sp1Ngdqc5UTrFzECmFlGMitIFhnJoiCbZWjRRu2clIN9aCqSRYltRno5lr5l2sQZBSTOKGg/v3uxD03DPrTjtuWWLLkuLLmu/ScEZIcZ2WHef8IfqAMO1FdcccVhyIYgCN1FjWrUV/jj7bfhgNHjOBw0HjN7J9J/nLFQjqcmwCsPLCPSQVXykBNy4oHa6jARaGyuLlbMMhabEi+ttuw9bLGbGHNaATanGbvLjM1lxuY0Hq0OE1azjOaPVenqcNFt4+LHhnY2oDaE0QIRIwDvbKB2Yw2aP4psU0i5uLlNseJPKzssScouc6uSWGB9NeGd7QdfPaq1GqZjznKCqiNZFWSrgmQ1xR6NrWVa92mFJEzLN163KG1Kqi0DccpFA9p9//YknpQPJ+XvPyFgyXZCdvf3ZhY654AD9fPPP4/L5eKiiy5qtf+1117D7/dz+eWXd1nmBEE4OKqq0VgdxN/YVNqNGKXfhhB+T5heQ1MZdqLRp8RbF+SVB5Z1eK4hJ+TEA7XNaY4HacUs40iwYE+04Ei04EgwtxqLa7YqzLpzPPYECzanmejuRjR/xKgeDrWuHpYdJiad21zqrHp2LdEKP76QijesQosSuSnVRtavxsd/rn+naJ/BtyUp1mNZMstGadUeC6pmGdnZOq1zXCa2/snINgXZYUZymJDtJqN0t1dHreRz+nV4/fZmzhIBUjgwBxyo58+fz9/+9rc2+zMyMrjmmmtEoBaEw0iNaHjrg3hrQ3jrgjTWhfDWGc97DUlhxMlGicpXF2LBPd92eB6b0wyxQO1wW7E6TdhdFqP0ajdhiT1aHSYyY71pAUwWmZ/cdxyORAtmm0JoWz2aN4Lqi6A1hlF3NVC1tgq1MYwp2UbaFc29pCtf3dxhla8p3d6qelVrjBg9jffW1NGnBXO2MxZ0jWpi2d7i+V7BN+3yoUYJdj/DiACc4zo31lYQDrcDDtTFxcX07t2251tBQQHFxcVdkilBONZEIyqNNUF8DWH8nhD+BqPtN6MgkX5jMwDwVAd48c4lHZ7DnmBpfh4LpI4EC/YEC/YEM/YEC45EMy67mZQUK6Ht9ai+CJJZ4apHTowfW/fONjRPGC0URW8Moe/2UP7JLrRAFFOanYzrm2elqntja4fBV49orX4257iMzkPtVA83jWttknzRANB1IwDvXUW8l5ZV2/vTssevIBwtDvivNiMjgzVr1lBYWNhq/+rVq0lNTe2qfAnCD4au64SDKv6GEN76EDaHmfRexvAdb12Q1x78Dn9DO6VHYNCkrHigdrqNNl3FLONKtuJKtpGQbMWVZCXBaSIl1UZwax2qN4Jslrnm8anx81Q+uYrojjo0fxR0UIGm/sHm/ATsg5rH/AY31nYYfLW9JruwFCSipUWQHSaUBAtyggUl0YKSYEFxt57BKm32kE5fs852MhKEY8EBB+pLL72UG2+8kYSEBE480fgW/vnnn3PTTTdxySWXdHkGBaGnUyPGIgS2WDVrKBBl0Qsb4j2i/Z4waovS5aDjsph+hRG07C4L/lgVr9mq4Eq24nBbcCRYSLCZyMiw419ThdoQQrIo/OyPU7A6jd7LFX9aSXRHfXwIUBSojr2HOc+FfVhz71vVF0HzNY/HlewmFKcZ2WnGnNV6Eo3E6b3QVS3Wa7i5J3BT+2xLqZcO6pJrKAiHi6apRIJBouEwaiRCNBJGjUbRolE0VcWVkkpCqvF/JeT3UbJxHbKsICkKimI8yrKCYjLhSEoiIaVzvdq70gEH6gceeICdO3cyffp0TCbjcE3TmD17Nr///e+7PIOC0FOoqkZDZYDaUh+1pV5qy3zUlvqorwww6LgspsWmgTSZZXasrm5zvMWm4EyyxquodU1Hiqhc/JvxuJKt2Jxmqp9bR7QqgFrlB83oQdU0JYQ5z0XmxOz4+Zo6ZQEgYQTSBKM0a95rBqvUSwchxTpMyQ5TfEhPe5zjRdvssaBlT3Q1GiEaDqNpGnpsU6PRWHALk5ieidVh/E3VV5RTtm0zaiSCFo2iqkbQU6NR1GiEARNPIDXP6CtRuXM76z9fhK43nVc3nuvGDGNDTzqF3IGD42m/++9brd5fU6PxoDrmjHPoN96YDKZs62Y+/Otj6LoWz3PLvB9/0Y8ZecoZsbRbeOXuX3V4HY6/+CdMuuBSADxVlbz90AMdph139vlM/emcQ7zyB+6AA7XFYuHVV1/lt7/9LatWrcJutzN8+HAKCjo3zk4QerpwMEpduR9d08nqY3SkUiMaf7/lc2PpvnZ4aoLx54pJ5uTLBmFzmo3e0IkWrDLoNUEi5T4i5X4qnlxFtMKHOctJxs9HxY9V60LN1c4yKAlWlCQrituCObt1dXDqZUOQTFK8F/LeU1G2ZMlP6PA1oefRdZ1oOEQ4EMDmSkCJFYpqS0uoLt5JOBAgHAwSDYdQoxHUiBEkR592FolpRlPJ1mXfsO6zhUSCQcLBIJFQkEgwSCQYIBIKcuGdvyVv8DAA1i76mEXPPdVhfs677R76jDZ62pdsWMtHT/+pw7QpOfnxQF1XVsrKD97pMG3OwCHxQO2tq2Hjl591mLb/xOPjz6PhELWlHY+7D/qaRwGYzLFaIEnCZLagmE3IignFZDxa7c1fai12O1l9+6NpGpqqoqkquqaiRlU0TcXm7J4mmYPuWdG/f3/69+/flXkRhCOuYqfHKB2XGqXj2jJffJGDnP5JnPd/xpq3ilnG6bYS8EZIyXaSkuMkNccZe+7CmRQrJas6qifUamrHir98j6fE2+77R6sDrUo2Sef1QzLJRnBOsOw7+IpxsD2Wv6Gextoawn4foUCASMBPOBiIBdgAY844B7vL+PK0ZtGHrF+8iHDATyjgJxIIEAr40TWjueTyh/9CWq9CADYv+ZJv/rOgw/ftN+64eKD2VFWxfeXyDtNGQs39ECS5bQ2LrJgwWSyYLBakFoO7E1LT6TVsBIrJjGwyo5hiQc9kQlFMuNMz4mlTc/OYcO5FSJIxNWf8EQlJlsko7NMibb5RWpUkZFluc+7M3s3D99IL+3DxPfORZNlYelmWjerq2HNnUvPkWxmFfbh5wVvIimm/y1O6M7L4ye8f22ea7nDAgfqCCy5gwoQJ3Hrrra32P/TQQyxfvpzXXnutyzInCF1B13U81QGqir1EIyqDjmuuPv7gqTXtduRyJFqw7zUG9+Lbx8fbhwFUb5hImY/Iuirqyv1GabnCh2xVyL7zuHg6JcFCRAJTqh1zlgNTphNzlgNzphNTqq3VzcPWN+kwXAGhIwFvI8FGTzyAhgN+43ns51Ezz8RsMTrFbfjyM3Z8/x3RcNho5wyHiYbDhAJ+Qn4fP/39Y7hSjA61y955jRXvd1ySHDhpSjxQe2trKd2yscO0LQNqUkYWuYOGYrHZMNvsmCwWFLM5VlI040xu7hRYMHwkp153I2arDYvNjtlqxWyzY7baMNtsONxJ8bTDp53K0JNmGEFPktoN3PHzjhhFwYhR+7yuTdJ6FTIl9iVjf9wZWYw7+/xOpbU5XeQPGd6ptJIso+zj8xwNDjhQf/HFF9x7771t9p9++uk88sgjXZEnQTgktaU+Kos9VBd7qdrdSPXuxvgUlE63pVWgzh2QjN8TNkrHOUbpODnLEe8YBkYpOVobwJbeXEVW8+8NBNa1PwezLmto/mh8UYPkc/vFhxkJh06NRgkHA0QCscAaDJDdf1D8C8+mrz9nz+aNBL2NBH1eQl6vkT4UIhIM8LMnnsHqMGojvvj386z77OMO32vQ8SdiTjUCdeWObWz6+vMO0wZ93nigdriTcSWnYHE4sdjtWGz25keHA0uL6taBk04gvVchFrsDi8NuPNrtWO0OzFZbq6A5eMrJDJ5ycqeuU1qvwnhJfH9kRUFWxN9nT3XAgdrr9WKxWNrsN5vNeDwdzHUrCIdJOBilttQXb0sGWLxgE2VFDa3SySaJ1BwX6fkuVFVDiXWmOvVnQ1ul0yMakQof3nXVREq9hEt9xqxXUY2ceyfFx+Eqbis0lZIzHZiznZizjE1JsbWqst57mJJg0HWdkM+H39NAwNOAv9F4DHg8BLyNTP3pnHjw/eTZp9jy7VdEAgGikbY1IDf+83XMNhsAO9d8z/rFn3T4vpFgMB6orbGg2SqY2u2Ybca+lsGr79iJJKSmx6qDrUZJ1mLFardjcThxZzZ3wptwzoVMOOfCTl2H1LxepOb16lRa4dh0wIF6+PDhvPrqq9x9992t9r/yyisMGdL5cZKCcKCMKuwgFTsaKCsytto9XpAkrnp0CpZYEM3ulwQSpOcnkJafQHqvBJKzHfHgDKD5I0SqAlhynEhm42bc8PFOGj/b3Wq6yiaSRSFaE4yP702Y1ovEmYXIlmO7FNKyfR2MnrsNVRWx0m4g3i4b8vsI+bycPvf/4unffeT3bFve8QQux1/0Yyw2Y7WiaChEwNP6y5diNseDazgYiAfqvmMm4EpOxeZyYU9IxBor1TZV+doTm7/UnTT7Kk6afVWnPmv+0BHkDx3RuQsjHJW0WO9xOdb23VMccKC+6667OP/88ykqKmLatGkALFq0iJdeeonXX3+9yzMoCACrPilm5Ue7Wi3y0CQhxUpjbZDU2CLzk87r2+p1PaoRLvHi295AaEcDkVIvmtc4T8YNo+I9ohWXBXSQnSbMOS4sOS7MOS7MOU5MqfbWpWTnD3clH01VW5Ukt69cTtWuHfgb6vF7GuKPAU8DoYCfG//5ejz4fvvmK2xd+k2H555x1c/j1b62WButxW7HnujGkeDGnphoPE90o2vN35gmXXgJY886t1WpVzG1/zvoP/H4Vj2Ehe6haRqqqqKqKiaTKT6cNxwOU1dXF39NVVWi0Wj8eUZGBmlpxlhlr9fL5s2b0XU9vjUFU1VVKSgooFcvozaioaGBr776Kn6+vbeRI0cyduxYAGpra3n++edb5UFVVWPYGDBhwgTOOOOMeB6eeOIJZFnGbDbzf//3f0f6Uh54oD777LN5++23+f3vf8/rr7+O3W5n5MiRfPrpp6SkpOz/BILQjnAgSvUeL9W7vVTvbqRip4eZVw0jJceoopQVmUBjBFmRSMtPILuPm6y+brL7ulutwrQ334oK6t/e1mY6SzCqpLVg8yQgjlHp2IenIbvM++0dejTQNY2gz4vf00DI5yNnQPPkJBu+/IzKHdsI+nyEfD5Cfh8BTwO++joiwSA3vvhG/Bqs/fTjfZZ8wwF/vCo5NTcfb7+BRjusraka2Y7V4cCe4EaSmkspJ19+FdN/dn3z8Jl9cGeIsd1dIRQK4fV6iUajRCIRIpEI4XA4vvXp0ye+XHFJSQkrV66Mp2t5TDQaZdq0aQwaZPxNbd26lTfeeKNVcG7prLPOYtw4Y8Wz3bt38+KLL3aYx5kzZ8YDdV1dHe+9916HaU8++eR4oA4EAixf3nEv9/z81iuLNTY2dpi2ZWlaVVXCYaO5JRqNdnTIYXVQw7POPPNMzjzzTAA8Hg8vv/wyv/zlL1mxYkWbX5AgdKSsqIHVnxRTVeLFUxVo83r5joZ4oO47Jp2MggTS8l2YzK2rmzV/hFBxI+GdHkI7G0iYmod9sNGpR0myokc0ZKcJa6EbSx831l6JmDLsyNbWf/5Hy3q3uq7jb6jHV1/XanjLly+9wJ7NGwk0egh4Ggh6vei68QVFkmVueemdePDdtnzJPku+IZ8Pm8uooeg1fCRWhxNnUpJR2nUn4Uh0x56749XTAJNnXcbkWZd16nO07FB1rFNVFSk2LAnA7/fT2NgYD6R7B9QhQ4bgdhtV+Fu3bmXFihWEw2FCoVCrx0gkwiWXXBIfSrt+/XrefffdDvNx0UUXxQN1Q0MDK1eu7DBtIND8f1bXdYLBYIdpW8YFs9mMw+HAZDKhxGb/atpMJhMuV/NYZbvdzsCBA42e6C02WZZRFIXMzMx4WpfLxdSpU5FlOV6Cb7k1BX+AxMRErr322jbv31TlrbSoUXK5XNx4443GhCrtLax+BBz0OOovvviCZ599ljfeeIOcnBzOP/98nnzyya7Mm/ADEQmplG6tZ/emWvqNyYh3/AoHoxR9XxVP50q2kpbnIjXPRUZBIjn9kuKvOd3W+FzXWjBKYEMN4V0eQjs9RCv8rd4vlFMfD9TWgkQybxmDKd2xzzHJPUUkHIoPBwLY8u1XlBdtxVtXi6+uhsaaajzVVaiRCIrJxE0vvhnvFVxfXsaeTevbnNPqcGJPSCQSCsaDar9xx5GUlYPV4cTmdGJxOLG7EnAmp+BMSsbqbB6jPXrmWYf5Ux+9vF4vDQ0NBIPBdrcpU6aQmJgIwPfff8+yZcvipdKWpVNd15kzZ068dLh69Wo++uijDt83IyMjHqg9Hg+bNm3qMG0k0txcZLFYsFgsmEwmzGZz/Oem584Wv/eMjAymTZsWT2s2m1s9T09vXru7oKCAG264IR7s2guATXr16sWvf/3rTl3ftLQ0Lr300k6ldblcnHxy53rEm0wmsrOz958Qo3SdnJwU+9J7FATq8vJyXnjhBZ599lk8Hg8XX3wxoVCIt99+W3QkE+I0TadqVyO7N9VSsrGWsu0N8Rm9ZEmKB+qMggSOv6Afafku0vJc2F1tRxMAqA0htLCKOTY8SvNHqfvPllZpTGl2LAWJWAsTsbboAS6ZZMyZPWtikF1rV1G1a0cs+Nbiq6+LP4+EgsbkDLLxjX7zt1+zZcmXbU8iSdgT3QR9XuwJRiAYc8Y5DJg0BXtCIvbERByJbmwuV7ttuUNOnHZYP+PRQtM0QqEQVqs1HkxKSkooKSkhEAjg9/sJBAKttssuuyzezLd06VK+/LKd30/MyJEj44Ha7/dTVlbWYdqWpU6r1YrD4WgVTFsGVIejuTaiV69enHnmmVitViwWS/yxKX3L4Dts2DCGDRvWqWuTnp7eKhjvi9Vq7XTa/THaolV0PbrXpqJpUazWNGTZ+DLr9W6mwbOKaKSBSNRDNFJPJOpB00LoWpj+/e/A6TTWCi8re4Odu55G0yLoehR0DS12Xl2PMmL4U6SkGH0b9pS+yqZNd7B3YJZlKyeftKFLPueB6HSgPvvss/niiy8488wzefzxxznttNNQFIWnn376cOZPOMo01gZ59XfLCPlat+W4UqzkD04hf3BzPwa7y8LoU9oOS1F9EUJF9bGtgWh1ANuQ1PjqS0qyFdugFEzpdqyFiVgKEo2OYN1I01S8tTV4KitpqKqgobIcT1UlDZUVeOtqmPPY3+Il3zWLPmo/+MYEPJ74zEp9Ro/DFSvlupJTSEhLJzEtHVdKapsAnDvo2PuyrGkagUCAYDBIKBRqtQ0ePDg+lHTt2rVs3LgxnjYYDBIIBAiFQui6zi9+8Yv46n+bN2/eZ/D1+/3xQJ2QkIDb7cZqtWKz2dpsLatxBw8eTEZGRrxE2lRCbdqs1uaalDFjxjBmzJgO86CqfsLhWjQthNMZYvDgRDQthKZ50bQaUlImx9PW1i0h4N+FpkfQtUibxz59bkaWjeu0Z88r1NUvRdci6Kig6+gtgtWQwQ9jNhtfPEpK/k1V9SexQKcCTQFWA11lxIi/YbUas5Tt2PEXSvb8G12PxgJlJFaNrAMaE8b/F5drgJF255/ZsaPjKUrHj3uLxESj93119SKKtnc8f0dB+HqavqdEo178/u0dptW08F6jGNqWnptmizvSOh2o//e//3HjjTdy/fXXi6lDBdSoRnlRA8UbapBNMhPPNtpKXclWFEXGYlPIHZgcD87uDPs+O2jpuo5vWTmB1VWEdjS0/j8igR5pLm1IkkTaFUPbnuQw0nWdQKOH+vJSGior8FRVMuGcC+PB9/0n/rjP4Outr42vupM3eCiSJBkBODkFV1IyzuRUnMmxSTJatN0OnTqdoVOnH94P14M0BV6fz9dm8/v9zJgxA1tsGNZHH33EkiUdd3LLzc2Nt0tWVVWxYUPHJSGvtxynM4SmRUhLjzB8eBI2uwmb1YTVasflGondbsdut6Pp37BzZw2qFiA5OcjpZwTR1CCqFsSkOBk8eH78vOvW38LmLduQJAVJMsUejc2kOBkxormgs3nzvTR4vm8VzDQtgqaFkSSZKSd8G0+7dt0vqKlZ3OHnmXby1njHvT17XqKy8oMO0xYWXh8P1A2eVVRUdNyGrWnNs6T5/Nuore34b15Vm5ukVC1AOFzVYdpwyW4YNCD2Uwf3CV1C0mVqF7xI4vUPA+B09iMxOACpNoQcNqOETcghBUI6BFVq/v0QSc++hiRJpKefSuilL/EvWQ5RHVTNeIxqSKpORf11JH+9HCUhgazMHxH927c0fvA/416kG7mSrHbouGvHYdPpQP3VV1/x7LPPMnbsWAYPHsxll10mlrU8xmiaTsmmWjYvLWfHqmoisZWb7AlmJpzZOzaXr8R5/zeGhDRbq3HL7Z4vGI1PICJJEv4VFYSLjZ6YpkwHtn5JWPsmYe3tRrYfdHeKTtt7TPCGLz+jaPm31FeUU19RSjjQusPb0KnT4zNRJaalIysKiWkZJKZn4M7IxJ2RFX9uT2iujh8986xjqt23urqampqaeCm2ZYk2GAxyzjnnxKtyP/jgA7777rsOzzVx4jgUxYGqejGZq3G5qlFMEWxWFZPJTig0MF66Ld59Nzt3VhKJNmIy+ThxahBjMdAoFks+Awf8K17yXf7daWwr2hl/nxZTRSMrBYwa9Wn856XLbsDrbT/oWyytl0AMBcs6TGsytV4oxe/fQWPjug4+udzq77MpsEqSGVm2IsuW2KMVRbai6xEkySihJyaOQIsGkTAh6TISCpKuGM91hcjuUky9BwKQmXEm1gYXelhFUo1gpquqEdRUFd/Cr7CedR4AWZnnomwIotY3ILUIeqg6elSl7pvncNx5PwB5eZfBc2sJrduM7g2gB8JIRmEagErpdlK+XQZAQa+rkP6wDP+3y5FUjMXTdZB047MHlP9BLFCnp59K8IN38X6yqN2rFgH0cBjJasVmy8ZRm0pkU3trv8f+38c6iymKHQtuFL8JyWIxNrMZ2W5v59jDT9IPsBubz+fj1Vdf5bnnnmPZsmWoqsqjjz7KnDlzSEjo+Sv0eDwe3G43DQ0N8bYjYf9WfryLNYt242sxL7Y9wUyvIan0GppC37EZ+w3MANGaAMEtdQTWVRPa1UjObybEe1v711Sh1oWwD0/DlGI7bJ8FjE5btSW7qdy1nepdO6kqNrY5jz0db/P9/N/P8d17bzYfJEkkpKThzszEnZ7J5FmXxdexjYSCKGZzvG35h662tpaamhq8Xi9erxefzxd/7vV6+dnPfoY9dlP773/fZdWqJShKBEWJoOsygUDzF5dZs1KxWCNEo15KSrZRVbUbi0XDbFbR1EyCwYtxOp04nU5k5VdEo3Xt5ikhYRgTxjfPr/3NNycTCBa3m9bh6MOk4xbGf/526en4/TuRZTOybIkFQAuybMZmzWH06H/F027f/jjBUDmKYkOWbSiyHVmxochWTKYEsrMviKf1eNYSidS1aHPV4u2tkiSTmdn8ha2h4XvCoVr0QBgCEXR/CIJRpLCKHtRwuPqQcMIJAGhahOqn/45WXYvqbUTz+tAaG1F9XrRGL9Y+fcj/W3Npfeu0aURL228ft/TrS9///jf+c9FZZxHeVtRuWlNONv0/bf7SsuOiiwmuXdtuWsXtZsDS5lqAXZdfgX/p0taJJAnJbkdJSKD/54vjuysfeYTg+g1IViuS1YpstSBZrLGfLWT+qnnZSs/HHxMpLgZZQTIpICvINiuS1YZst+GaOhUpNgQwUlmJHgwiKQrIMsQW8Wh6rrjd8Vqyvb+4d7UDiUUHXExxOp3MmTOHOXPmsHnzZp599lkefPBBbrvtNk455ZR9dv3vyJNPPsnDDz9MeXk5I0eO5M9//jMTJkzY73GvvPIKl156Keeccw5vv/32Ab+v0DFfQwibyxwPviFfFF9DGKvTRP9xmQycmEVmYeJ+e1LrEZXQ9gaCW+oIbq4jWt26VBra3oB9mBHsHCO6rjNKOODHW1tDY20N2f0GxMf5bvjyM5a+9R/qSvfEhy61VLVrJ72GGe1ffcdNxJWcSlJWNklZ2bjTMzG1M30ugNl6eL9YdCVN0+Il2uTk5HgnqqKiIkpKSgiFQvFSb9PzUCjIj398KiZTmGjUw9Kln7Fr10YUUxiTKUwo6KS8vKnqUmfl9+eh641Eo17sDi+TWsw/oqoDkJiH3W7HZrNRWXUN0WjzrGMt+yQlJKQxYfys+M9ff+MkGq1DkswoihOT4kAxOTGZ3LicrZvk+vW/DXSj5KooNqSmUqdkQVFal4wmTvig0zflPn1u7vA1XdPQQiHkWHtzQsIwvJ9+itrgQfU0oHka0TzNzyv7bSLjl78EwO0ezaYxY9H9/nbPHRgzJh6oZdlMwyv/IVpZ2W5a2db671Fq2Z9BkpBMJjCbkUwmZGfrzpbW3r2RFBOSyRQvSUomE5LZjJKW2ipt4sxTsY8YEXvdBCYTkslslD4TWi8JmXXPPejRCLLDiex0IDscxvnbue4ZBzCpSOKpp3Y6rTkjY/+JYnrSXAoHXKJuj6qqvPfeezz33HMHHKhfffVVZs+ezdNPP83EiRN5/PHHee2119i8eTMZ+7ioO3fu5IQTTqBPnz6kpKR0OlCLEnXHIiGV7auq2LK0nN0baznj5yMoHG4EUU91gOoSLwXDUlFM+y45t/wm6vuunLrXtza/KIOlIBH7oBTsw9IwpR54VZIajSBJcnz2rOJ1a9j0zec0VlfhqaqksaaaSKh5TOesex+Mr7u76qP34+vu2hISySgoJK1Xb9J7FZJe0JvU/IJOTcDR00QiETweD16vl/z8fGTZqCpdseIbiorWEAzWEg578Pl16uua28CvuGIQFouCpoVZv3455RXbMJuDWMxBvN4Udu5s6tCkM+XEl4jXVe5F1wbidN6Fy+XC5XJRvPuCVsEXjOpaRXGRlDSOEcOb1z7euvX3aHoYRXFhUpxG4FWcKIoLizWNJPfYeNpotDFe1Xs46eEwqi9WSm1oQLJYsQ00vojoqkr5Aw+g1tWj1tejNnrQPI2ojY1ojY24TjyR/KebP9+mUaPROxhjbB8zhsKXmpet3HriVKKVlUgOB0pCArLDgWy3Izns2AYMIKvF1M3VTz2FFg6juBKQXS6UBBeyy4XsSkBJSsLap3c8reb3g6IYAfUoWnxD13XCWphgNEhYDZNoTcSqGF+CqvxVbK3fSigaIqSFjEe1eZveazq93cY1WFO1hje2vkFYDRPR2s5uOGvgLMZnGettr6pcxdNrno6fLxANGOeMhpBlmYUXLmxz/ME4rCXq9iiKwrnnnsu55557wMc++uijXH311Vx55ZUAPP3007z//vs899xz3Hbbbe0eo6oqP/nJT7jvvvv48ssvqa+vP4TcH9s0TWfPpjo2Ly2naFUV0VBzp63y7Q3xQJ2YZicxreOgqjaE8K+tJrCmCseYDFzHGesx2wYko7gt2AakYBuYjLVfUrxdujN0TaO2dA9l2zZTvm0zZVu3UFW8g4vvmU/eIKNDWW1pCWsXtR1zanU6cSWntuqp2Xv0WM6/7V7SC3rjTE7pUd+a26PrOuFwGJNJQVXrCYdrKSpaRVn5NoKBKsLhWhoarOzZY1xvWY4yffrXqJqXaNSDrkdJa1FCra7Oo77OGGtqsVgo2n43RiMgmMyQl9ecNjUthVGjzsVms2G1WinZsxAJMJkTMZncmM1uTKaEeGk2N3dS/Njk5L8jy5bY68bWNKRmb/37/6bT12Pvdt3O0DUNta6OaFUV0arq2GMV5txc3GcZEzfpqkrRGWfEq5D1cOt2TNdJJ8WDr6QoNLz9TofBV91rxivnxInoqoqSmIicmICS6EZxJyInJGDOyW2Vts977xolzU58WUy7/vpOXwPZ0bWTy/gjfjxhDyE1RDAaJKgGCUVDBNUgwWiQCVkTSLIlAfDVnq/4347/4Ql7aAw34gl78Ef8aLqGpms8PPVhRmeMBuDtbW/z2IrHiGrReMBt6akZT3FC7gnx8979Tes1J1rqldArHqhLfaW8ufXNDtNOyZ0Sf+4Je/h6z9ftpjNJh7+vTLvv2y3vGhMOh1mxYgW33357fJ8sy8yYMWOfvTnvv/9+MjIy+NnPfrbPYRTCvvk9Yf7zu2Wt2p0T0+0MnJDJgIlZJGXs+z+36g0TWFeNf3U14Z0temorcjxQK4lWsm6bcMABcfeGtXz75qtUFG0l5Pe1eb2xurkHae7AwUy68MckpqWTmJ5BQmoarpTUdquj3RlZPWY6Sl1XiUYbiUTq2blrPeVlRQQCFUSi1fh9Tiore+H1etF1P5NPeMMY+xljNhubcZ5e7NmTg9lsJiEhmWBoD03B16AgywkoipMBA8Zz5hm/xG63oygKq9fsBF1Hks2YFCdmSyoWSyoWcyp2ey+SkkbFz9K7d+e7uyYljTuka9MRXVUJbdmC6mlEa/Q0PzY0oDZ4sPbrS3Jsggw9EmHr1JNQGxqgnRkTXVOnxgO1pChEKyrbBF/J4UBxu1GSklrtT7/xRqMqOCkJJcltlH4TE+OPLbVsK94fxe1usy+iRjDJzeug7/HuodxXTjAaRNWNz6W3GEY1MXsidpPxpXp9zXq21W0jrIWN0qQaIayFCakhImqEK4ddSbLN6Dn3XtF7fLDjg+ZSaYvAG1SDvDDzBfolG2OS/7XhXzy5quMJrl48/UVG2UYBsL1+O+8WdVzT2jIYh6IhaoO17aaTJZmI2lwaTrGl0D+5PzbFhlWxYjVZsSk2LIoFq2Ily9n8/3xA8gBuHH0jFsViXMu9epYPT2te23pg8kAemPwANpMtfm67yR5/j8Pddt2ebg3U1dXVqKraaho4gMzMzA5n2mnqfb5q1apOvUfTmMomx/JSnJGQSvXuRmN1KcCRaMHmMhONavQfawTnrD6J+/0j1FWdmn+tJ7i1rlVNqKUgEcdIY77sljo6nxqNULlzO2Vbt1C2dRNDT5xG4SijmlNTVYrXrgLAZLGS2acf2f0Hkt1vAFn9BsSHOgGkF/QmvaB3e2/RrSKRRmpqNlBbuwFP4xbC4WS8jcOoq6ujvr6CQYP/yt5jNW12sAGhUD719U03fDMgAxJmcxK67iISsWI2JWG1ppE9YiQ/+tFl2Gw2JEmioWGK0X5rdmM2uZFlW4e/g5Ej/n4Yr0DHWt7s9GgU7xdfEq2pRq2pIVpdQ7S6GrW6mmhNDc7jjyfrrjuNA1WVHeed3+F5nVNPjAdqyWxGCwbjQVpJScGUno4pLQ1Tejq24a0n/ij45wtINjuKy4mckIDsdHZYTZw658r9fsbGcCO1wVqC0WA8+DVV4QbVIDMLZ2KSjVvwm1vfZGnZUhrCDXhCHhpCDTSEG/CFfUT1KF9d8hVuqxHE/7H2H7y+peMFkD684ENyXUZJ/YPtH/CvDf/qMO05/c6JB+rixmK+2vNVh2n90ea2c5tiwySZsJmMQBYParFg2VQ9DTA2ayw3j7mZBEsCidZEEs2JOC1OFElBQqIgsSCedmbhTMZkjkGRlXjQbTqvSTK1+juemj+VqflTO8xvS33cfegzos/+EwKZzkzO7Xdup9IeKd0aqA9UY2Mjl112Gc8880yreVv3Zf78+dx3332HOWc9W3VJI+u/LGXL0nJ0Ha74w+T4kpCnXzccV7Jtn+3Ouq4TrQpgjpWwJSX2n0UDc54Lx4h07CPSMCXtu0NVyO+jaMUyKrZvo2zbZip3FKG2mN7QmZwSD9TZ/QYw46obyO4/kLT8gh63qL2mRYlEalHVCMGgnerqaqqqKklO/pBgaCd+/w5CofJWx9TU5LFhfdPNTmfQYAWIoihOwEEkbEFRkjCZ0+nXdxjHT7ow3ttZ12/AYklGljuxgIW744kyjhQtGMTzvw+J7NlDpLSUaEVFrNTbgFpfj+vkk8h96KFYYo2Sn/+8w3OZW9THSxYL5l69jNJsQoJRlexKQElyIycmYt1rjofer/0H2eXClJKy3+pk+8iRQGydbDWEL1yPP+onP6F5MYdVlasobiwmEAngj/rxR/3UBeuoD9XTEGrg76f8PR5M7vnmHhbu6rg9c0reFBItxpexNVVr+GBHx2OdA9FAPFBnODIoSCzAbrKjSMb/C4nYPNhImFv8jfRx92FyzmTMihmLbJQ0LYoFs2zGqlhJsDQ3JUzLn0auK9coOSrW5sAbC8JNwR/g8qGXc8WwK/Z5PZsMTR3K0NTOzXuQZEuKV5kfMF2HSAAiflAjoKugRUFTjc2eBK5Yv6eQF3Z+CWEfhL3Gz03Po0EoOB6GGsPQCHrgk3uM8ytmOOPhg8vfIejWQJ2WloaiKFRUVLTaX1FRQVZW2+rJoqIidu7cydlnnx3fp8XaH00mE5s3b6Zv39ZLHN5+++3Mmzcv/rPH42mzisoPUSSksvW7CtZ/WUrlzuZahMQ0Gw1VAdJjSzu60zuu3la9YfzfV+L7roJopZ+sW8fHg7H7jN4knd0XUzvt1rqmUVdeSkXRVuzuJApHGO1PIZ+P//2l9SxCNleCUVLuP5DCkc0BxmJ3MPKU0w/+AnQBXdcJhfxUVb9DMFhMILALj6eIULASHS+SpFNXm8e6dc3zC0896R00rbnkEQ7ZCYWT0fVMbNb+TJ48mZSUFJKTk0lPvxanM62THaM631v1cNGjUfwrVqLW1hCtrUWtqSVaW2M81tRgHz2qediMJFHWoklrb2qLfiWSxYJ93FgUpwslLRVTahqmtFSU1FRMaemYc1rPydzv447nwG5S7iunLliH1+mlMbQLb7GXxnAj3rCXkBrixjE3xtP+YdkfWFK6BF/Uhy/iwx/xx6uUAVZdtgolNuxuwcYFfLjzww7f1xP2xANqsjUZh8mB3WTHZmpROmxRhdrklIJT6O3ujdvqxm1xk2RLwm1x4zQ7sZvtuMzNPaivH3k914/cR/u0roMaBS3CBQWnckHfHxkBBoyA5KuMBa8oNFYbGzqDgcG5JxkBDSBQBzVFRqBSq6F6R/y8khqBnNGQEqvJatgD2xYa59U14zEahGgIogEYcDr0mmikrVgPn/7OGBIlKSCbQG7xOOhsGBDryV27HT79rRF4tWjsMQKRoBFYx10B42PriZevhb81tzW3cfyNcOoDxnNfJby8j3lAdL05UEeD8N1zxnOT7dgL1BaLhbFjx7Jo0aJ4RzRN01i0aBFz585tk37QoEGs3WvM3p133kljYyN/+tOf2g3AVqu11dR8x4LdG2pZ+Pz6+NrNsizRe1Q6Q6fkkDcweZ9DqnRdJ1RUj3dJGcGNtdC0JrBJJlLijQfqlvNnRyMRKoq2smfzBvZsWk/p5o0EfV4A+o0/Lh6oE9LS6T1qLEnZOWT16U/2gEEkZWZ3W4cuVQ0QCOxmT+lqykrXEgzuJhqtIBB0smvnRPx+P5qmcuLUN9D1FsPKJGN6BF2XQDLW2k1NTSUtLY30dDepKb1wOPpiNudhsSTF1+HtqbRwGM3rJVpZaZSAS0oIlxiPtsGDSb/xF/G0xZdf3uF5WpZYZauVhNNOQ0lwYc7JwZSVjZKcZLT3upMwpSS3Orbw3/9uc76oFo1XDQN8vedrdnp2UhusNbZALXWhOuqCdWi6xvvnvx9Pe8839/BNaftt6hISc0fPRY7N3FXhr6Coof1xw3aTnZAawiEbX2gHpgzEE/ZgN9njQdhtdZNiSyHFloJFaf7Sdcdxd3DXpLuaT+argcbSWMnNB0WfGyXAaJDJ0RCTh/wIEmIFlB1fwvIFRpCLBCDsN0qKkdjPZ/8J8mK94b//N/zv1uZApu/VHn/JyzDIWFuZTf+Ft65t97MCcP4zMOLi5jz8Zx8roZ39RHOgrtoE793UcVpXZnOgDnpg8/sdp00ubA7UQQ+se6PjtA17mp9bWgwz2/sLgCSDqUUcsLohZwxYXWBp2pzGZrZDbos+FmYHnBT70ikfg53JAObNm8fll1/OuHHjmDBhAo8//jg+ny/eC3z27Nnk5uYyf/58bDZbmwnlk2KdPDo70fyxwJ1hJ+SPkpBqY9iJuQyalI0jcf+ltki5j5qXN7Vajcqcn4BzXCaOkenx3tq6psUnBdBUlaev+WmbDl8mi5X0wt5kFDbXcEiSxPm3H7lmCE2LEgqV0+jdQU1NFfV12ZSUlFBVVcWw4a8SiZS0Sm+2GJumu/F6m6rqJBz26SSnpOCwF9LQYGHnTg8pKQWkpRUydkwm55/nbrU6UHfTdR21vp5IyR4ie0pigbeEaFU1mteLbehQMn/9q3jazWPGQgfr7Gq+5t+rZDJhHznSqHZOSUFJTcGUkhp/tBQWtDo245E/4Al78IQ8NEYa8Uf8RDUvU/JGx9O8seUNttVvozHcSH2onrpQHfXBeuqCdciyzFeXNLeZvrD+Bb4t+5b2SEhouhYPvmn2NDLsGTgtTlxmFwmWhPhjgiUBVVORY3MEXD38amYNnIXT7MRhduDUZZyail3XUdQIVGyAkAdCjVwVtXHVlIfAFuv0teFd2PBOi+rTB2OPXuSQF372MWTF7k0rnjNKhx3JGtYcqCvWw/JnOk4baNHhSteM9++I1uJ3q1iMoCQrRjCTJIxvnrEvy62CWQIk9QLZbJTIZTMopuafXS36FjnTYeAZRkBsOrfJZpzPbIes5s5apPaDsx6Llbw1I38tq6kLTmhO686DmfON94vnwWyc2+KAlBbtzsmFcHuJEVj3N/GQMxWu+WzfaeLXwQUntT8C6Ujp9kA9a9YsqqqquPvuuykvL2fUqFF8+OGH8Q5mxcXFPeom2NPoms62lZVUFTdy/PlGj8zENDvn3jKajN6J+50tTI9qSLH2aSXJilofQrLIOMZm4pqYjTnLia7r1OzexY7VK9m56jvUaJRL7jPaF2VFITW/gPryUnIHDiF30BByBw0lvaA3yhEuSe7e/QJe31YCgWK83p2Ew+VIktE04vUm8/3K5lmgdM34j2xMhpGF12vDbM7B6ehFZkY/xo+bjN1ux+FwxBd2AMjPh57wnVDz+YxS754SIrt3o6Sk4G5qEopE2Hr85Ph0iG20qMGQJAnF6URtaEBJSsKcl4c5Lw9LXi7m3Fys/Yy/qY01G6kKVOGdPxtvJFaNHPHSGK7HJHu5bcKP4+f8+Sc/Z1n5sjZDawBcZhdLftw8ouPjXR93WPIFiKoRTNEQBOoY58glseDUeOk1pa6YlPoSkiMhElQNXv6xccNXI/xOi8JF/zFuyABf/wlWv9ocEL5+MV79O1gNGzftpNgCMR/fBd880fHFzxndHKirNsG6jjt2tQqg9mQjuJkdzSU4s705oLVsm80bByf+Gsw2MMfSmR2xRztkj2pOO+QcKDwhVoI0ty5JKmYjODcZdr6xdUbfk+Hm9mcdayN7BFz6cufSutJh3JzOpXWmwaSO+y+0IivGl4sfoG4P1ABz585tt6obYPHixfs89oUXXuj6DB0FdF1n17oalr67nerdxs2g/7hM0nsZf6jZLdZybk9oRwPer/YQbQiRccMoYzF2m4nU2UOw5LqIaCF2rl3Njne+Y8fqlXhrqpsPliT8ngYcicbN6rxf343V6TysVdihUBVe7ya8vk00Nm7C692Oqpowm35FbW0ttbW15Ob9i2h0V8tsomkywaCLSCSZgQMHkpubS3Z2Nikpl5KYmIXZ3HY4TE+g6zp6IBAf/6prGqW/vpVwcTGRkhLU2tZDWOzjxsYDtWSxYMrKgmjUCLy5uZjzcjFnZRljd2Pr8EbUCDXBGiL/+TPVupeKUBXlvnLKfGVI1PL7Kb+Mn/+eb+5hY+3GdvOaYE7gtgnNJQ5VV+NBWkLCZXaRaHbgUKwkyFb0zR8hhRsh2MApEYlBQ6/EZUkg2ZZMctEXJO/5nuSQj2R/A8rvso02SeBagFt3NbehvnczrN7HBEvRFs0VjRVQ2Xat7rhwi9nAzPZYVandCJQWF1gTjZKVNaF14Os7LVZl6opVoyY0V6daXZDYYpz0+Kua21P3J2+csXWGzd38xUH4QeoRgVroPE3T2f59Fd9/vIvKXcbEChabwqhTeuHO2P8sX6FdHjwLdxHaVh/fFyn3Y8k22ndsfZMA+PCPD7JteXM1o8lsIW/ocHqPGkvhyLHx+bABbC2W8jtUrYbt6DrrN/yK2toviERq2qSNRk0s+eZ9mibUz8qeSO/CH2G35wPprFlTRk7OYPLze+F2u3vk5CbhnTtjJWNjC+8uJrKrmHBxMbbBgyl40RhaI8ky/u++I1re3JNcdruxxErAtqHNvWqjWhTXW/+iMlJDpb+SCl8FFf4Kotoubp1wazzdZf+7jPU17Qcvu2zmd84h8YA6JOCHlMG4LC4SzAm46neT4KvFpeskRnR4diZEfBD2c7cagDkfkmBPxmV2Ib9xdetS56rmBRQuBLh1p1HaBNj8JZSsaZshxQL2FAg1Ngfq/qeAI9U41mRtLkHKJmOzt2gHH3elkb5Vu6UxLzSK2ag2bTL1VqNNsjN/LwcSUAXhIIlAfRSpLfPxwVNraKg0SgqKWWbESXmMmVmAzbXvoSfhPV48C3cR3BQriSkSzrGZ2I/LpKRsA5te/5zjL/4pSZlGG9nA40+kpmS3EZhHjSVvyDDMlq7vlBcO19DQ8D2VVUupr1tBKFyOz3sblZVVVFZWMvG4neh6DSBhtfaipAR8viTCoWTMllwGDhxISkoqKSkp9OrVq9WY/Ozsjt/3SNCjUSLlFURKdhPevZvI7hIkq4X0G26Ip9l1+RVE9xr10CS8e3f8uaqpJNx8A16CeFJtVCcrVCsBwmq41TCZ6xZex5KyJWjtzGNul0zcWlEG/mrw15JGBSbFRIo9xWjTrdlFlqec7GiUrKiKVnQDTS199wLcXWf01AV47Qooan/FolwAixtiQ4+wOIzAaHMbJVNbYuwx9nPLKvqxV0D/U41qYHuS8WhzG6XWvQPnoDONrTPS+htbZxwjC6sIRw8RqHu4liXMxFQb4UAUq8PE8JPyGHFyHvaE/XcSC+1ooOpvsVKKDI4xmfgLg6xY9TGb7/6aYKMxfCs1rxcTzzN6fA6cNIVBx5/Y5Z8nEAhQWbUQb+PnNHhWEgi0Xd1o3frPCQWNKnxPwxSmTbsbp7M/kmRl69atZGZmkpiY2K19F7RAgGhNDdGqKvRwBOfE5kVk9vzyVwTWrCFSWtqmk5Y5J4f0G24gGA1S7isn0Csd1QbeVDu1SSaqkmW8mS6uP/P++Pjhaz6+hiVlLWbqazGFtg2Zy1e+jeStgMZyLElWNJsZk2Qi3ZFOpq+ODG8NmapKRlRF3f58PPg+JEnY7qhAbupA9PYNUL3ICJ4JbshObB1YdQ1j4hVgzGzoc5JR0m3azA4jKDe1wTY563H40Z87d2FzRhubIAhxIlD3UOFAlO8+2MmeLXVceOs4JFnCZFE484aRJGc54hOWdESPaEhm46ZqKUjEnO1ETrOy27yNVV8voO615h7PDncSA4+fQu/RzVV4h1JNrOsagcBuGr0bqa76ntraNdTXn8Pu3bVUVlZy3HElmC3NPS79fjeNnjRUrRCbdQgTxg8lPT2TzMxMUlNTWw1vGjhw4EHnq7O0UAi1vh5zi9J5xcMPE1y/gUhZKWpVtbHIQYwpO5v+n32Krus0RhppLN6OXmx8AdFMCoH0BHwZLgYOPRFLgdFhac5Hc1hbvRZmtH1/u2Ti5s1Pw/JS8JRiVmrj/1OdZidpkTCpwUZSVY0UVSVa8xlN9Sm/CSvcfct6UpyZRg/oT38LJd+BI8WoOnamGdXFjhQcjjSj+rfJuR1PCdlG32mdTytKqIJwSESg7oEqd3n46B/r8VQZVdzFG2opGGb0Xs0s3PcqK6ovQuOiYgIba8i8ZSyyRUGSJTJ+PopINMjL195DJBTEZLUy8LgTGHTCSfQaOuKQZ/7yeNZQUfk+jZ51eBrXoaqth4tsK0qkod6oi25sLGTs2Btxu0eTmDiShoYISUlHfrxxtK6OcFERoW1FhIqKCBdtI7StiGhlZZt1dwPfryKwcmWr4zWLCWtaBqbYhBxzPprDdxXfMXi4DsMVKpKgLgF0yYtZCrCi0IHk3wSvXUGWfwfbTHZynDlkObPIKltHVu0uUlQNl6ahb/97fDbiB2QZ6Zb1OB1pxjjdL/4IZasgIdsYztP06Moiy5EKzozmauJpdx7+CykIwmHVJctcHk168jKXuq6zdnEJX7+xDS2qk5Bi48RLBlAwPHX/829HNLzflOL5rBg9aEx4UF1Yw46G1Zz767vjxy9753VsLhcDJ52I9SBW1IlGvdTXL6e+fhlpaedSV2dh165dRKOfIsnNy/VpmoLP58bvS8FkKsTtPolevUaRn5+Pqws7n3WGrqqEt28nvHs3CdOaS4I7Zs0iuLqdjkuA7HIxYOm3vFn0NisrV+L4Zi2+hmq22xqpderUuyBqNfHd6DuQ63dC7U5+6VnFR7oHl9lFmj2NFE8Fqb4aUlWVVFXlZ/WeeMk3DJh/U4Zkif0OPvg1bP/MCLiJuUbwTcxp3jKHG2NYBUH4QTiQWCQCdQ8R9EX47MVNbF9lrArVe2Qa02YPxubcdycxXdMJrKmi4cOdqPXGkBi/4mXZng+oCOwA4Ce/e5SsfgMOKl+aFqbBs5q62q+prfsGT8NqdIx2121bJ1FWZoyzdbt9nHa6DXfiCBISh1O6R8Nmc5KTY6zqdKToqkp4xw6C69cTWLee4Pr1BDduRA8EwGxm4Irv+LpyKZvrNpP353dJWV9CVaaNkjSJHSkRdiaFefHMhzGZQkj+GubteJ2Fvp2t3sOm6eRFI+RFosyvqsEV+y9UJ8vY/m8LdmdsXcn/3gJbFxrVzc50cKQZY0hdWUZAHniGMfxHEIRjzhFfj1o4dIv+uZGda6qRFYnjL+jHiJPz9luK1sIqVc+sJbLbGKYV1P2srv6MXd716OjkDxnO8Bmnkdar8KDy1NCwiu9XXYaq+lvtDwRc1Ndn4fMlkJCQQEFBAb169aJf39HxoHwEmpKNxULKyjBlZxPVo+xp3EPt7Xdj/3R5m7SS3YatXyHq8jd4t+oNPmzYjHS8jj5ZAlovJF/79iwyYysune6wM+SUu8hx9yY3IZfcr54kdfWrRrW0Kwvyj4Pk3pDSm+TkQmNyiiZnPXbYPrsgtEdVVSKRyP4TCoed2WxG6aLFhESg7iEmndeXxpog02YPIqOgcyV92aJgclsIl8Hayi/Y4lmOZFEYccppjJp5Fmn5Bfs/CaCqfurqvqW6ZjFOZz/y82YTjUbZvTuKqoYwm1NITp5EbW0m33xTS1bmMIYPH86ZZ/QlKSnpiI1PjtbUULfqOypWfkNg7VrcRZWoNTX0fe05bi1+ik+qv+dsXeMiM+zMhKIsie1ZEtuzJV7w7iJL3w4LP2V8ggvruJ+S4sok1ZZKysYPSN222KiilsykJOTGS8CnONNg0I+bx+RO+RUcf7Mx7tZy4E0HgnA46LpOeXk59S0WOxG6X1JSEllZWYd8jxRV390kElIpXl9D3zHNqyLpmr7PBTMAAuurCdj9eLw1FI4YjdoQQkPj7Sd+S58xExh60nRszv23Afv9u6ip+YzqmsXU1y9F08IAmEz9qKq8mq1btxIKhTj77AmMGXMakiTj9/sJh8Px+dUPJ13XKaovYlXVKkLvf0y//ywjsa7tlJRIOvlTavnHUBsvpWbS315AbnIB2VWbySn5nuxolOyoSmFUxezMgMRsoyT8oyeal7yr3W6sxpOYbYzb7YETowjCvpSVlVFfX09GRgYOh6NHTu5zLNF1Hb/fT2VlJUlJSWS3M6mDqPru4aJhlff/uobSLXWcO280Of2N0tq+grTqDVP9+kYimzzs9m1idfgLfvanZzC7bSjARXf9rlPvres6K1bOoqFhRes8Rd1UVWZSU5tLXe06gNhY5Wyk2EIHDocDx0F0QOtIY7iR4sZidlesp3r116hrNjGlRELbVkHWDDdv51bzT7vEhCqNMXUaGlCWAqWZ0Jihcpqtgd4JQWSrheulFG484z/ITav57FkJjeXNvaKd6R13xmo5sb8gHGVUVY0H6dTU1O7OjhBjtxszRVZWVpKRkXFI1eAiUB9h0YjKB0+vZc/mOsxWJb6Cz740LNtN/TtFKKqCpmt4IrVkFPYl5PdhtnXcGUnTwtTVL6O+fhl9et+CJEnouo5JyUCSFNzucSQmTOatt7bi97sBifT0dE44YWB8XuxDnVRE13V0dOSwD2q28b+tb/Oyr4iGkp2M+q6OgSU6A/foFMQKy01l5uCmSkYkqEzOn8GggkHsHG8nOwUmNJaQmNoP3PnGyjruPHCkYd07n7ljEIRjQVObdFd+iRa6RtPvJBKJiEB9tFAjGh/+fR27N9RissicNXckWX06nkw/VNNI8bPfYq+1oaBQH65kh2Mjo288l7wh7S/hpOsqdXXfUlb+FtXVnxCNGh3N/L6hbN8eZMuWLWRn92fWrN/FF6QYNuwDUlJSGDBgACkpKQf12UJqiN2e3ezy7GJX6VJ2lH/Pdn8pRZFG/l4Xof/2KiRFpzHfxvdpKRTU61zyRfM0lxEzeHNMZPbLImv4UGyjxnJq7kBOzRpuLJIgCMI+ierunqerficiUB8hqqrx0T/WsWttDSazzJk3jCSnf1KH6UPFHqqeXYM9ZEPTVXZqG8i9dAxnjTu/3V++37+LPaUvUVH+HqFw89zRquqkujqX75Z/RCBgtIOUlupA87fvM844o9OfQ9M1NtduJj8hH5fFBf5a3l7xJHdvfw2d5u4O6fU6I3boTN+pI+/Q2BlKx91P4/gRvfjDsPMpPP0EHJUvkDB0MI4xo7EOHYl0hCc8EQRBOBqIO+MRoKkaC59dz47V1SgmmTOuH0HewOR206rRKIrJhDndgWK34KeB8FiFE866FnmvqRhbzgPu92+nuPgfAJhMburr+1G0LQ2PJw2QSUpKYsQIo0q7oKDggKphKnwVLClbwjd7vmFp6TfUhht42DmM0yp2QNVGMuw29KwMEhQn1y0yMXCrj8TqYIszyMguJ9KYM8mbcx95Tbv/+Ein8yAIgnCgCgsLufnmm7n55pu79Lw7d+6kd+/efP/994waNapLz90eEaiPAEmSsDrNyCaJ068bTv6QttXLuq6z6X+f8uX7/2bWPQ/izsgk/arhKElWJFPr9teGhpXs2vV3nM7+9Okzjz179rB6dSN5eWeTk3MGqalTWb16A+Vlyxg3bjADBw4kIyPjgKphyn3l/HP9P1lSuoSihqJWrzk0jdodX+DbESbitTNmfC6LR9xEyqjL2PGfcwlV14DJhH3kSJzHT8J5/PHYhw8XJWZBEISDIIZnHSG6plNT6iUtL6HNaw1Vlax/8j1yA31ZWbOQxOPzmT7nutbH6xrV1YvYVfxMix7bqWzccBnV1cZazTNnzmTSpEmx9HqnA3NYDbO6ajUmZEbrZti+mIrti5ihbQdAQmJYUj8mb/2O44sgbU8qvp0R9LCKZLEwYNlS5FintsZPPgFZwTFhAorLua+3FQShCwSDQXbs2EHv3r2x7aNzaU+kaRp//OMf+fvf/87u3bvJzMzk2muv5Y477mDt2rXcdNNNLFmyBIfDwQUXXMCjjz4an4L4iiuuoL6+nhNOOIFHHnmEcDjMJZdcwuOPP47ZbOakk07i888/b/V+TeHuq6++4vbbb+e7774jLS2N8847j/nz5+N0GveswsJCrrnmGrZt28Zrr71GcnIyd955J9dccw3Qtu156tSpLF68uM3n29fvRgzP6iE2fVtG//GZKIqMJEttgrSuaaz94GMii2roZR0AEgwdOJW+s5vno1bVEOUVb1Nc/A/8fiNw6rpCRUVv9pQMxu+vwWQyMXjwYPLy4pXK+wzSuq6zqXYT35R+w9LixXxfs46gHmVyKMrTpaUAZALX9BvPwBN+zagyK5E3/4v3k+1ogRBejGptJSUF56RJqB5PPFAnzGhnOShBEI4YXdcJRNRueW+7WTmgmrvbb7+dZ555hscee4wTTjiBsrIyNm3ahM/nixc8li9fTmVlJVdddRVz587lhRdeiB//2WefkZ2dzWeffca2bduYNWsWo0aN4uqrr+bNN99k5MiRXHPNNVx99dXxY4qKijjttNP47W9/y3PPPUdVVRVz585l7ty5PP/88/F0jzzyCA888AC/+c1veP3117n++uuZOnUqAwcOZNmyZUyYMIFPPvmEoUOHYrHsf7nhQyFK1IdJdYmXV3+7jL6j05l5zbA2f7x+TwPfPPI8hf7B2BQHKlFsJ2eScergVmk3b7mXkpIXAVCUBHbtKmBPyUDCYQf5+fmMHj2aIUOGdOqbtK5pPLZsPh+VfEGpr7TVa6lRlZMCAe71hNFyJ0HvKcgDZ0DmUGqefZbKh/8IgCknm8TTTifx9NOwDR2K1I1rQguC0LbU5g9HGXL3R92Slw33z8Rh6Vz5r7GxkfT0dP7yl79w1VVXtXrtmWee4dZbb2X37t3xUu4HH3zA2WefTWlpKZmZmVxxxRUsXryYoqKieJ+biy++GFmWeeWVV4D226ivuuoqFEXhb3/7W3zfV199xdSpU/H5fNhsNgoLC5kyZQovvmjce3VdJysri/vuu4/rrruu023UokTdw32/cBdgTGLS3jfMLS98yqDQWFAg4oqSc9U4rFkJqGoITQugKIns2LGDkpK+WK3Z9Mq/kpyci/E2fk56msy4cePIyMhoc96WIuEAG7a9x8iGKiheglT8LRtSEyhVothNdiZmT+S43WuYqJopzDoRX1UCJdt24XvjKzLv+AlJJw4FIPG004hUVJB4+unYR40Sw0AEQThkGzduJBQKMX369HZfGzlyZDxIA0yePBlN09i8eTOZsbXihw4d2qpjbHZ2NmvXrt3n+65evZo1a9awYEHzan+6rqNpGjt27GDw4MEAjBgxIv66JElkZWVRWVl5cB/2EIlAfRh4agJsXW78Qkef2qvN65FyH2llaQAowxPInTUCXdYoLX2dou2PEY32Y83qMdTV1QFw/fWvkZlpTEF31lln7ff9ty19kgWbX+EjtZZGWebT4hLSVWPM8lVSmEvP/xvH9zoJU2UdjSWLaPzyU7Yufw2i0fg5/EuXknT+eQCYc3PJ+s1vDuGKCIJwpNjNChvun9lt793ptPZDnx9h75X5JElC07QOUhu8Xi/XXnstN954Y5vXevVqvl8fzLkPFxGoD4PVi3ajazp5g5JbLbBRsmEdOYMGY85yknROX9TGCAnT86ms/pjNmx8kEtkNQDDYSENDHlarixEjRmC17ucPumEPWkIWX5V+zYsbXuTbsm+N/bJMqqqxs/fxpBdMh4LjOS57FJhtqPX1bJlxCrT4w7P274dr2nQSpk/DNqz9CVUEQejZJEnqdPVzd+rfvz92u51Fixa1qfoePHgwL7zwAj6fL16q/vrrr5FlmYEHsDSfxWJBVVu3148ZM4YNGzbQr1+/g857U5v03uc+XHr+b/MoE/RG2PCV0f475lRj9Spd11n+zht8++rLDD/tNE6+/Gpcx+VQW/sNK1bcjKdxDQCRiIXdxcORpJM466zjGDZsWMedFBpKYNXLsOk9NtZs4Ff9x7DLXwaAjMR0Rz6XDp3N6D4/IrR6LeWLPkF9701yHzoOACUpCccYY5pN1/TpJEw7GUtB51bbEgRBOFQ2m41bb72VX//611gsFiZPnkxVVRXr16/nJz/5Cffccw+XX3459957L1VVVfziF7/gsssui1d7d0ZhYSFffPEFl1xyCVarlbS0NG699VaOO+445s6dy1VXXYXT6WTDhg0sXLiQv/zlL506b0ZGBna7nQ8//JC8vDxsNhtud8ezTB4qEai72NrPS4iGNdLyXeQNTkZTVRY9+xS21TLTs39CdbSOhoYGdu9+lYrKPwAgyw7KyoaSmHABZ511QrsrrcRVrIevn4B1r4NmVFXnKAqVwWoSzAlcMOACLhkwC/fqnXj++V+2L34MtaGB2BuRefvtmJKNyVZ6vfC8GNssCEK3ueuuuzCZTNx9992UlpaSnZ3Nddddh8Ph4KOPPuKmm25i/PjxrYZnHYj777+fa6+9lr59+xIKhdB1nREjRvD5559zxx13MGXKFHRdp2/fvsyaNavT5zWZTDzxxBPcf//93H333UyZMqXd4VldRfT67mLvPP49JZvqOPVnQykYlsD7jz1EVlke+c6BePCzZZiXtTs2kJRkZfSYd0hPO4XC3nMxm1L2vQBGwx74781oWz/m9QQX39ms/ME5GGnELBhwOsu9OxmaOpTop19R9ac/Ed6+PX6okpSE6+STSZgxHeeUKciHeSiBIAhHztE8jvqHTvT67qF+dNMoSjbWkdnHyZv330Vf71Ccriy+ci4lkPsNu7YNByRcrnSGDnmD5OSszp3Ynsy28pXcl53JKpsVgLOm38qJeScCMN6VDkBdQz3h7duRnU7c555L4mkzsY8eLUrOgiAIRylx9+5ikiSRPySFT5/7G9mBQWxx+/DlvUBB75Wkm6K4XIWMH38jhYWFHZ9E12HzB/D9v2HWAkJ6hL+vf5bn0hOI6ioOk4MbR/+CMeV2Sv54C87Jx5N80UUAuM8+Gz0cwX3uOSixGXwEQRCEo5cI1F2krtyHM8mKxWZc0l4MZHvaahxDXibLXQWAzTacM864AaezcB8n2gn/uxW2fAjAsu+e5P49H7HLY4zLPjl3Kr8MTEW973V2r/4dAKGtW0m68EIkSUK220n56U8O2+cUBEEQjiwRqLuArut8/Ox6GmuCnHbtcHJ6J2KpCWIe+yyJFh+y7KB/v9vIzb0USeqgHToagm+egC/+CNEgyGaik27ggZIP2dVYTLYpjXs9J5H5x2/x7VwEgGSxkPijs0m5bLaYhEQQBOEHSgTqLlCysY7q3V4Us05EryUYtVI7/XW0eh8u5yBGjnwGmy2n4xMUfQYf/BJqthk/9z4RzngEU/oA7i5fzoc7PuSy/1QT+N8rhAE5MZHkH19Kyk9/iikt7Yh8RkEQBKF7iEDdBVZ+bFRL25NW8uKCz8jKkeg36EskyczQoY/uO0hrGnx8F9RsQ3Vl8uyI00gumMK50QSk2lrGZ41nfNZ4fNJSSletJfWKy3FfcKFYmUoQBOEYIQL1Iarc5aFkUx0RfRu7NQ+a2YTX62TY0JdR1R24XO3MoqPrxibLxnbmI1SsXsBvTA1UrPqUc/7+Kds2QsoVl5P5q18B4Jg4gX4ff4S017R2giAIwg+bCNSH6PuPi1GpozF1F6rZTKJm56dTLiQjozcwpu0B/lp47ybIGQ1T5gGwGD8vrVnKKV82MnJn87D28K5d8XWlJUkCEaQFQRCOOT1ijcInn3ySwsJCbDYbEydOZNmyZR2mfeaZZ5gyZQrJyckkJyczY8aMfaY/nBqq/GxZuZv65JWoFjO5KeXMzMwhfWwHU3Fu+wT+Ogk2vgtfPEzIU8o//3wtgZ/+nFte9BhBWpZJPOMMCl97jfy//EV0EhMEQTjGdXugfvXVV5k3bx733HMPK1euZOTIkcycObPD5cQWL17MpZdeymeffcaSJUvIz8/n1FNPZc+ePUc457B9bTn1SUvRrGbcljB9B31JxeDf0uBb2TphJAAf/Br+fQF4yyFtAMHZb3PZ5zdTvfRLCishajXh/umP6fvxx+Q++gj24WJRDEEQhANRWFjI448/3t3Z6HLdHqgfffRRrr76aq688kqGDBnC008/jcPh4Lnnnms3/YIFC/j5z3/OqFGjGDRoEP/4xz/QNI1FixYd4ZyDxVWJrkSx6ibG9VuNbgqSkDgct3t0c6LSVfC3qbDsb+g6eGxnEzz5WWz5E5neazpfTU7GN+cchnz+JTl33oUlL/eIfw5BEISe5IorruDcc8/t7mz0GN3aRh0Oh1mxYgW33357fJ8sy8yYMYMlS5Z06hx+v59IJEJKSsrhymaH+g4expnvlhFN/w5v2iZk2cqQwQ8hSbE1WQN18MKZEPbia8iiclshwa0rcO34K/l/e5prRlzDxQMvJtmWfMTzLgiCIBwdurVEXV1djaqqbZYty8zMpLy8vFPnuPXWW8nJyWHGjBntvh4KhfB4PK22rqKXhEgxgX/A2wD07fN/OJ19mhPYkwkUzGHXsoEU/08muLWYsEVGGdQfXdOQJEkEaUEQjlmvv/46w4cPx263k5qayowZM/jVr37FP//5T9555514R9rFixczbdo05s6d2+r4qqoqLBZLhzWq9fX1XHXVVaSnp5OYmMi0adNYvXr1kfhoXeqo7vX94IMP8sorr7B48eIOV42ZP38+991332F5f9ugFGpOeRUtFMTtHkt+/hXGuOhALbo9hfJ77qH+tdcB0EwyH46CN4+XuHKKm6v2tVKWIAjCoQr7On5NUsBs62RaGcz2/ae1HNjcDmVlZVx66aU89NBDnHfeeTQ2NvLll18ye/ZsiouL8Xg8PP/88wCkpKRw1VVXMXfuXB555BGsVmNhon//+9/k5uYybdq0dt/joosuwm6387///Q+3283f/vY3pk+fzpYtW7qlFvZgdWugTktLQ1EUKioqWu2vqKggK2vfq0r98Y9/5MEHH+STTz5hxIgRHaa7/fbbmTdvXvxnj8dDfn7+oWU8pqrqIxpCy5FlG0MG/wFJ0+Ht62DPCurdPzeCtCRRckI/5g/bTlWSxCUDL+HKoVd2yfsLgiB06Pf7mGip/6nwk9eaf364H0T87actOAGufL/558eHg7+mbbp7Gw4oe2VlZUSjUc4//3wKCoyRMsOHDwfAbrcTCoVaxYHzzz+fuXPn8s4773DxxRcD8MILL3DFFVe0Ozrmq6++YtmyZVRWVsYD+x//+EfefvttXn/9da655poDym936tZAbbFYGDt2LIsWLYp3HGjqGLZ3FUdLDz30EL/73e/46KOPGDdu3D7fw2q1xn9JXS09/VQG9L8LSbbgsOTAa5fDpv+CbMJ9Uga+c37Eh8nF/Cl7HSBx85ibmTNsjhhyJQjCMW/kyJFMnz6d4cOHM3PmTE499VQuvPBCkpPbbw602WxcdtllPPfcc1x88cWsXLmSdevW8e6777abfvXq1Xi9XlJTU1vtDwQCFBUVdfnnOZy6vep73rx5XH755YwbN44JEybw+OOP4/P5uPJKo9Q5e/ZscnNzmT9/PgB/+MMfuPvuu3nppZcoLCyMt2W7XC5cR3hZR0mSjerusB9evgSKPgXFChf/E7X/DH47432+Ll2HSTJx/+T7Obvv2Uc0f4IgHMN+U9rxa00dXpv8ats+0u7VTHfz2oPPUwuKorBw4UK++eYbPv74Y/785z9zxx13sHTp0g6Pueqqqxg1ahQlJSU8//zzTJs2LV4a35vX6yU7O5vFixe3eS0pKalLPsOR0u2BetasWVRVVXH33XdTXl7OqFGj+PDDD+MdzIqLi5FbtOc+9dRThMNhLrzwwlbnueeee7j33nuPZNYNwQZ4aRYUL0HDQX3itST3n8nuxp2sr9mA3WTn8ZMe5/jc44983gRBOHYdSJvx4Uq7H5IkMXnyZCZPnszdd99NQUEBb731FhaLBVVV26QfPnw448aN45lnnuGll17iL3/5S4fnHjNmDOXl5ZhMJgoLC7ssz92h2wM1wNy5czus6t7729DOnTsPf4Y6y18LL54HZavQLW7Kdp2M55VXCVZE6PP73/HSmS9R0ljCpJxJ3Z1TQRCEHmXp0qUsWrSIU089lYyMDJYuXUpVVRWDBw8mGAzy0UcfsXnzZlJTU3G73ZhjUyg3dSpzOp2cd955HZ5/xowZTJo0iXPPPZeHHnqIAQMGUFpayvvvv895552332bTnkR0PT4UagRCHnCkUuu8Fs/ny8BkIumC8wHIT8gXQVoQBKEdiYmJfPHFF5xxxhkMGDCAO++8k0ceeYTTTz+dq6++moEDBzJu3DjS09P5+uuv48ddeumlmEwmLr300g5H+4BRWv/ggw848cQTufLKKxkwYACXXHIJu3btajMkuKeTdF3X95/sh8Pj8eB2u2loaCAxMfHQT1i/G9+331I8717QNF47K4mTbv4DJ+adeOjnFgRB2I9gMMiOHTvo3bv3PgPXD8XOnTvp27cvy5cvZ8yYdhY+6kH29bs5kFgkStSHKOJX2HPfY6BpLB/t4rVhjTy/7nmOse8/giAIh1UkEqG8vJw777yT4447rscH6a4kAvUh0EIhSm68CbWujoo8J49PD5CbkMcjJz0ihmAJgiB0oa+//prs7GyWL1/O008/3d3ZOaJ6RGeyo1Vw7VpCW7YQclm4/+wgFoeLP0/7Mym2o2fGG0EQhKPBSSeddMzWVIoS9SFwjBvHht/9lPk/ilKTrPDQiQ/RP7l/d2dLEARB+AERJepDsKpyFffV/RutQOZXY/9PdCATBEEQupwI1IdgaNpQLux/IaquctmQy7o7O4IgHMOO1WrhnqyrficiUB8Cs2zmzuPuRNM10XlMEIRu0TQRiN/vx2637ye1cCT5/cZCJ02/o4MlAvUhkiQJZe95cwVBEI4QRVFISkqisrISAIfDIQoO3UzXdfx+P5WVlSQlJaEohxYjRKAWBEE4yjUtB9kUrIWeISkpab9LNneGCNSCIAhHOUmSyM7OJiMjg0gk0t3ZETCquw+1JN1EBGpBEIQfCEVRuiw4CD2HGEctCIIgCD2YCNSCIAiC0IOJQC0IgiAIPdgx10bdNADd4/F0c04EQRCEY1VTDOrMpCjHXKBubGwEID8/v5tzIgiCIBzrGhsbcbvd+0wj6cfYvHOaplFaWkpCQsIhTwrg8XjIz89n9+7d+134W2gmrtvBEdftwIlrdnDEdTs4B3LddF2nsbGRnJwcZHnfrdDHXIlalmXy8vK69JyJiYnij/kgiOt2cMR1O3Dimh0ccd0OTmev2/5K0k1EZzJBEARB6MFEoBYEQRCEHkwE6kNgtVq55557sFqt3Z2Vo4q4bgdHXLcDJ67ZwRHX7eAcrut2zHUmEwRBEISjiShRC4IgCEIPJgK1IAiCIPRgIlALgiAIQg8mAvUhePLJJyksLMRmszFx4kSWLVvW3VnqUb744gvOPvtscnJykCSJt99+u9Xruq5z9913k52djd1uZ8aMGWzdurV7MttDzJ8/n/Hjx5OQkEBGRgbnnnsumzdvbpUmGAxyww03kJqaisvl4oILLqCioqKbctwzPPXUU4wYMSI+fnXSpEn873//i78urtn+Pfjgg0iSxM033xzfJ65bW/feey+SJLXaBg0aFH/9cFwzEagP0quvvsq8efO45557WLlyJSNHjmTmzJlUVlZ2d9Z6DJ/Px8iRI3nyySfbff2hhx7iiSee4Omnn2bp0qU4nU5mzpxJMBg8wjntOT7//HNuuOEGvv32WxYuXEgkEuHUU0/F5/PF09xyyy289957vPbaa3z++eeUlpZy/vnnd2Ouu19eXh4PPvggK1as4LvvvmPatGmcc845rF+/HhDXbH+WL1/O3/72N0aMGNFqv7hu7Rs6dChlZWXx7auvvoq/dliumS4clAkTJug33HBD/GdVVfWcnBx9/vz53ZirngvQ33rrrfjPmqbpWVlZ+sMPPxzfV19fr1utVv3ll1/uhhz2TJWVlTqgf/7557quG9fIbDbrr732WjzNxo0bdUBfsmRJd2WzR0pOTtb/8Y9/iGu2H42NjXr//v31hQsX6lOnTtVvuukmXdfF31pH7rnnHn3kyJHtvna4rpkoUR+EcDjMihUrmDFjRnyfLMvMmDGDJUuWdGPOjh47duygvLy81TV0u91MnDhRXMMWGhoaAEhJSQFgxYoVRCKRVtdt0KBB9OrVS1y3GFVVeeWVV/D5fEyaNElcs/244YYbOPPMM1tdHxB/a/uydetWcnJy6NOnDz/5yU8oLi4GDt81O+bm+u4K1dXVqKpKZmZmq/2ZmZls2rSpm3J1dCkvLwdo9xo2vXas0zSNm2++mcmTJzNs2DDAuG4Wi4WkpKRWacV1g7Vr1zJp0iSCwSAul4u33nqLIUOGsGrVKnHNOvDKK6+wcuVKli9f3uY18bfWvokTJ/LCCy8wcOBAysrKuO+++5gyZQrr1q07bNdMBGpB6KFuuOEG1q1b16r9S+jYwIEDWbVqFQ0NDbz++utcfvnlfP75592drR5r9+7d3HTTTSxcuBCbzdbd2TlqnH766fHnI0aMYOLEiRQUFPCf//wHu91+WN5TVH0fhLS0NBRFadOTr6KigqysrG7K1dGl6TqJa9i+uXPn8t///pfPPvus1WpvWVlZhMNh6uvrW6UX1w0sFgv9+vVj7NixzJ8/n5EjR/KnP/1JXLMOrFixgsrKSsaMGYPJZMJkMvH555/zxBNPYDKZyMzMFNetE5KSkhgwYADbtm07bH9rIlAfBIvFwtixY1m0aFF8n6ZpLFq0iEmTJnVjzo4evXv3Jisrq9U19Hg8LF269Ji+hrquM3fuXN566y0+/fRTevfu3er1sWPHYjabW123zZs3U1xcfExft/ZomkYoFBLXrAPTp09n7dq1rFq1Kr6NGzeOn/zkJ/Hn4rrtn9frpaioiOzs7MP3t3bQ3dCOca+88oputVr1F154Qd+wYYN+zTXX6ElJSXp5eXl3Z63HaGxs1L///nv9+++/1wH90Ucf1b///nt9165duq7r+oMPPqgnJSXp77zzjr5mzRr9nHPO0Xv37q0HAoFuznn3uf7663W3260vXrxYLysri29+vz+e5rrrrtN79eqlf/rpp/p3332nT5o0SZ80aVI35rr73Xbbbfrnn3+u79ixQ1+zZo1+22236ZIk6R9//LGu6+KadVbLXt+6Lq5be/7v//5PX7x4sb5jxw7966+/1mfMmKGnpaXplZWVuq4fnmsmAvUh+POf/6z36tVLt1gs+oQJE/Rvv/22u7PUo3z22Wc60Ga7/PLLdV03hmjdddddemZmpm61WvXp06frmzdv7t5Md7P2rhegP//88/E0gUBA//nPf64nJyfrDodDP++88/SysrLuy3QPMGfOHL2goEC3WCx6enq6Pn369HiQ1nVxzTpr70Atrltbs2bN0rOzs3WLxaLn5ubqs2bN0rdt2xZ//XBcM7F6liAIgiD0YKKNWhAEQRB6MBGoBUEQBKEH+//27iYUnj+OA/h7PPy22Y1a1sM6SbSxxQHJ04EtrFK0ktq0XGQtubjI0zq4CbetLVyIokgew1GJkqUsNy4S4mCVvfj+D2pr0v+X/4//z1jvV03NfL87M5/Zy3tmvlNfBjUREZGKMaiJiIhUjEFNRESkYgxqIiIiFWNQExERqRiDmoiISMUY1ET0v5EkCUtLS19dBtG3xqAmClPNzc2QJOnNUlVV9dWlEdF/wPmoicJYVVUVpqamFG0ajeaLqiGiP8EnaqIwptFokJycrFj0ej2A19fSHo8HVqsVsiwjLS0NCwsLiv1PTk5QXl4OWZYRHx+P1tZWBAIBxW8mJydhNpuh0WhgNBrR0dGh6L+7u0NdXR20Wi0yMjKwvLwc6nt4eIDdbkdCQgJkWUZGRsabGwuin45BTfSD9ff3w2azwefzwW63o7GxEX6/HwDw9PSEyspK6PV6HBwcYH5+Htvb24og9ng8cLlcaG1txcnJCZaXl5Genq44x9DQEBoaGnB8fIzq6mrY7Xbc39+Hzn96eor19XX4/X54PB4YDIa/9wcQfQcfm/CLiNTK4XCIyMhIodPpFMvw8LAQ4nVKzba2NsU+BQUFwul0CiGE8Hq9Qq/Xi0AgEOpfXV0VERERoXnXU1JSRG9v77/WAED09fWFtgOBgAAg1tfXhRBC1NTUiJaWls+5YKIwxTFqojBWVlYGj8ejaIuLiwutFxYWKvoKCwtxdHQEAPD7/cjJyYFOpwv1FxcX4+XlBefn55AkCVdXV7BYLL+tITs7O7Su0+kQGxuLm5sbAIDT6YTNZsPh4SEqKipQW1uLoqKiP7pWonDFoCYKYzqd7s2r6M8iy/K7fhcdHa3YliQJLy8vAACr1YrLy0usra1ha2sLFosFLpcLIyMjn14v0XfFMWqiH2xvb+/NdmZmJgAgMzMTPp8PT09Pof7d3V1ERETAZDIhJiYGqamp2NnZ+VANCQkJcDgcmJ6exvj4OLxe74eORxRu+ERNFMaCwSCur68VbVFRUaEPtubn55GXl4eSkhLMzMxgf38fExMTAAC73Y7BwUE4HA643W7c3t6is7MTTU1NSEpKAgC43W60tbUhMTERVqsVj4+P2N3dRWdn57vqGxgYQG5uLsxmM4LBIFZWVkI3CkT0ikFNFMY2NjZgNBoVbSaTCWdnZwBev8iem5tDe3s7jEYjZmdnkZWVBQDQarXY3NxEV1cX8vPzodVqYbPZMDo6GjqWw+HA8/MzxsbG0N3dDYPBgPr6+nfX9+vXL/T09ODi4gKyLKO0tBRzc3OfcOVE4UMSQoivLoKI/j5JkrC4uIja2tqvLoWIfoNj1ERERCrGoCYiIlIxjlET/VAc9SL6HvhETUREpGIMaiIiIhVjUBMREakYg5qIiEjFGNREREQqxqAmIiJSMQY1ERGRijGoiYiIVIxBTUREpGL/AIVoErH1BW6qAAAAAElFTkSuQmCC",
      "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": {
    "jp-MarkdownHeadingCollapsed": true,
    "tags": []
   },
   "source": [
    "## Predict style"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "metadata": {},
   "outputs": [],
   "source": [
    "global_model, private_modules = load_fedgan_all_styles(global_model, model_paths[-1], device=device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "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": 37,
   "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_attr, (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",
    "        # 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": 42,
   "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": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "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
}
