{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "collapsed": false,
    "jupyter": {
     "outputs_hidden": false
    },
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [],
   "source": [
    "%matplotlib inline\n",
    "\n",
    "import sys\n",
    "sys.path.insert(0, \"../fl_sim/\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import random\n",
    "import glob\n",
    "import json\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",
    "plt.rcParams[\"figure.figsize\"] = (10,6)\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 opts import get_args\n",
    "from argparse import Namespace\n",
    "\n",
    "from models import *\n",
    "from data_funcs import *\n",
    "\n",
    "# Utility functions\n",
    "from utils.utils import top1_accuracy, \\\n",
    "    create_model_dir, init_metrics_meter, extend_metrics_dict, metric_to_dict\n",
    "from utils.tasks import get_task_elements, get_agg, get_sampling, get_optimizer_init\n",
    "from utils.logger import Logger\n",
    "\n",
    "# Main Modules\n",
    "from worker import *\n",
    "from server import TorchServer\n",
    "from simulator import ParallelTrainer, DistributedEvaluator"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Hyperparameters"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "args_dict = {\n",
    "    \"task\": \"linear-mixture1\",\n",
    "    \"agg\": \"mean\",\n",
    "    \"sampling\": \"fixed\",\n",
    "    \"simulated_workers\": 8,\n",
    "\n",
    "    \"seed\": 123,\n",
    "    \"log_interval\": 1,\n",
    "    \"identifier\": \"test\",\n",
    "\n",
    "    \"comm_rounds\": 50,\n",
    "    \"local_epochs\": 1,\n",
    "    \"global_opt\": \"sgd\",\n",
    "    \"local_opt\": \"sgd\",\n",
    "    \"global_lr\": 4.0,  # 1.0 for 4 workers\n",
    "    \"local_lr\": 0.2,\n",
    "    \"lr_sched\": \"exp\",\n",
    "    \"batch_size\": 10,\n",
    "    \"test_batch_size\": 10,\n",
    "\n",
    "    \"gpu\": \"0\",\n",
    "    \"num_workers\": 0,\n",
    "    \"loglevel\": \"INFO\",\n",
    "    \"deterministic\": True,\n",
    "}\n",
    "\n",
    "args = get_args(None, namespace=Namespace(**args_dict))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Setup"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[2023-02-16 19:34:03] (32625) {1057815708.py:9}WARNING - CUDA unsupported!!\n"
     ]
    }
   ],
   "source": [
    "# Logger\n",
    "Logger.setup_logging(\"INFO\", logfile=\"\")\n",
    "Logger()\n",
    "\n",
    "# CUDA support\n",
    "if torch.cuda.device_count():\n",
    "    cuda_support = True\n",
    "else:\n",
    "    Logger.get().warning('CUDA unsupported!!')\n",
    "    cuda_support = False\n",
    "\n",
    "# Seed\n",
    "if cuda_support:\n",
    "    torch.cuda.manual_seed(args.seed)\n",
    "    torch.cuda.manual_seed_all(args.seed)\n",
    "random.seed(args.seed)\n",
    "np.random.seed(args.seed)\n",
    "os.environ['PYTHONHASHSEED'] = str(args.seed)\n",
    "torch.manual_seed(args.seed)\n",
    "\n",
    "# Loader kwargs\n",
    "loader_kwargs = {}\n",
    "if not args.device == 'cpu':\n",
    "    loader_kwargs[\"num_workers\"] = args.num_workers\n",
    "    loader_kwargs[\"persistent_workers\"] = args.num_workers > 0\n",
    "train_loader_kwargs = {'batch_size': args.batch_size, 'shuffle': True, 'drop_last': True, **loader_kwargs}"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Task init"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Task inits\n",
    "init_model, loss_func, is_rnn, test_batch_size, train_datasets, test_dataset = \\\n",
    "    get_task_elements(args.task, args.test_batch_size, args.data_path)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### DataLoaders, Models and Optimizers"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[2023-02-16 19:34:03] (32625) {2048266642.py:9}INFO - Global model has 2 parameters.\n"
     ]
    }
   ],
   "source": [
    "test_loader = DataLoader(test_dataset, test_batch_size, shuffle=False, **loader_kwargs)\n",
    "train_loader_s = [DataLoader(dataset, args.batch_size, shuffle=True, **loader_kwargs) for\n",
    "                  dataset in train_datasets]\n",
    "\n",
    "def count_params(module):\n",
    "    return sum(p.numel() for p in module.parameters())\n",
    "\n",
    "global_model = init_model().to(args.device)\n",
    "Logger.get().info(f\"Global model has {count_params(global_model)} parameters.\")\n",
    "local_model_s = [init_model().to(args.device) for _ in range(args.simulated_workers)]\n",
    "\n",
    "local_opt_init = get_optimizer_init(args.local_opt, args.local_lr)\n",
    "global_opt_init = get_optimizer_init(args.global_opt, args.global_lr)\n",
    "server_opt = global_opt_init(global_model.parameters())"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Aggregator, Sampler, Metrics"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[2023-02-16 19:34:03] (32625) {base.py:11}INFO - Init aggregator: Mean\n",
      "[2023-02-16 19:34:03] (32625) {base.py:9}INFO - Init sampler: Fixed Sampler\n"
     ]
    }
   ],
   "source": [
    "agg = get_agg(args.aggregation)\n",
    "client_sampler = get_sampling(args.sampling, args.comm_rounds, args.simulated_workers,\n",
    "                              len(train_loader_s), args.seed)\n",
    "if 'fedgan' in args.task:\n",
    "    metrics = {k: (lambda _: 0.0) for k in TorchWorkerFedGAN.METRICS}\n",
    "elif 'gan' in args.task:\n",
    "    metrics = {k: (lambda _: 0.0) for k in TorchWorkerGAN.METRICS}\n",
    "else:\n",
    "    metrics = {}\n",
    "Logger.get().debug(f\"metrics: {list(metrics.keys())}\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Server, Trainer, and Workers"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[2023-02-16 19:34:03] (32625) {simulator.py:125}INFO - => Add worker TorchWorkerPartial [0]\n",
      "[2023-02-16 19:34:03] (32625) {simulator.py:125}INFO - => Add worker TorchWorkerPartial [1]\n",
      "[2023-02-16 19:34:03] (32625) {simulator.py:125}INFO - => Add worker TorchWorkerPartial [2]\n",
      "[2023-02-16 19:34:03] (32625) {simulator.py:125}INFO - => Add worker TorchWorkerPartial [3]\n",
      "[2023-02-16 19:34:03] (32625) {simulator.py:125}INFO - => Add worker TorchWorkerPartial [4]\n",
      "[2023-02-16 19:34:03] (32625) {simulator.py:125}INFO - => Add worker TorchWorkerPartial [5]\n",
      "[2023-02-16 19:34:03] (32625) {simulator.py:125}INFO - => Add worker TorchWorkerPartial [6]\n",
      "[2023-02-16 19:34:03] (32625) {simulator.py:125}INFO - => Add worker TorchWorkerPartial [7]\n"
     ]
    }
   ],
   "source": [
    "server = TorchServer(\n",
    "    global_model=global_model,\n",
    "    optimizer=server_opt\n",
    ")\n",
    "trainer = ParallelTrainer(\n",
    "    server=server,\n",
    "    aggregator=agg,\n",
    "    client_sampler=client_sampler,\n",
    "    datasets=train_datasets,\n",
    "    data_loader_kwargs=train_loader_kwargs,\n",
    "    log_interval=args.log_interval,\n",
    "    metrics=metrics,\n",
    "    device=args.device,\n",
    "    lr_sched=args.lr_sched,\n",
    "    aggregate_optim=args.aggregate_optim,\n",
    ")\n",
    "\n",
    "for worker_id, w_model in enumerate(local_model_s):\n",
    "    worker = initialize_worker(\n",
    "        worker_id=worker_id,\n",
    "        model=w_model,\n",
    "        optimizer_init=local_opt_init,\n",
    "        loss_func=loss_func,\n",
    "        is_rnn=is_rnn,\n",
    "        device=args.device,\n",
    "        server=server,\n",
    "        log_interval=args.log_interval,\n",
    "        private_modules=['weight' if 'mixture3' in args.task else 'bias']\n",
    "    )\n",
    "    trainer.add_worker(worker)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Visualize Data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "trainer.set_data_loaders(1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>worker_id</th>\n",
       "      <th>x</th>\n",
       "      <th>y</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0</td>\n",
       "      <td>1.910005</td>\n",
       "      <td>-1.124004</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0</td>\n",
       "      <td>1.843241</td>\n",
       "      <td>-1.194736</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>0</td>\n",
       "      <td>1.263296</td>\n",
       "      <td>-1.747019</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>0</td>\n",
       "      <td>1.655682</td>\n",
       "      <td>-1.344302</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>0</td>\n",
       "      <td>1.460607</td>\n",
       "      <td>-1.445171</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>395</th>\n",
       "      <td>7</td>\n",
       "      <td>-1.519668</td>\n",
       "      <td>1.497469</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>396</th>\n",
       "      <td>7</td>\n",
       "      <td>-1.852612</td>\n",
       "      <td>1.125577</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>397</th>\n",
       "      <td>7</td>\n",
       "      <td>-1.528653</td>\n",
       "      <td>1.421961</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>398</th>\n",
       "      <td>7</td>\n",
       "      <td>-1.524251</td>\n",
       "      <td>1.494675</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>399</th>\n",
       "      <td>7</td>\n",
       "      <td>-1.020127</td>\n",
       "      <td>1.978003</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>400 rows × 3 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "     worker_id         x         y\n",
       "0            0  1.910005 -1.124004\n",
       "1            0  1.843241 -1.194736\n",
       "2            0  1.263296 -1.747019\n",
       "3            0  1.655682 -1.344302\n",
       "4            0  1.460607 -1.445171\n",
       "..         ...       ...       ...\n",
       "395          7 -1.519668  1.497469\n",
       "396          7 -1.852612  1.125577\n",
       "397          7 -1.528653  1.421961\n",
       "398          7 -1.524251  1.494675\n",
       "399          7 -1.020127  1.978003\n",
       "\n",
       "[400 rows x 3 columns]"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "dicts = []\n",
    "for worker in trainer.workers:\n",
    "    for data, target in worker.data_loader:\n",
    "        for x, y in zip(data.tolist(), target.tolist()):\n",
    "            dicts.append({'worker_id': worker.worker_id, 'x': x[0], 'y': y[0]})\n",
    "df = pd.DataFrame(dicts)\n",
    "df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<AxesSubplot:xlabel='x', ylabel='y'>"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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bM7kCRoweVkOY5+fwZaiqmbunYiAAi0RERGRVqW8upbHpqymNlB/UlJemY+fV+c1Q69EZFcKtERERERakXKfn1nrCxqsn7I8h1p/sAl7JCLhKNASERERaUXsVivxkc4G69NiIrBZLU3YIxEJR4GWiIiISCuSGO3i6qO7NFh//tD2WBVoiTQ7BVoiIiIircyoHsmc0jctpMxigXtP7UVmnKeZeiUiO1N69z1QencRERFpiQorasguqebXNfm4nTYO75pIUrSLKFer2CZVpFXal9hA/0sUERERaYXiI53ERzrpla4fgkVaIk0dFBERERERaWQKtERERERERBqZAi0REREREZFGpkBLRERERESkkSnQEhERERERaWQKtERERERERBqZAi0REREREZFGpkBLRERERESkkSnQEhERERERaWQKtERERERERBqZAi0REREREZFGpkBLRERERESkkSnQEhERERERaWQKtERERERERBqZAi0REREREZFGZm/uDrR0hmEAUFpa2sw9ERERERGR5rQ9JtgeI+yOAq09KCsrAyAzM7OZeyIiIiIiIi1BWVkZXq93t20sxt6EY21YMBhk69atREdHY7FYGuWcpaWlZGZmsmnTJmJiYhrlnNIw3e+mpfvdtHS/m5bud9PS/W5aut9NR/e6aTXm/TYMg7KyMtLT07Fad78KSyNae2C1WmnXrt0BOXdMTIz+x9WEdL+blu5309L9blq6301L97tp6X43Hd3rptVY93tPI1nbKRmGiIiIiIhII1OgJSIiIiIi0sgUaDUDl8vFvffei8vlau6utAm6301L97tp6X43Ld3vpqX73bR0v5uO7nXTaq77rWQYIiIiIiIijUwjWiIiIiIiIo1MgZaIiIiIiEgjU6AlIiIiIiLSyBRoiYiIiIiINDIFWk1gw4YNXH755XTq1Am3202XLl249957qamp2e1xhmEwfvx40tPTcbvdjBw5kqVLlzZRr1u3+++/nxEjRuDxeIiNjd2rY8aNG4fFYgl5DRs27MB29CCxP/dbz/f+Kyoq4qKLLsLr9eL1ernooosoLi7e7TF6vvfeM888Q6dOnYiIiGDgwIH8/PPPu23/448/MnDgQCIiIujcuTPPPfdcE/X04LAv93vatGn1nmOLxcKKFSuasMet008//cSpp55Keno6FouFTz/9dI/H6Nnef/t6v/Vs778HH3yQwYMHEx0dTXJyMmeccQYrV67c43FN8Xwr0GoCK1asIBgM8vzzz7N06VIee+wxnnvuOe66667dHvfwww8zYcIEJk6cyJw5c0hNTeW4446jrKysiXreetXU1DB27FiuvfbafTruhBNOYNu2bXWvr7766gD18OCyP/dbz/f+O//881m4cCHffPMN33zzDQsXLuSiiy7a43F6vvfs/fff5+abb+Yf//gHCxYs4Mgjj+TEE08kKysrbPv169dz0kknceSRR7JgwQLuuusubrzxRj7++OMm7nnrtK/3e7uVK1eGPMvdunVroh63XhUVFRx22GFMnDhxr9rr2f5j9vV+b6dne9/9+OOP/OUvf2HmzJlMmTIFv9/PmDFjqKioaPCYJnu+DWkWDz/8sNGpU6cG64PBoJGammr85z//qSurrq42vF6v8dxzzzVFFw8Kr776quH1eveq7SWXXGKcfvrpB7Q/B7u9vd96vvffsmXLDMCYOXNmXdmMGTMMwFixYkWDx+n53jtDhgwxrrnmmpCynj17GnfccUfY9rfddpvRs2fPkLKrr77aGDZs2AHr48FkX+/31KlTDcAoKipqgt4dvABj0qRJu22jZ7vx7M391rPdeHJzcw3A+PHHHxts01TPt0a0mklJSQnx8fEN1q9fv57s7GzGjBlTV+ZyuTj66KOZPn16U3SxTZo2bRrJycl0796dK6+8ktzc3Obu0kFJz/f+mzFjBl6vl6FDh9aVDRs2DK/Xu8d7p+d792pqapg3b17IcwkwZsyYBu/tjBkz6rU//vjjmTt3LrW1tQesrweD/bnf2/Xv35+0tDSOOeYYpk6deiC72Wbp2W4eerb/uJKSEoDdfs9uqudbgVYzWLt2LU899RTXXHNNg22ys7MBSElJCSlPSUmpq5PGdeKJJ/L222/zww8/8OijjzJnzhxGjx6Nz+dr7q4ddPR877/s7GySk5PrlScnJ+/23un53rP8/HwCgcA+PZfZ2dlh2/v9fvLz8w9YXw8G+3O/09LSeOGFF/j444/55JNP6NGjB8cccww//fRTU3S5TdGz3bT0bDcOwzC49dZbOeKII+jTp0+D7Zrq+Vag9QeMHz8+7MLFnV9z584NOWbr1q2ccMIJjB07liuuuGKPn2GxWELeG4ZRr6yt2J/7vS/OOeccTj75ZPr06cOpp57K119/zapVq/jyyy8b8SpajwN9v0HP98725X6Hu0d7und6vvfevj6X4dqHK5fw9uV+9+jRgyuvvJIBAwYwfPhwnnnmGU4++WQeeeSRpuhqm6Nnu+no2W4c119/PYsWLeLdd9/dY9umeL7tjXamNuj666/n3HPP3W2bjh071v29detWRo0axfDhw3nhhRd2e1xqaipgRtxpaWl15bm5ufUi8LZiX+/3H5WWlkaHDh1YvXp1o52zNTmQ91vPd317e78XLVpETk5Ovbq8vLx9undt/fkOJzExEZvNVm80ZXfPZWpqatj2drudhISEA9bXg8H+3O9whg0bxltvvdXY3Wvz9Gw3Pz3b++aGG27gf//7Hz/99BPt2rXbbdumer4VaP0BiYmJJCYm7lXbLVu2MGrUKAYOHMirr76K1br7wcROnTqRmprKlClT6N+/P2DOZ//xxx956KGH/nDfW6N9ud+NoaCggE2bNoUEAm3Jgbzfer7r29v7PXz4cEpKSpg9ezZDhgwBYNasWZSUlDBixIi9/ry2/nyH43Q6GThwIFOmTOHMM8+sK58yZQqnn3562GOGDx/O559/HlI2efJkBg0ahMPhOKD9be32536Hs2DBAj3HB4Ce7eanZ3vvGIbBDTfcwKRJk5g2bRqdOnXa4zFN9nw3amoNCWvLli1G165djdGjRxubN282tm3bVvfaWY8ePYxPPvmk7v1//vMfw+v1Gp988omxePFi47zzzjPS0tKM0tLSpr6EVmfjxo3GggULjPvuu8+IiooyFixYYCxYsMAoKyura7Pz/S4rKzP++te/GtOnTzfWr19vTJ061Rg+fLiRkZGh+70X9vV+G4ae7z/ihBNOMPr27WvMmDHDmDFjhnHooYcap5xySkgbPd/757333jMcDofx8ssvG8uWLTNuvvlmIzIy0tiwYYNhGIZxxx13GBdddFFd+3Xr1hkej8e45ZZbjGXLlhkvv/yy4XA4jI8++qi5LqFV2df7/dhjjxmTJk0yVq1aZSxZssS44447DMD4+OOPm+sSWo2ysrK6f5sBY8KECcaCBQuMjRs3GoahZ7ux7ev91rO9/6699lrD6/Ua06ZNC/mOXVlZWdemuZ5vBVpN4NVXXzWAsK+dAcarr75a9z4YDBr33nuvkZqaarhcLuOoo44yFi9e3MS9b50uueSSsPd76tSpdW12vt+VlZXGmDFjjKSkJMPhcBjt27c3LrnkEiMrK6t5LqCV2df7bRh6vv+IgoIC44ILLjCio6ON6Oho44ILLqiXEljP9/57+umnjQ4dOhhOp9MYMGBASIrgSy65xDj66KND2k+bNs3o37+/4XQ6jY4dOxrPPvtsE/e4dduX+/3QQw8ZXbp0MSIiIoy4uDjjiCOOML788stm6HXrsz19+K6vSy65xDAMPduNbV/vt57t/dfQd+ydv3M01/Nt+b2DIiIiIiIi0kiUdVBERERERKSRKdASERERERFpZAq0REREREREGpkCLRERERERkUamQEtERERERKSRKdASERERERFpZAq0REREREREGpkCLRERERERkUamQEtERERERKSRKdASERERERFpZAq0REREGpCXl0dqaioPPPBAXdmsWbNwOp1Mnjy5GXsmIiItncUwDKO5OyEiItJSffXVV5xxxhlMnz6dnj170r9/f04++WQef/zx5u6aiIi0YAq0RERE9uAvf/kL3333HYMHD+a3335jzpw5RERENHe3RESkBVOgJSIisgdVVVX06dOHTZs2MXfuXPr27dvcXRIRkRZOa7RERET2YN26dWzdupVgMMjGjRubuzsiItIKaERLRERkN2pqahgyZAj9+vWjZ8+eTJgwgcWLF5OSktLcXRMRkRZMgZaIiMhu/P3vf+ejjz7it99+IyoqilGjRhEdHc0XX3zR3F0TEZEWTFMHRUREGjBt2jQef/xx3nzzTWJiYrBarbz55pv88ssvPPvss83dPRERacE0oiUiIiIiItLINKIlIiIiIiLSyBRoiYiIiIiINDIFWiIiIiIiIo1MgZaIiIiIiEgjU6AlIiIiIiLSyBRoiYiIiIiINDIFWiIiIiIiIo1MgZaIiIiIiEgjU6AlIiIiIiLSyBRoiYiIiIiINDIFWiIiIiIiIo1MgZaIiIiIiEgj+3/U1JIdw7dcEwAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 1000x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "sns.scatterplot(data=df, x='x', y='y', hue='worker_id', palette='tab10', legend=False)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Train"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Train partially-federated model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "test_evaluator = DistributedEvaluator(\n",
    "    model=global_model,\n",
    "    is_rnn=is_rnn,\n",
    "    data_loader=test_loader,\n",
    "    loss_func=loss_func,\n",
    "    device=args.device,\n",
    "    metrics=metrics,\n",
    "    log_interval=args.log_interval,\n",
    "    log_identifier_type='Test',\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[2023-02-16 19:34:03] (32625) {simulator.py:208}INFO - Test | 1/40 | loss = 0.1250; \n",
      "[2023-02-16 19:34:03] (32625) {simulator.py:208}INFO - Test | 2/40 | loss = 0.1641; \n",
      "[2023-02-16 19:34:03] (32625) {simulator.py:208}INFO - Test | 3/40 | loss = 0.1299; \n",
      "[2023-02-16 19:34:03] (32625) {simulator.py:208}INFO - Test | 4/40 | loss = 0.1162; \n",
      "[2023-02-16 19:34:03] (32625) {simulator.py:208}INFO - Test | 5/40 | loss = 0.1252; \n",
      "[2023-02-16 19:34:03] (32625) {simulator.py:208}INFO - Test | 6/40 | loss = 0.1238; \n",
      "[2023-02-16 19:34:03] (32625) {simulator.py:208}INFO - Test | 7/40 | loss = 0.1437; \n",
      "[2023-02-16 19:34:03] (32625) {simulator.py:208}INFO - Test | 8/40 | loss = 0.1370; \n",
      "[2023-02-16 19:34:03] (32625) {simulator.py:208}INFO - Test | 9/40 | loss = 0.1384; \n",
      "[2023-02-16 19:34:03] (32625) {simulator.py:208}INFO - Test | 10/40 | loss = 0.1397; \n",
      "[2023-02-16 19:34:03] (32625) {simulator.py:208}INFO - Test | 11/40 | loss = 0.1403; \n",
      "[2023-02-16 19:34:03] (32625) {simulator.py:208}INFO - Test | 12/40 | loss = 0.1397; \n",
      "[2023-02-16 19:34:03] (32625) {simulator.py:208}INFO - Test | 13/40 | loss = 0.1446; \n",
      "[2023-02-16 19:34:03] (32625) {simulator.py:208}INFO - Test | 14/40 | loss = 0.1420; \n",
      "[2023-02-16 19:34:03] (32625) {simulator.py:208}INFO - Test | 15/40 | loss = 0.1402; \n",
      "[2023-02-16 19:34:03] (32625) {simulator.py:208}INFO - Test | 16/40 | loss = 0.1415; \n",
      "[2023-02-16 19:34:03] (32625) {simulator.py:208}INFO - Test | 17/40 | loss = 0.1575; \n",
      "[2023-02-16 19:34:03] (32625) {simulator.py:208}INFO - Test | 18/40 | loss = 0.1620; \n",
      "[2023-02-16 19:34:03] (32625) {simulator.py:208}INFO - Test | 19/40 | loss = 0.1724; \n",
      "[2023-02-16 19:34:03] (32625) {simulator.py:208}INFO - Test | 20/40 | loss = 0.1712; \n",
      "[2023-02-16 19:34:03] (32625) {simulator.py:208}INFO - Test | 21/40 | loss = 0.1723; \n",
      "[2023-02-16 19:34:03] (32625) {simulator.py:208}INFO - Test | 22/40 | loss = 0.1703; \n",
      "[2023-02-16 19:34:03] (32625) {simulator.py:208}INFO - Test | 23/40 | loss = 0.1675; \n",
      "[2023-02-16 19:34:03] (32625) {simulator.py:208}INFO - Test | 24/40 | loss = 0.1741; \n",
      "[2023-02-16 19:34:03] (32625) {simulator.py:208}INFO - Test | 25/40 | loss = 0.1757; \n",
      "[2023-02-16 19:34:03] (32625) {simulator.py:208}INFO - Test | 26/40 | loss = 0.1763; \n",
      "[2023-02-16 19:34:03] (32625) {simulator.py:208}INFO - Test | 27/40 | loss = 0.1819; \n",
      "[2023-02-16 19:34:03] (32625) {simulator.py:208}INFO - Test | 28/40 | loss = 0.1814; \n",
      "[2023-02-16 19:34:03] (32625) {simulator.py:208}INFO - Test | 29/40 | loss = 0.1891; \n",
      "[2023-02-16 19:34:03] (32625) {simulator.py:208}INFO - Test | 30/40 | loss = 0.1952; \n",
      "[2023-02-16 19:34:03] (32625) {simulator.py:208}INFO - Test | 31/40 | loss = 0.2056; \n",
      "[2023-02-16 19:34:03] (32625) {simulator.py:208}INFO - Test | 32/40 | loss = 0.2034; \n",
      "[2023-02-16 19:34:03] (32625) {simulator.py:208}INFO - Test | 33/40 | loss = 0.2127; \n",
      "[2023-02-16 19:34:03] (32625) {simulator.py:208}INFO - Test | 34/40 | loss = 0.2175; \n",
      "[2023-02-16 19:34:03] (32625) {simulator.py:208}INFO - Test | 35/40 | loss = 0.2280; \n",
      "[2023-02-16 19:34:03] (32625) {simulator.py:208}INFO - Test | 36/40 | loss = 0.2376; \n",
      "[2023-02-16 19:34:03] (32625) {simulator.py:208}INFO - Test | 37/40 | loss = 0.2442; \n",
      "[2023-02-16 19:34:03] (32625) {simulator.py:208}INFO - Test | 38/40 | loss = 0.2470; \n",
      "[2023-02-16 19:34:03] (32625) {simulator.py:208}INFO - Test | 39/40 | loss = 0.2536; \n",
      "[2023-02-16 19:34:03] (32625) {simulator.py:208}INFO - Test | 40/40 | loss = 0.2604; \n",
      "[2023-02-16 19:34:03] (32625) {2092133410.py:18}INFO - Communication round 1/50\n",
      "[2023-02-16 19:34:03] (32625) {worker.py:220}INFO -  Train | Worker ID: 0 | Dataset ID: 0 | 5/5 | loss = 0.1618; \n",
      "[2023-02-16 19:34:03] (32625) {worker.py:220}INFO -  Train | Worker ID: 1 | Dataset ID: 1 | 5/5 | loss = 0.3055; \n",
      "[2023-02-16 19:34:03] (32625) {worker.py:220}INFO -  Train | Worker ID: 2 | Dataset ID: 2 | 5/5 | loss = 0.2467; \n",
      "[2023-02-16 19:34:03] (32625) {worker.py:220}INFO -  Train | Worker ID: 3 | Dataset ID: 3 | 5/5 | loss = 0.2711; \n",
      "[2023-02-16 19:34:03] (32625) {worker.py:220}INFO -  Train | Worker ID: 4 | Dataset ID: 4 | 5/5 | loss = 0.2835; \n",
      "[2023-02-16 19:34:03] (32625) {worker.py:220}INFO -  Train | Worker ID: 5 | Dataset ID: 5 | 5/5 | loss = 0.2730; \n",
      "[2023-02-16 19:34:03] (32625) {worker.py:220}INFO -  Train | Worker ID: 6 | Dataset ID: 6 | 5/5 | loss = 0.2896; \n",
      "[2023-02-16 19:34:03] (32625) {worker.py:220}INFO -  Train | Worker ID: 7 | Dataset ID: 7 | 5/5 | loss = 0.3073; \n",
      "[2023-02-16 19:34:03] (32625) {2092133410.py:18}INFO - Communication round 2/50\n",
      "[2023-02-16 19:34:03] (32625) {worker.py:220}INFO -  Train | Worker ID: 0 | Dataset ID: 0 | 5/5 | loss = 0.2126; \n",
      "[2023-02-16 19:34:03] (32625) {worker.py:220}INFO -  Train | Worker ID: 1 | Dataset ID: 1 | 5/5 | loss = 0.2094; \n",
      "[2023-02-16 19:34:03] (32625) {worker.py:220}INFO -  Train | Worker ID: 2 | Dataset ID: 2 | 5/5 | loss = 0.1927; \n",
      "[2023-02-16 19:34:03] (32625) {worker.py:220}INFO -  Train | Worker ID: 3 | Dataset ID: 3 | 5/5 | loss = 0.1949; \n",
      "[2023-02-16 19:34:03] (32625) {worker.py:220}INFO -  Train | Worker ID: 4 | Dataset ID: 4 | 5/5 | loss = 0.1810; \n",
      "[2023-02-16 19:34:03] (32625) {worker.py:220}INFO -  Train | Worker ID: 5 | Dataset ID: 5 | 5/5 | loss = 0.1798; \n",
      "[2023-02-16 19:34:03] (32625) {worker.py:220}INFO -  Train | Worker ID: 6 | Dataset ID: 6 | 5/5 | loss = 0.1873; \n",
      "[2023-02-16 19:34:03] (32625) {worker.py:220}INFO -  Train | Worker ID: 7 | Dataset ID: 7 | 5/5 | loss = 0.1925; \n",
      "[2023-02-16 19:34:03] (32625) {2092133410.py:18}INFO - Communication round 3/50\n",
      "[2023-02-16 19:34:03] (32625) {worker.py:220}INFO -  Train | Worker ID: 0 | Dataset ID: 0 | 5/5 | loss = 0.1466; \n",
      "[2023-02-16 19:34:03] (32625) {worker.py:220}INFO -  Train | Worker ID: 1 | Dataset ID: 1 | 5/5 | loss = 0.1700; \n",
      "[2023-02-16 19:34:03] (32625) {worker.py:220}INFO -  Train | Worker ID: 2 | Dataset ID: 2 | 5/5 | loss = 0.1442; \n",
      "[2023-02-16 19:34:03] (32625) {worker.py:220}INFO -  Train | Worker ID: 3 | Dataset ID: 3 | 5/5 | loss = 0.1414; \n",
      "[2023-02-16 19:34:03] (32625) {worker.py:220}INFO -  Train | Worker ID: 4 | Dataset ID: 4 | 5/5 | loss = 0.1278; \n",
      "[2023-02-16 19:34:03] (32625) {worker.py:220}INFO -  Train | Worker ID: 5 | Dataset ID: 5 | 5/5 | loss = 0.1247; \n",
      "[2023-02-16 19:34:03] (32625) {worker.py:220}INFO -  Train | Worker ID: 6 | Dataset ID: 6 | 5/5 | loss = 0.1328; \n",
      "[2023-02-16 19:34:03] (32625) {worker.py:220}INFO -  Train | Worker ID: 7 | Dataset ID: 7 | 5/5 | loss = 0.1567; \n",
      "[2023-02-16 19:34:03] (32625) {2092133410.py:18}INFO - Communication round 4/50\n",
      "[2023-02-16 19:34:03] (32625) {worker.py:220}INFO -  Train | Worker ID: 0 | Dataset ID: 0 | 5/5 | loss = 0.1304; \n",
      "[2023-02-16 19:34:03] (32625) {worker.py:220}INFO -  Train | Worker ID: 1 | Dataset ID: 1 | 5/5 | loss = 0.1638; \n",
      "[2023-02-16 19:34:03] (32625) {worker.py:220}INFO -  Train | Worker ID: 2 | Dataset ID: 2 | 5/5 | loss = 0.1474; \n",
      "[2023-02-16 19:34:03] (32625) {worker.py:220}INFO -  Train | Worker ID: 3 | Dataset ID: 3 | 5/5 | loss = 0.1490; \n",
      "[2023-02-16 19:34:03] (32625) {worker.py:220}INFO -  Train | Worker ID: 4 | Dataset ID: 4 | 5/5 | loss = 0.1375; \n",
      "[2023-02-16 19:34:03] (32625) {worker.py:220}INFO -  Train | Worker ID: 5 | Dataset ID: 5 | 5/5 | loss = 0.1340; \n",
      "[2023-02-16 19:34:03] (32625) {worker.py:220}INFO -  Train | Worker ID: 6 | Dataset ID: 6 | 5/5 | loss = 0.1321; \n",
      "[2023-02-16 19:34:03] (32625) {worker.py:220}INFO -  Train | Worker ID: 7 | Dataset ID: 7 | 5/5 | loss = 0.1360; \n",
      "[2023-02-16 19:34:03] (32625) {2092133410.py:18}INFO - Communication round 5/50\n",
      "[2023-02-16 19:34:03] (32625) {worker.py:220}INFO -  Train | Worker ID: 0 | Dataset ID: 0 | 5/5 | loss = 0.1640; \n",
      "[2023-02-16 19:34:03] (32625) {worker.py:220}INFO -  Train | Worker ID: 1 | Dataset ID: 1 | 5/5 | loss = 0.1394; \n",
      "[2023-02-16 19:34:03] (32625) {worker.py:220}INFO -  Train | Worker ID: 2 | Dataset ID: 2 | 5/5 | loss = 0.1188; \n",
      "[2023-02-16 19:34:03] (32625) {worker.py:220}INFO -  Train | Worker ID: 3 | Dataset ID: 3 | 5/5 | loss = 0.1125; \n",
      "[2023-02-16 19:34:03] (32625) {worker.py:220}INFO -  Train | Worker ID: 4 | Dataset ID: 4 | 5/5 | loss = 0.1006; \n",
      "[2023-02-16 19:34:03] (32625) {worker.py:220}INFO -  Train | Worker ID: 5 | Dataset ID: 5 | 5/5 | loss = 0.0996; \n",
      "[2023-02-16 19:34:03] (32625) {worker.py:220}INFO -  Train | Worker ID: 6 | Dataset ID: 6 | 5/5 | loss = 0.1033; \n",
      "[2023-02-16 19:34:03] (32625) {worker.py:220}INFO -  Train | Worker ID: 7 | Dataset ID: 7 | 5/5 | loss = 0.1159; \n",
      "[2023-02-16 19:34:03] (32625) {simulator.py:208}INFO - Test | 1/40 | loss = 1469.3344; \n",
      "[2023-02-16 19:34:03] (32625) {simulator.py:208}INFO - Test | 2/40 | loss = 1476.8881; \n",
      "[2023-02-16 19:34:03] (32625) {simulator.py:208}INFO - Test | 3/40 | loss = 1478.9494; \n",
      "[2023-02-16 19:34:03] (32625) {simulator.py:208}INFO - Test | 4/40 | loss = 1479.0276; \n",
      "[2023-02-16 19:34:03] (32625) {simulator.py:208}INFO - Test | 5/40 | loss = 1478.1455; \n",
      "[2023-02-16 19:34:03] (32625) {simulator.py:208}INFO - Test | 6/40 | loss = 1476.0649; \n",
      "[2023-02-16 19:34:03] (32625) {simulator.py:208}INFO - Test | 7/40 | loss = 1475.6388; \n",
      "[2023-02-16 19:34:03] (32625) {simulator.py:208}INFO - Test | 8/40 | loss = 1472.1364; \n",
      "[2023-02-16 19:34:03] (32625) {simulator.py:208}INFO - Test | 9/40 | loss = 1471.7225; \n",
      "[2023-02-16 19:34:03] (32625) {simulator.py:208}INFO - Test | 10/40 | loss = 1472.0374; \n",
      "[2023-02-16 19:34:03] (32625) {simulator.py:208}INFO - Test | 11/40 | loss = 1469.6234; \n",
      "[2023-02-16 19:34:03] (32625) {simulator.py:208}INFO - Test | 12/40 | loss = 1466.9286; \n",
      "[2023-02-16 19:34:03] (32625) {simulator.py:208}INFO - Test | 13/40 | loss = 1465.5030; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 14/40 | loss = 1464.2846; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 15/40 | loss = 1462.9052; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 16/40 | loss = 1460.9969; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 17/40 | loss = 1459.2406; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 18/40 | loss = 1457.2275; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 19/40 | loss = 1455.2197; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 20/40 | loss = 1454.6176; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 21/40 | loss = 1452.5893; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 22/40 | loss = 1451.0466; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 23/40 | loss = 1449.5063; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 24/40 | loss = 1448.0816; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 25/40 | loss = 1447.3279; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 26/40 | loss = 1445.6500; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 27/40 | loss = 1443.7126; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 28/40 | loss = 1442.4241; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 29/40 | loss = 1440.5883; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 30/40 | loss = 1438.8633; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 31/40 | loss = 1436.8388; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 32/40 | loss = 1435.5918; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 33/40 | loss = 1433.7850; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 34/40 | loss = 1432.2252; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 35/40 | loss = 1430.5034; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 36/40 | loss = 1428.6209; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 37/40 | loss = 1426.9410; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 38/40 | loss = 1425.5164; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 39/40 | loss = 1423.9346; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 40/40 | loss = 1422.5064; \n",
      "[2023-02-16 19:34:04] (32625) {2092133410.py:18}INFO - Communication round 6/50\n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 0 | Dataset ID: 0 | 5/5 | loss = 0.1073; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 1 | Dataset ID: 1 | 5/5 | loss = 0.1108; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 2 | Dataset ID: 2 | 5/5 | loss = 0.1046; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 3 | Dataset ID: 3 | 5/5 | loss = 0.1101; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 4 | Dataset ID: 4 | 5/5 | loss = 0.1022; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 5 | Dataset ID: 5 | 5/5 | loss = 0.1012; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 6 | Dataset ID: 6 | 5/5 | loss = 0.1000; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 7 | Dataset ID: 7 | 5/5 | loss = 0.1044; \n",
      "[2023-02-16 19:34:04] (32625) {2092133410.py:18}INFO - Communication round 7/50\n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 0 | Dataset ID: 0 | 5/5 | loss = 0.1479; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 1 | Dataset ID: 1 | 5/5 | loss = 0.1179; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 2 | Dataset ID: 2 | 5/5 | loss = 0.1008; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 3 | Dataset ID: 3 | 5/5 | loss = 0.0963; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 4 | Dataset ID: 4 | 5/5 | loss = 0.0869; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 5 | Dataset ID: 5 | 5/5 | loss = 0.0836; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 6 | Dataset ID: 6 | 5/5 | loss = 0.0835; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 7 | Dataset ID: 7 | 5/5 | loss = 0.0922; \n",
      "[2023-02-16 19:34:04] (32625) {2092133410.py:18}INFO - Communication round 8/50\n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 0 | Dataset ID: 0 | 5/5 | loss = 0.1457; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 1 | Dataset ID: 1 | 5/5 | loss = 0.1108; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 2 | Dataset ID: 2 | 5/5 | loss = 0.0939; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 3 | Dataset ID: 3 | 5/5 | loss = 0.0896; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 4 | Dataset ID: 4 | 5/5 | loss = 0.0805; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 5 | Dataset ID: 5 | 5/5 | loss = 0.0772; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 6 | Dataset ID: 6 | 5/5 | loss = 0.0756; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 7 | Dataset ID: 7 | 5/5 | loss = 0.0805; \n",
      "[2023-02-16 19:34:04] (32625) {2092133410.py:18}INFO - Communication round 9/50\n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 0 | Dataset ID: 0 | 5/5 | loss = 0.0707; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 1 | Dataset ID: 1 | 5/5 | loss = 0.0696; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 2 | Dataset ID: 2 | 5/5 | loss = 0.0631; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 3 | Dataset ID: 3 | 5/5 | loss = 0.0651; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 4 | Dataset ID: 4 | 5/5 | loss = 0.0601; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 5 | Dataset ID: 5 | 5/5 | loss = 0.0593; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 6 | Dataset ID: 6 | 5/5 | loss = 0.0585; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 7 | Dataset ID: 7 | 5/5 | loss = 0.0607; \n",
      "[2023-02-16 19:34:04] (32625) {2092133410.py:18}INFO - Communication round 10/50\n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 0 | Dataset ID: 0 | 5/5 | loss = 0.0933; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 1 | Dataset ID: 1 | 5/5 | loss = 0.0771; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 2 | Dataset ID: 2 | 5/5 | loss = 0.0661; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 3 | Dataset ID: 3 | 5/5 | loss = 0.0637; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 4 | Dataset ID: 4 | 5/5 | loss = 0.0576; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 5 | Dataset ID: 5 | 5/5 | loss = 0.0556; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 6 | Dataset ID: 6 | 5/5 | loss = 0.0544; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 7 | Dataset ID: 7 | 5/5 | loss = 0.0584; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 1/40 | loss = 12119869.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 2/40 | loss = 12119420.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 3/40 | loss = 12119269.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 4/40 | loss = 12119261.2500; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 5/40 | loss = 12119322.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 6/40 | loss = 12119794.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 7/40 | loss = 12120074.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 8/40 | loss = 12120467.5000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 9/40 | loss = 12120640.5556; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 10/40 | loss = 12120737.4000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 11/40 | loss = 12121163.9091; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 12/40 | loss = 12121568.7500; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 13/40 | loss = 12121856.6923; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 14/40 | loss = 12122102.4286; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 15/40 | loss = 12122334.4000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 16/40 | loss = 12122708.1875; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 17/40 | loss = 12123043.6471; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 18/40 | loss = 12123369.7778; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 19/40 | loss = 12123675.8947; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 20/40 | loss = 12123878.6000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 21/40 | loss = 12124250.9524; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 22/40 | loss = 12124572.6364; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 23/40 | loss = 12124874.5217; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 24/40 | loss = 12125154.9167; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 25/40 | loss = 12125377.2000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 26/40 | loss = 12125720.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 27/40 | loss = 12126061.1481; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 28/40 | loss = 12126348.4643; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 29/40 | loss = 12126652.5172; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 30/40 | loss = 12126939.7333; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 31/40 | loss = 12127300.8710; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 32/40 | loss = 12127600.3125; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 33/40 | loss = 12127917.3333; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 34/40 | loss = 12128210.2941; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 35/40 | loss = 12128500.6571; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 36/40 | loss = 12128848.2222; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 37/40 | loss = 12129173.6757; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 38/40 | loss = 12129470.1316; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 39/40 | loss = 12129765.5128; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 40/40 | loss = 12130041.9250; \n",
      "[2023-02-16 19:34:04] (32625) {2092133410.py:18}INFO - Communication round 11/50\n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 0 | Dataset ID: 0 | 5/5 | loss = 0.0666; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 1 | Dataset ID: 1 | 5/5 | loss = 0.0582; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 2 | Dataset ID: 2 | 5/5 | loss = 0.0518; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 3 | Dataset ID: 3 | 5/5 | loss = 0.0519; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 4 | Dataset ID: 4 | 5/5 | loss = 0.0474; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 5 | Dataset ID: 5 | 5/5 | loss = 0.0468; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 6 | Dataset ID: 6 | 5/5 | loss = 0.0460; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 7 | Dataset ID: 7 | 5/5 | loss = 0.0514; \n",
      "[2023-02-16 19:34:04] (32625) {2092133410.py:18}INFO - Communication round 12/50\n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 0 | Dataset ID: 0 | 5/5 | loss = 0.0585; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 1 | Dataset ID: 1 | 5/5 | loss = 0.0521; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 2 | Dataset ID: 2 | 5/5 | loss = 0.0472; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 3 | Dataset ID: 3 | 5/5 | loss = 0.0478; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 4 | Dataset ID: 4 | 5/5 | loss = 0.0437; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 5 | Dataset ID: 5 | 5/5 | loss = 0.0430; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 6 | Dataset ID: 6 | 5/5 | loss = 0.0423; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 7 | Dataset ID: 7 | 5/5 | loss = 0.0447; \n",
      "[2023-02-16 19:34:04] (32625) {2092133410.py:18}INFO - Communication round 13/50\n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 0 | Dataset ID: 0 | 5/5 | loss = 0.0565; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 1 | Dataset ID: 1 | 5/5 | loss = 0.0482; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 2 | Dataset ID: 2 | 5/5 | loss = 0.0417; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 3 | Dataset ID: 3 | 5/5 | loss = 0.0405; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 4 | Dataset ID: 4 | 5/5 | loss = 0.0366; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 5 | Dataset ID: 5 | 5/5 | loss = 0.0362; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 6 | Dataset ID: 6 | 5/5 | loss = 0.0359; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 7 | Dataset ID: 7 | 5/5 | loss = 0.0388; \n",
      "[2023-02-16 19:34:04] (32625) {2092133410.py:18}INFO - Communication round 14/50\n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 0 | Dataset ID: 0 | 5/5 | loss = 0.0365; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 1 | Dataset ID: 1 | 5/5 | loss = 0.0364; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 2 | Dataset ID: 2 | 5/5 | loss = 0.0340; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 3 | Dataset ID: 3 | 5/5 | loss = 0.0350; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 4 | Dataset ID: 4 | 5/5 | loss = 0.0323; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 5 | Dataset ID: 5 | 5/5 | loss = 0.0321; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 6 | Dataset ID: 6 | 5/5 | loss = 0.0319; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 7 | Dataset ID: 7 | 5/5 | loss = 0.0335; \n",
      "[2023-02-16 19:34:04] (32625) {2092133410.py:18}INFO - Communication round 15/50\n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 0 | Dataset ID: 0 | 5/5 | loss = 0.0444; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 1 | Dataset ID: 1 | 5/5 | loss = 0.0376; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 2 | Dataset ID: 2 | 5/5 | loss = 0.0327; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 3 | Dataset ID: 3 | 5/5 | loss = 0.0321; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 4 | Dataset ID: 4 | 5/5 | loss = 0.0290; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 5 | Dataset ID: 5 | 5/5 | loss = 0.0284; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 6 | Dataset ID: 6 | 5/5 | loss = 0.0282; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 7 | Dataset ID: 7 | 5/5 | loss = 0.0289; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 1/40 | loss = 24237768704.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 2/40 | loss = 24237784064.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 3/40 | loss = 24237789866.6667; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 4/40 | loss = 24237789696.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 5/40 | loss = 24237787545.6000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 6/40 | loss = 24237760853.3333; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 7/40 | loss = 24237743835.4286; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 8/40 | loss = 24237724928.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 9/40 | loss = 24237714545.7778; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 10/40 | loss = 24237708083.2000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 11/40 | loss = 24237684922.1818; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 12/40 | loss = 24237663914.6667; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 13/40 | loss = 24237648187.0769; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 14/40 | loss = 24237634560.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 15/40 | loss = 24237622067.2000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 16/40 | loss = 24237601664.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 17/40 | loss = 24237583299.7647; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 18/40 | loss = 24237566065.7778; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 19/40 | loss = 24237549999.1579; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 20/40 | loss = 24237538201.6000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 21/40 | loss = 24237517970.2857; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 22/40 | loss = 24237500043.6364; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 23/40 | loss = 24237483408.6957; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 24/40 | loss = 24237467989.3333; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 25/40 | loss = 24237455114.2400; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 26/40 | loss = 24237436219.0769; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 27/40 | loss = 24237417813.3333; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 28/40 | loss = 24237401819.4286; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 29/40 | loss = 24237385586.7586; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 30/40 | loss = 24237370299.7333; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 31/40 | loss = 24237350912.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 32/40 | loss = 24237334016.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 33/40 | loss = 24237317026.9091; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 34/40 | loss = 24237301097.4118; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 35/40 | loss = 24237285610.0571; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 36/40 | loss = 24237266773.3333; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 37/40 | loss = 24237248899.4595; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 38/40 | loss = 24237232505.2632; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 39/40 | loss = 24237216426.6667; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 40/40 | loss = 24237201305.6000; \n",
      "[2023-02-16 19:34:04] (32625) {2092133410.py:18}INFO - Communication round 16/50\n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 0 | Dataset ID: 0 | 5/5 | loss = 0.0342; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 1 | Dataset ID: 1 | 5/5 | loss = 0.0309; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 2 | Dataset ID: 2 | 5/5 | loss = 0.0283; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 3 | Dataset ID: 3 | 5/5 | loss = 0.0290; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 4 | Dataset ID: 4 | 5/5 | loss = 0.0266; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 5 | Dataset ID: 5 | 5/5 | loss = 0.0261; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 6 | Dataset ID: 6 | 5/5 | loss = 0.0257; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 7 | Dataset ID: 7 | 5/5 | loss = 0.0258; \n",
      "[2023-02-16 19:34:04] (32625) {2092133410.py:18}INFO - Communication round 17/50\n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 0 | Dataset ID: 0 | 5/5 | loss = 0.0289; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 1 | Dataset ID: 1 | 5/5 | loss = 0.0261; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 2 | Dataset ID: 2 | 5/5 | loss = 0.0237; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 3 | Dataset ID: 3 | 5/5 | loss = 0.0238; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 4 | Dataset ID: 4 | 5/5 | loss = 0.0219; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 5 | Dataset ID: 5 | 5/5 | loss = 0.0216; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 6 | Dataset ID: 6 | 5/5 | loss = 0.0217; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 7 | Dataset ID: 7 | 5/5 | loss = 0.0220; \n",
      "[2023-02-16 19:34:04] (32625) {2092133410.py:18}INFO - Communication round 18/50\n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 0 | Dataset ID: 0 | 5/5 | loss = 0.0317; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 1 | Dataset ID: 1 | 5/5 | loss = 0.0273; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 2 | Dataset ID: 2 | 5/5 | loss = 0.0239; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 3 | Dataset ID: 3 | 5/5 | loss = 0.0237; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 4 | Dataset ID: 4 | 5/5 | loss = 0.0215; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 5 | Dataset ID: 5 | 5/5 | loss = 0.0209; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 6 | Dataset ID: 6 | 5/5 | loss = 0.0205; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 7 | Dataset ID: 7 | 5/5 | loss = 0.0216; \n",
      "[2023-02-16 19:34:04] (32625) {2092133410.py:18}INFO - Communication round 19/50\n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 0 | Dataset ID: 0 | 5/5 | loss = 0.0181; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 1 | Dataset ID: 1 | 5/5 | loss = 0.0176; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 2 | Dataset ID: 2 | 5/5 | loss = 0.0167; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 3 | Dataset ID: 3 | 5/5 | loss = 0.0173; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 4 | Dataset ID: 4 | 5/5 | loss = 0.0160; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 5 | Dataset ID: 5 | 5/5 | loss = 0.0159; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 6 | Dataset ID: 6 | 5/5 | loss = 0.0160; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 7 | Dataset ID: 7 | 5/5 | loss = 0.0166; \n",
      "[2023-02-16 19:34:04] (32625) {2092133410.py:18}INFO - Communication round 20/50\n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 0 | Dataset ID: 0 | 5/5 | loss = 0.0191; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 1 | Dataset ID: 1 | 5/5 | loss = 0.0172; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 2 | Dataset ID: 2 | 5/5 | loss = 0.0163; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 3 | Dataset ID: 3 | 5/5 | loss = 0.0168; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 4 | Dataset ID: 4 | 5/5 | loss = 0.0154; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 5 | Dataset ID: 5 | 5/5 | loss = 0.0153; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 6 | Dataset ID: 6 | 5/5 | loss = 0.0151; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 7 | Dataset ID: 7 | 5/5 | loss = 0.0156; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 1/40 | loss = 10586711654400.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 2/40 | loss = 10586711654400.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 3/40 | loss = 10586711304874.6660; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 4/40 | loss = 10586711392256.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 5/40 | loss = 10586711234969.5996; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 6/40 | loss = 10586712003925.3340; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 7/40 | loss = 10586712553179.4277; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 8/40 | loss = 10586713096192.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 9/40 | loss = 10586713402026.6660; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 10/40 | loss = 10586713646694.4004; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 11/40 | loss = 10586714228177.4551; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 12/40 | loss = 10586714712746.6660; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 13/40 | loss = 10586715122766.7695; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 14/40 | loss = 10586715474212.5723; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 15/40 | loss = 10586715778798.9336; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 16/40 | loss = 10586716307456.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 17/40 | loss = 10586716773918.1172; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 18/40 | loss = 10586717188551.1113; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 19/40 | loss = 10586717559538.5254; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 20/40 | loss = 10586717893427.1992; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 21/40 | loss = 10586718395245.7148; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 22/40 | loss = 10586718803781.8184; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 23/40 | loss = 10586719176793.0430; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 24/40 | loss = 10586719562410.6660; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 25/40 | loss = 10586719875235.8398; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 26/40 | loss = 10586720405976.6152; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 27/40 | loss = 10586720858567.1113; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 28/40 | loss = 10586721278829.7148; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 29/40 | loss = 10586721706266.4824; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 30/40 | loss = 10586722105207.4668; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 31/40 | loss = 10586722579885.4199; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 32/40 | loss = 10586722992128.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 33/40 | loss = 10586723411161.2129; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 34/40 | loss = 10586723774704.9414; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 35/40 | loss = 10586724147434.0566; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 36/40 | loss = 10586724645091.5547; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 37/40 | loss = 10586725115848.6484; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 38/40 | loss = 10586725534234.9473; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 39/40 | loss = 10586725931165.5391; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 40/40 | loss = 10586726334464.0000; \n",
      "[2023-02-16 19:34:04] (32625) {2092133410.py:18}INFO - Communication round 21/50\n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 0 | Dataset ID: 0 | 5/5 | loss = 0.0160; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 1 | Dataset ID: 1 | 5/5 | loss = 0.0149; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 2 | Dataset ID: 2 | 5/5 | loss = 0.0138; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 3 | Dataset ID: 3 | 5/5 | loss = 0.0141; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 4 | Dataset ID: 4 | 5/5 | loss = 0.0129; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 5 | Dataset ID: 5 | 5/5 | loss = 0.0128; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 6 | Dataset ID: 6 | 5/5 | loss = 0.0128; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 7 | Dataset ID: 7 | 5/5 | loss = 0.0137; \n",
      "[2023-02-16 19:34:04] (32625) {2092133410.py:18}INFO - Communication round 22/50\n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 0 | Dataset ID: 0 | 5/5 | loss = 0.0155; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 1 | Dataset ID: 1 | 5/5 | loss = 0.0161; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 2 | Dataset ID: 2 | 5/5 | loss = 0.0147; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 3 | Dataset ID: 3 | 5/5 | loss = 0.0152; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 4 | Dataset ID: 4 | 5/5 | loss = 0.0139; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 5 | Dataset ID: 5 | 5/5 | loss = 0.0136; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 6 | Dataset ID: 6 | 5/5 | loss = 0.0133; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 7 | Dataset ID: 7 | 5/5 | loss = 0.0131; \n",
      "[2023-02-16 19:34:04] (32625) {2092133410.py:18}INFO - Communication round 23/50\n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 0 | Dataset ID: 0 | 5/5 | loss = 0.0175; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 1 | Dataset ID: 1 | 5/5 | loss = 0.0146; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 2 | Dataset ID: 2 | 5/5 | loss = 0.0133; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 3 | Dataset ID: 3 | 5/5 | loss = 0.0131; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 4 | Dataset ID: 4 | 5/5 | loss = 0.0118; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 5 | Dataset ID: 5 | 5/5 | loss = 0.0116; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 6 | Dataset ID: 6 | 5/5 | loss = 0.0114; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 7 | Dataset ID: 7 | 5/5 | loss = 0.0120; \n",
      "[2023-02-16 19:34:04] (32625) {2092133410.py:18}INFO - Communication round 24/50\n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 0 | Dataset ID: 0 | 5/5 | loss = 0.0118; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 1 | Dataset ID: 1 | 5/5 | loss = 0.0114; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 2 | Dataset ID: 2 | 5/5 | loss = 0.0107; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 3 | Dataset ID: 3 | 5/5 | loss = 0.0111; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 4 | Dataset ID: 4 | 5/5 | loss = 0.0102; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 5 | Dataset ID: 5 | 5/5 | loss = 0.0101; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 6 | Dataset ID: 6 | 5/5 | loss = 0.0099; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 7 | Dataset ID: 7 | 5/5 | loss = 0.0100; \n",
      "[2023-02-16 19:34:04] (32625) {2092133410.py:18}INFO - Communication round 25/50\n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 0 | Dataset ID: 0 | 5/5 | loss = 0.0153; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 1 | Dataset ID: 1 | 5/5 | loss = 0.0123; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 2 | Dataset ID: 2 | 5/5 | loss = 0.0111; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 3 | Dataset ID: 3 | 5/5 | loss = 0.0108; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 4 | Dataset ID: 4 | 5/5 | loss = 0.0097; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 5 | Dataset ID: 5 | 5/5 | loss = 0.0095; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 6 | Dataset ID: 6 | 5/5 | loss = 0.0093; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 7 | Dataset ID: 7 | 5/5 | loss = 0.0096; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 1/40 | loss = 927185057611776.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 2/40 | loss = 927185124720640.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 3/40 | loss = 927185102351018.6250; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 4/40 | loss = 927185091166208.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 5/40 | loss = 927185111298867.2500; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 6/40 | loss = 927185102351018.6250; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 7/40 | loss = 927185095959698.2500; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 8/40 | loss = 927185091166208.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 9/40 | loss = 927185087437937.7500; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 10/40 | loss = 927185084455321.6250; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 11/40 | loss = 927185082014999.2500; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 12/40 | loss = 927185079981397.3750; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 13/40 | loss = 927185078260657.2500; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 14/40 | loss = 927185076785737.1250; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 15/40 | loss = 927185075507473.1250; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 16/40 | loss = 927185074388992.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 17/40 | loss = 927185073402097.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 18/40 | loss = 927185072524856.8750; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 19/40 | loss = 927185071739957.8750; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 20/40 | loss = 927185071033548.7500; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 21/40 | loss = 927185070394416.7500; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 22/40 | loss = 927185069813387.6250; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 23/40 | loss = 927185069282882.7500; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 24/40 | loss = 927185068796586.6250; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 25/40 | loss = 927185068349194.2500; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 26/40 | loss = 927185067936216.6250; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 27/40 | loss = 927185067553829.8750; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 28/40 | loss = 927185067198756.6250; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 29/40 | loss = 927185064554072.2500; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 30/40 | loss = 927185062085700.2500; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 31/40 | loss = 927185055446973.8750; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 32/40 | loss = 927185053417472.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 33/40 | loss = 927185045410164.3750; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 34/40 | loss = 927185039847665.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 35/40 | loss = 927185034603022.6250; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 36/40 | loss = 927185027785614.2500; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 37/40 | loss = 927185021336714.3750; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 38/40 | loss = 927185015227230.3750; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 39/40 | loss = 927185009431053.1250; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 40/40 | loss = 927185003924684.7500; \n",
      "[2023-02-16 19:34:04] (32625) {2092133410.py:18}INFO - Communication round 26/50\n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 0 | Dataset ID: 0 | 5/5 | loss = 0.0100; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 1 | Dataset ID: 1 | 5/5 | loss = 0.0095; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 2 | Dataset ID: 2 | 5/5 | loss = 0.0090; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 3 | Dataset ID: 3 | 5/5 | loss = 0.0091; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 4 | Dataset ID: 4 | 5/5 | loss = 0.0083; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 5 | Dataset ID: 5 | 5/5 | loss = 0.0082; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 6 | Dataset ID: 6 | 5/5 | loss = 0.0081; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 7 | Dataset ID: 7 | 5/5 | loss = 0.0084; \n",
      "[2023-02-16 19:34:04] (32625) {2092133410.py:18}INFO - Communication round 27/50\n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 0 | Dataset ID: 0 | 5/5 | loss = 0.0130; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 1 | Dataset ID: 1 | 5/5 | loss = 0.0112; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 2 | Dataset ID: 2 | 5/5 | loss = 0.0098; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 3 | Dataset ID: 3 | 5/5 | loss = 0.0093; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 4 | Dataset ID: 4 | 5/5 | loss = 0.0084; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 5 | Dataset ID: 5 | 5/5 | loss = 0.0080; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 6 | Dataset ID: 6 | 5/5 | loss = 0.0078; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 7 | Dataset ID: 7 | 5/5 | loss = 0.0080; \n",
      "[2023-02-16 19:34:04] (32625) {2092133410.py:18}INFO - Communication round 28/50\n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 0 | Dataset ID: 0 | 5/5 | loss = 0.0086; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 1 | Dataset ID: 1 | 5/5 | loss = 0.0087; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 2 | Dataset ID: 2 | 5/5 | loss = 0.0080; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 3 | Dataset ID: 3 | 5/5 | loss = 0.0080; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 4 | Dataset ID: 4 | 5/5 | loss = 0.0073; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 5 | Dataset ID: 5 | 5/5 | loss = 0.0071; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 6 | Dataset ID: 6 | 5/5 | loss = 0.0070; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 7 | Dataset ID: 7 | 5/5 | loss = 0.0072; \n",
      "[2023-02-16 19:34:04] (32625) {2092133410.py:18}INFO - Communication round 29/50\n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 0 | Dataset ID: 0 | 5/5 | loss = 0.0081; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 1 | Dataset ID: 1 | 5/5 | loss = 0.0077; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 2 | Dataset ID: 2 | 5/5 | loss = 0.0072; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 3 | Dataset ID: 3 | 5/5 | loss = 0.0072; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 4 | Dataset ID: 4 | 5/5 | loss = 0.0066; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 5 | Dataset ID: 5 | 5/5 | loss = 0.0065; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 6 | Dataset ID: 6 | 5/5 | loss = 0.0063; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 7 | Dataset ID: 7 | 5/5 | loss = 0.0063; \n",
      "[2023-02-16 19:34:04] (32625) {2092133410.py:18}INFO - Communication round 30/50\n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 0 | Dataset ID: 0 | 5/5 | loss = 0.0083; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 1 | Dataset ID: 1 | 5/5 | loss = 0.0069; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 2 | Dataset ID: 2 | 5/5 | loss = 0.0064; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 3 | Dataset ID: 3 | 5/5 | loss = 0.0063; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 4 | Dataset ID: 4 | 5/5 | loss = 0.0058; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 5 | Dataset ID: 5 | 5/5 | loss = 0.0057; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 6 | Dataset ID: 6 | 5/5 | loss = 0.0056; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 7 | Dataset ID: 7 | 5/5 | loss = 0.0057; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 1/40 | loss = 14616510295179264.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 2/40 | loss = 14616510295179264.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 3/40 | loss = 14616510295179264.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 4/40 | loss = 14616510295179264.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 5/40 | loss = 14616510295179264.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 6/40 | loss = 14616510295179264.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 7/40 | loss = 14616510295179264.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 8/40 | loss = 14616510295179264.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 9/40 | loss = 14616510295179264.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 10/40 | loss = 14616510295179264.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 11/40 | loss = 14616510295179264.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 12/40 | loss = 14616510295179264.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 13/40 | loss = 14616510295179264.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 14/40 | loss = 14616510295179264.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 15/40 | loss = 14616510295179264.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 16/40 | loss = 14616510295179264.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 17/40 | loss = 14616510295179264.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 18/40 | loss = 14616510295179264.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 19/40 | loss = 14616510295179264.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 20/40 | loss = 14616510295179264.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 21/40 | loss = 14616510295179264.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 22/40 | loss = 14616510295179264.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 23/40 | loss = 14616510295179264.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 24/40 | loss = 14616510295179264.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 25/40 | loss = 14616510295179264.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 26/40 | loss = 14616510295179264.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 27/40 | loss = 14616510295179264.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 28/40 | loss = 14616510295179264.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 29/40 | loss = 14616510295179264.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 30/40 | loss = 14616510295179264.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 31/40 | loss = 14616510295179264.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 32/40 | loss = 14616510295179264.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 33/40 | loss = 14616510295179264.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 34/40 | loss = 14616510295179264.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 35/40 | loss = 14616510295179264.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 36/40 | loss = 14616510295179264.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 37/40 | loss = 14616510295179264.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 38/40 | loss = 14616510295179264.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 39/40 | loss = 14616510295179264.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 40/40 | loss = 14616510295179264.0000; \n",
      "[2023-02-16 19:34:04] (32625) {2092133410.py:18}INFO - Communication round 31/50\n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 0 | Dataset ID: 0 | 5/5 | loss = 0.0067; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 1 | Dataset ID: 1 | 5/5 | loss = 0.0059; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 2 | Dataset ID: 2 | 5/5 | loss = 0.0058; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 3 | Dataset ID: 3 | 5/5 | loss = 0.0058; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 4 | Dataset ID: 4 | 5/5 | loss = 0.0054; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 5 | Dataset ID: 5 | 5/5 | loss = 0.0053; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 6 | Dataset ID: 6 | 5/5 | loss = 0.0052; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 7 | Dataset ID: 7 | 5/5 | loss = 0.0054; \n",
      "[2023-02-16 19:34:04] (32625) {2092133410.py:18}INFO - Communication round 32/50\n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 0 | Dataset ID: 0 | 5/5 | loss = 0.0056; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 1 | Dataset ID: 1 | 5/5 | loss = 0.0055; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 2 | Dataset ID: 2 | 5/5 | loss = 0.0052; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 3 | Dataset ID: 3 | 5/5 | loss = 0.0053; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 4 | Dataset ID: 4 | 5/5 | loss = 0.0049; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 5 | Dataset ID: 5 | 5/5 | loss = 0.0048; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 6 | Dataset ID: 6 | 5/5 | loss = 0.0047; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 7 | Dataset ID: 7 | 5/5 | loss = 0.0050; \n",
      "[2023-02-16 19:34:04] (32625) {2092133410.py:18}INFO - Communication round 33/50\n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 0 | Dataset ID: 0 | 5/5 | loss = 0.0066; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 1 | Dataset ID: 1 | 5/5 | loss = 0.0056; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 2 | Dataset ID: 2 | 5/5 | loss = 0.0052; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 3 | Dataset ID: 3 | 5/5 | loss = 0.0052; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 4 | Dataset ID: 4 | 5/5 | loss = 0.0048; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 5 | Dataset ID: 5 | 5/5 | loss = 0.0047; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 6 | Dataset ID: 6 | 5/5 | loss = 0.0046; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 7 | Dataset ID: 7 | 5/5 | loss = 0.0048; \n",
      "[2023-02-16 19:34:04] (32625) {2092133410.py:18}INFO - Communication round 34/50\n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 0 | Dataset ID: 0 | 5/5 | loss = 0.0054; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 1 | Dataset ID: 1 | 5/5 | loss = 0.0048; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 2 | Dataset ID: 2 | 5/5 | loss = 0.0046; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 3 | Dataset ID: 3 | 5/5 | loss = 0.0047; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 4 | Dataset ID: 4 | 5/5 | loss = 0.0044; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 5 | Dataset ID: 5 | 5/5 | loss = 0.0043; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 6 | Dataset ID: 6 | 5/5 | loss = 0.0042; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 7 | Dataset ID: 7 | 5/5 | loss = 0.0043; \n",
      "[2023-02-16 19:34:04] (32625) {2092133410.py:18}INFO - Communication round 35/50\n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 0 | Dataset ID: 0 | 5/5 | loss = 0.0062; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 1 | Dataset ID: 1 | 5/5 | loss = 0.0050; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 2 | Dataset ID: 2 | 5/5 | loss = 0.0047; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 3 | Dataset ID: 3 | 5/5 | loss = 0.0046; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 4 | Dataset ID: 4 | 5/5 | loss = 0.0042; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 5 | Dataset ID: 5 | 5/5 | loss = 0.0042; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 6 | Dataset ID: 6 | 5/5 | loss = 0.0041; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 7 | Dataset ID: 7 | 5/5 | loss = 0.0042; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 1/40 | loss = 36140783996239872.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 2/40 | loss = 36140783996239872.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 3/40 | loss = 36140783996239872.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 4/40 | loss = 36140783996239872.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 5/40 | loss = 36140783996239872.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 6/40 | loss = 36140783996239872.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 7/40 | loss = 36140783996239872.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 8/40 | loss = 36140783996239872.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 9/40 | loss = 36140783996239872.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 10/40 | loss = 36140783996239872.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 11/40 | loss = 36140783996239872.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 12/40 | loss = 36140783996239872.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 13/40 | loss = 36140783996239872.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 14/40 | loss = 36140783996239872.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 15/40 | loss = 36140783996239872.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 16/40 | loss = 36140783996239872.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 17/40 | loss = 36140783996239872.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 18/40 | loss = 36140783996239872.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 19/40 | loss = 36140783996239872.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 20/40 | loss = 36140783996239872.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 21/40 | loss = 36140783996239872.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 22/40 | loss = 36140783996239872.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 23/40 | loss = 36140783996239872.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 24/40 | loss = 36140783996239872.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 25/40 | loss = 36140783996239872.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 26/40 | loss = 36140783996239872.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 27/40 | loss = 36140783996239872.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 28/40 | loss = 36140783996239872.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 29/40 | loss = 36140783996239872.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 30/40 | loss = 36140783996239872.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 31/40 | loss = 36140783996239872.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 32/40 | loss = 36140783996239872.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 33/40 | loss = 36140783996239872.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 34/40 | loss = 36140783996239872.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 35/40 | loss = 36140783996239872.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 36/40 | loss = 36140783996239872.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 37/40 | loss = 36140783996239872.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 38/40 | loss = 36140783996239872.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 39/40 | loss = 36140783996239872.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 40/40 | loss = 36140783996239872.0000; \n",
      "[2023-02-16 19:34:04] (32625) {2092133410.py:18}INFO - Communication round 36/50\n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 0 | Dataset ID: 0 | 5/5 | loss = 0.0046; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 1 | Dataset ID: 1 | 5/5 | loss = 0.0042; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 2 | Dataset ID: 2 | 5/5 | loss = 0.0041; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 3 | Dataset ID: 3 | 5/5 | loss = 0.0041; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 4 | Dataset ID: 4 | 5/5 | loss = 0.0038; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 5 | Dataset ID: 5 | 5/5 | loss = 0.0038; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 6 | Dataset ID: 6 | 5/5 | loss = 0.0037; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 7 | Dataset ID: 7 | 5/5 | loss = 0.0037; \n",
      "[2023-02-16 19:34:04] (32625) {2092133410.py:18}INFO - Communication round 37/50\n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 0 | Dataset ID: 0 | 5/5 | loss = 0.0040; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 1 | Dataset ID: 1 | 5/5 | loss = 0.0041; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 2 | Dataset ID: 2 | 5/5 | loss = 0.0040; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 3 | Dataset ID: 3 | 5/5 | loss = 0.0040; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 4 | Dataset ID: 4 | 5/5 | loss = 0.0037; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 5 | Dataset ID: 5 | 5/5 | loss = 0.0036; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 6 | Dataset ID: 6 | 5/5 | loss = 0.0036; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 7 | Dataset ID: 7 | 5/5 | loss = 0.0035; \n",
      "[2023-02-16 19:34:04] (32625) {2092133410.py:18}INFO - Communication round 38/50\n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 0 | Dataset ID: 0 | 5/5 | loss = 0.0049; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 1 | Dataset ID: 1 | 5/5 | loss = 0.0040; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 2 | Dataset ID: 2 | 5/5 | loss = 0.0039; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 3 | Dataset ID: 3 | 5/5 | loss = 0.0038; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 4 | Dataset ID: 4 | 5/5 | loss = 0.0036; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 5 | Dataset ID: 5 | 5/5 | loss = 0.0035; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 6 | Dataset ID: 6 | 5/5 | loss = 0.0035; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 7 | Dataset ID: 7 | 5/5 | loss = 0.0035; \n",
      "[2023-02-16 19:34:04] (32625) {2092133410.py:18}INFO - Communication round 39/50\n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 0 | Dataset ID: 0 | 5/5 | loss = 0.0034; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 1 | Dataset ID: 1 | 5/5 | loss = 0.0034; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 2 | Dataset ID: 2 | 5/5 | loss = 0.0034; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 3 | Dataset ID: 3 | 5/5 | loss = 0.0034; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 4 | Dataset ID: 4 | 5/5 | loss = 0.0032; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 5 | Dataset ID: 5 | 5/5 | loss = 0.0032; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 6 | Dataset ID: 6 | 5/5 | loss = 0.0031; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 7 | Dataset ID: 7 | 5/5 | loss = 0.0031; \n",
      "[2023-02-16 19:34:04] (32625) {2092133410.py:18}INFO - Communication round 40/50\n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 0 | Dataset ID: 0 | 5/5 | loss = 0.0034; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 1 | Dataset ID: 1 | 5/5 | loss = 0.0031; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 2 | Dataset ID: 2 | 5/5 | loss = 0.0032; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 3 | Dataset ID: 3 | 5/5 | loss = 0.0033; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 4 | Dataset ID: 4 | 5/5 | loss = 0.0031; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 5 | Dataset ID: 5 | 5/5 | loss = 0.0031; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 6 | Dataset ID: 6 | 5/5 | loss = 0.0030; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 7 | Dataset ID: 7 | 5/5 | loss = 0.0029; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 1/40 | loss = 11698110082318336.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 2/40 | loss = 11698110082318336.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 3/40 | loss = 11698110082318336.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 4/40 | loss = 11698110082318336.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 5/40 | loss = 11698110082318336.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 6/40 | loss = 11698110082318336.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 7/40 | loss = 11698110082318336.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 8/40 | loss = 11698110082318336.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 9/40 | loss = 11698110082318336.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 10/40 | loss = 11698110082318336.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 11/40 | loss = 11698110082318336.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 12/40 | loss = 11698110082318336.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 13/40 | loss = 11698110082318336.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 14/40 | loss = 11698110082318336.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 15/40 | loss = 11698110082318336.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 16/40 | loss = 11698110082318336.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 17/40 | loss = 11698110082318336.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 18/40 | loss = 11698110082318336.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 19/40 | loss = 11698110082318336.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 20/40 | loss = 11698110082318336.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 21/40 | loss = 11698110082318336.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 22/40 | loss = 11698110082318336.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 23/40 | loss = 11698110082318336.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 24/40 | loss = 11698110082318336.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 25/40 | loss = 11698110082318336.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 26/40 | loss = 11698110082318336.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 27/40 | loss = 11698110082318336.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 28/40 | loss = 11698110082318336.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 29/40 | loss = 11698110082318336.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 30/40 | loss = 11698110082318336.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 31/40 | loss = 11698110082318336.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 32/40 | loss = 11698110082318336.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 33/40 | loss = 11698110082318336.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 34/40 | loss = 11698110082318336.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 35/40 | loss = 11698110082318336.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 36/40 | loss = 11698110082318336.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 37/40 | loss = 11698110082318336.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 38/40 | loss = 11698110082318336.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 39/40 | loss = 11698110082318336.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 40/40 | loss = 11698110082318336.0000; \n",
      "[2023-02-16 19:34:04] (32625) {2092133410.py:18}INFO - Communication round 41/50\n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 0 | Dataset ID: 0 | 5/5 | loss = 0.0038; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 1 | Dataset ID: 1 | 5/5 | loss = 0.0032; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 2 | Dataset ID: 2 | 5/5 | loss = 0.0031; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 3 | Dataset ID: 3 | 5/5 | loss = 0.0031; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 4 | Dataset ID: 4 | 5/5 | loss = 0.0030; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 5 | Dataset ID: 5 | 5/5 | loss = 0.0030; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 6 | Dataset ID: 6 | 5/5 | loss = 0.0029; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 7 | Dataset ID: 7 | 5/5 | loss = 0.0028; \n",
      "[2023-02-16 19:34:04] (32625) {2092133410.py:18}INFO - Communication round 42/50\n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 0 | Dataset ID: 0 | 5/5 | loss = 0.0032; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 1 | Dataset ID: 1 | 5/5 | loss = 0.0031; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 2 | Dataset ID: 2 | 5/5 | loss = 0.0030; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 3 | Dataset ID: 3 | 5/5 | loss = 0.0031; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 4 | Dataset ID: 4 | 5/5 | loss = 0.0029; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 5 | Dataset ID: 5 | 5/5 | loss = 0.0029; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 6 | Dataset ID: 6 | 5/5 | loss = 0.0029; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 7 | Dataset ID: 7 | 5/5 | loss = 0.0028; \n",
      "[2023-02-16 19:34:04] (32625) {2092133410.py:18}INFO - Communication round 43/50\n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 0 | Dataset ID: 0 | 5/5 | loss = 0.0045; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 1 | Dataset ID: 1 | 5/5 | loss = 0.0035; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 2 | Dataset ID: 2 | 5/5 | loss = 0.0033; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 3 | Dataset ID: 3 | 5/5 | loss = 0.0032; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 4 | Dataset ID: 4 | 5/5 | loss = 0.0030; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 5 | Dataset ID: 5 | 5/5 | loss = 0.0030; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 6 | Dataset ID: 6 | 5/5 | loss = 0.0029; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 7 | Dataset ID: 7 | 5/5 | loss = 0.0028; \n",
      "[2023-02-16 19:34:04] (32625) {2092133410.py:18}INFO - Communication round 44/50\n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 0 | Dataset ID: 0 | 5/5 | loss = 0.0031; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 1 | Dataset ID: 1 | 5/5 | loss = 0.0028; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 2 | Dataset ID: 2 | 5/5 | loss = 0.0028; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 3 | Dataset ID: 3 | 5/5 | loss = 0.0029; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 4 | Dataset ID: 4 | 5/5 | loss = 0.0027; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 5 | Dataset ID: 5 | 5/5 | loss = 0.0027; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 6 | Dataset ID: 6 | 5/5 | loss = 0.0026; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 7 | Dataset ID: 7 | 5/5 | loss = 0.0025; \n",
      "[2023-02-16 19:34:04] (32625) {2092133410.py:18}INFO - Communication round 45/50\n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 0 | Dataset ID: 0 | 5/5 | loss = 0.0036; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 1 | Dataset ID: 1 | 5/5 | loss = 0.0030; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 2 | Dataset ID: 2 | 5/5 | loss = 0.0029; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 3 | Dataset ID: 3 | 5/5 | loss = 0.0029; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 4 | Dataset ID: 4 | 5/5 | loss = 0.0027; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 5 | Dataset ID: 5 | 5/5 | loss = 0.0027; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 6 | Dataset ID: 6 | 5/5 | loss = 0.0026; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 7 | Dataset ID: 7 | 5/5 | loss = 0.0025; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 1/40 | loss = 387394708701184.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 2/40 | loss = 387394708701184.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 3/40 | loss = 387394708701184.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 4/40 | loss = 387394708701184.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 5/40 | loss = 387394708701184.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 6/40 | loss = 387394680739157.3125; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 7/40 | loss = 387394660766281.1250; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 8/40 | loss = 387394645786624.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 9/40 | loss = 387394634135779.5625; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 10/40 | loss = 387394624815104.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 11/40 | loss = 387394614138693.8125; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 12/40 | loss = 387394605241685.3125; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 13/40 | loss = 387394597713447.3750; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 14/40 | loss = 387394591260672.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 15/40 | loss = 387394585668266.6875; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 16/40 | loss = 387394580774912.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 17/40 | loss = 387394576457246.1250; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 18/40 | loss = 387394572619320.8750; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 19/40 | loss = 387394569185387.8125; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 20/40 | loss = 387394566094848.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 21/40 | loss = 387394563298645.3125; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 22/40 | loss = 387394560756642.9375; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 23/40 | loss = 387394558435684.1875; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 24/40 | loss = 387394556308138.6875; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 25/40 | loss = 387394554350796.8125; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 26/40 | loss = 387394552544019.6875; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 27/40 | loss = 387394550871077.9375; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 28/40 | loss = 387394549317632.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 29/40 | loss = 387394547871320.2500; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 30/40 | loss = 387394546521429.3125; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 31/40 | loss = 387394544176227.1250; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 32/40 | loss = 387394541977600.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 33/40 | loss = 387394539912223.0000; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 34/40 | loss = 387394537968338.8125; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 35/40 | loss = 387394535176835.6875; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 36/40 | loss = 387394528812145.7500; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 37/40 | loss = 387394522791493.1875; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 38/40 | loss = 387394517087717.0625; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 39/40 | loss = 387394511676442.2500; \n",
      "[2023-02-16 19:34:04] (32625) {simulator.py:208}INFO - Test | 40/40 | loss = 387394506535731.1875; \n",
      "[2023-02-16 19:34:04] (32625) {2092133410.py:18}INFO - Communication round 46/50\n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 0 | Dataset ID: 0 | 5/5 | loss = 0.0032; \n",
      "[2023-02-16 19:34:04] (32625) {worker.py:220}INFO -  Train | Worker ID: 1 | Dataset ID: 1 | 5/5 | loss = 0.0027; \n",
      "[2023-02-16 19:34:05] (32625) {worker.py:220}INFO -  Train | Worker ID: 2 | Dataset ID: 2 | 5/5 | loss = 0.0027; \n",
      "[2023-02-16 19:34:05] (32625) {worker.py:220}INFO -  Train | Worker ID: 3 | Dataset ID: 3 | 5/5 | loss = 0.0027; \n",
      "[2023-02-16 19:34:05] (32625) {worker.py:220}INFO -  Train | Worker ID: 4 | Dataset ID: 4 | 5/5 | loss = 0.0026; \n",
      "[2023-02-16 19:34:05] (32625) {worker.py:220}INFO -  Train | Worker ID: 5 | Dataset ID: 5 | 5/5 | loss = 0.0025; \n",
      "[2023-02-16 19:34:05] (32625) {worker.py:220}INFO -  Train | Worker ID: 6 | Dataset ID: 6 | 5/5 | loss = 0.0025; \n",
      "[2023-02-16 19:34:05] (32625) {worker.py:220}INFO -  Train | Worker ID: 7 | Dataset ID: 7 | 5/5 | loss = 0.0024; \n",
      "[2023-02-16 19:34:05] (32625) {2092133410.py:18}INFO - Communication round 47/50\n",
      "[2023-02-16 19:34:05] (32625) {worker.py:220}INFO -  Train | Worker ID: 0 | Dataset ID: 0 | 5/5 | loss = 0.0031; \n",
      "[2023-02-16 19:34:05] (32625) {worker.py:220}INFO -  Train | Worker ID: 1 | Dataset ID: 1 | 5/5 | loss = 0.0027; \n",
      "[2023-02-16 19:34:05] (32625) {worker.py:220}INFO -  Train | Worker ID: 2 | Dataset ID: 2 | 5/5 | loss = 0.0027; \n",
      "[2023-02-16 19:34:05] (32625) {worker.py:220}INFO -  Train | Worker ID: 3 | Dataset ID: 3 | 5/5 | loss = 0.0027; \n",
      "[2023-02-16 19:34:05] (32625) {worker.py:220}INFO -  Train | Worker ID: 4 | Dataset ID: 4 | 5/5 | loss = 0.0026; \n",
      "[2023-02-16 19:34:05] (32625) {worker.py:220}INFO -  Train | Worker ID: 5 | Dataset ID: 5 | 5/5 | loss = 0.0025; \n",
      "[2023-02-16 19:34:05] (32625) {worker.py:220}INFO -  Train | Worker ID: 6 | Dataset ID: 6 | 5/5 | loss = 0.0024; \n",
      "[2023-02-16 19:34:05] (32625) {worker.py:220}INFO -  Train | Worker ID: 7 | Dataset ID: 7 | 5/5 | loss = 0.0024; \n",
      "[2023-02-16 19:34:05] (32625) {2092133410.py:18}INFO - Communication round 48/50\n",
      "[2023-02-16 19:34:05] (32625) {worker.py:220}INFO -  Train | Worker ID: 0 | Dataset ID: 0 | 5/5 | loss = 0.0026; \n",
      "[2023-02-16 19:34:05] (32625) {worker.py:220}INFO -  Train | Worker ID: 1 | Dataset ID: 1 | 5/5 | loss = 0.0024; \n",
      "[2023-02-16 19:34:05] (32625) {worker.py:220}INFO -  Train | Worker ID: 2 | Dataset ID: 2 | 5/5 | loss = 0.0025; \n",
      "[2023-02-16 19:34:05] (32625) {worker.py:220}INFO -  Train | Worker ID: 3 | Dataset ID: 3 | 5/5 | loss = 0.0025; \n",
      "[2023-02-16 19:34:05] (32625) {worker.py:220}INFO -  Train | Worker ID: 4 | Dataset ID: 4 | 5/5 | loss = 0.0024; \n",
      "[2023-02-16 19:34:05] (32625) {worker.py:220}INFO -  Train | Worker ID: 5 | Dataset ID: 5 | 5/5 | loss = 0.0024; \n",
      "[2023-02-16 19:34:05] (32625) {worker.py:220}INFO -  Train | Worker ID: 6 | Dataset ID: 6 | 5/5 | loss = 0.0023; \n",
      "[2023-02-16 19:34:05] (32625) {worker.py:220}INFO -  Train | Worker ID: 7 | Dataset ID: 7 | 5/5 | loss = 0.0023; \n",
      "[2023-02-16 19:34:05] (32625) {2092133410.py:18}INFO - Communication round 49/50\n",
      "[2023-02-16 19:34:05] (32625) {worker.py:220}INFO -  Train | Worker ID: 0 | Dataset ID: 0 | 5/5 | loss = 0.0031; \n",
      "[2023-02-16 19:34:05] (32625) {worker.py:220}INFO -  Train | Worker ID: 1 | Dataset ID: 1 | 5/5 | loss = 0.0025; \n",
      "[2023-02-16 19:34:05] (32625) {worker.py:220}INFO -  Train | Worker ID: 2 | Dataset ID: 2 | 5/5 | loss = 0.0025; \n",
      "[2023-02-16 19:34:05] (32625) {worker.py:220}INFO -  Train | Worker ID: 3 | Dataset ID: 3 | 5/5 | loss = 0.0025; \n",
      "[2023-02-16 19:34:05] (32625) {worker.py:220}INFO -  Train | Worker ID: 4 | Dataset ID: 4 | 5/5 | loss = 0.0024; \n",
      "[2023-02-16 19:34:05] (32625) {worker.py:220}INFO -  Train | Worker ID: 5 | Dataset ID: 5 | 5/5 | loss = 0.0024; \n",
      "[2023-02-16 19:34:05] (32625) {worker.py:220}INFO -  Train | Worker ID: 6 | Dataset ID: 6 | 5/5 | loss = 0.0023; \n",
      "[2023-02-16 19:34:05] (32625) {worker.py:220}INFO -  Train | Worker ID: 7 | Dataset ID: 7 | 5/5 | loss = 0.0023; \n",
      "[2023-02-16 19:34:05] (32625) {2092133410.py:18}INFO - Communication round 50/50\n",
      "[2023-02-16 19:34:05] (32625) {worker.py:220}INFO -  Train | Worker ID: 0 | Dataset ID: 0 | 5/5 | loss = 0.0027; \n",
      "[2023-02-16 19:34:05] (32625) {worker.py:220}INFO -  Train | Worker ID: 1 | Dataset ID: 1 | 5/5 | loss = 0.0024; \n",
      "[2023-02-16 19:34:05] (32625) {worker.py:220}INFO -  Train | Worker ID: 2 | Dataset ID: 2 | 5/5 | loss = 0.0024; \n",
      "[2023-02-16 19:34:05] (32625) {worker.py:220}INFO -  Train | Worker ID: 3 | Dataset ID: 3 | 5/5 | loss = 0.0024; \n",
      "[2023-02-16 19:34:05] (32625) {worker.py:220}INFO -  Train | Worker ID: 4 | Dataset ID: 4 | 5/5 | loss = 0.0023; \n",
      "[2023-02-16 19:34:05] (32625) {worker.py:220}INFO -  Train | Worker ID: 5 | Dataset ID: 5 | 5/5 | loss = 0.0023; \n",
      "[2023-02-16 19:34:05] (32625) {worker.py:220}INFO -  Train | Worker ID: 6 | Dataset ID: 6 | 5/5 | loss = 0.0022; \n",
      "[2023-02-16 19:34:05] (32625) {worker.py:220}INFO -  Train | Worker ID: 7 | Dataset ID: 7 | 5/5 | loss = 0.0022; \n",
      "[2023-02-16 19:34:05] (32625) {simulator.py:208}INFO - Test | 1/40 | loss = 921220546560.0000; \n",
      "[2023-02-16 19:34:05] (32625) {simulator.py:208}INFO - Test | 2/40 | loss = 921220612096.0000; \n",
      "[2023-02-16 19:34:05] (32625) {simulator.py:208}INFO - Test | 3/40 | loss = 921220633941.3334; \n",
      "[2023-02-16 19:34:05] (32625) {simulator.py:208}INFO - Test | 4/40 | loss = 921220644864.0000; \n",
      "[2023-02-16 19:34:05] (32625) {simulator.py:208}INFO - Test | 5/40 | loss = 921220651417.6000; \n",
      "[2023-02-16 19:34:05] (32625) {simulator.py:208}INFO - Test | 6/40 | loss = 921220917930.6666; \n",
      "[2023-02-16 19:34:05] (32625) {simulator.py:208}INFO - Test | 7/40 | loss = 921221108297.1428; \n",
      "[2023-02-16 19:34:05] (32625) {simulator.py:208}INFO - Test | 8/40 | loss = 921221251072.0000; \n",
      "[2023-02-16 19:34:05] (32625) {simulator.py:208}INFO - Test | 9/40 | loss = 921221362119.1111; \n",
      "[2023-02-16 19:34:05] (32625) {simulator.py:208}INFO - Test | 10/40 | loss = 921221450956.8000; \n",
      "[2023-02-16 19:34:05] (32625) {simulator.py:208}INFO - Test | 11/40 | loss = 921221654714.1818; \n",
      "[2023-02-16 19:34:05] (32625) {simulator.py:208}INFO - Test | 12/40 | loss = 921221835434.6666; \n",
      "[2023-02-16 19:34:05] (32625) {simulator.py:208}INFO - Test | 13/40 | loss = 921221978269.5385; \n",
      "[2023-02-16 19:34:05] (32625) {simulator.py:208}INFO - Test | 14/40 | loss = 921222100699.4286; \n",
      "[2023-02-16 19:34:05] (32625) {simulator.py:208}INFO - Test | 15/40 | loss = 921222206805.3334; \n",
      "[2023-02-16 19:34:05] (32625) {simulator.py:208}INFO - Test | 16/40 | loss = 921222397952.0000; \n",
      "[2023-02-16 19:34:05] (32625) {simulator.py:208}INFO - Test | 17/40 | loss = 921222566610.8235; \n",
      "[2023-02-16 19:34:05] (32625) {simulator.py:208}INFO - Test | 18/40 | loss = 921222723811.5555; \n",
      "[2023-02-16 19:34:05] (32625) {simulator.py:208}INFO - Test | 19/40 | loss = 921222857566.3158; \n",
      "[2023-02-16 19:34:05] (32625) {simulator.py:208}INFO - Test | 20/40 | loss = 921222977945.6000; \n",
      "[2023-02-16 19:34:05] (32625) {simulator.py:208}INFO - Test | 21/40 | loss = 921223161758.4762; \n",
      "[2023-02-16 19:34:05] (32625) {simulator.py:208}INFO - Test | 22/40 | loss = 921223328861.0909; \n",
      "[2023-02-16 19:34:05] (32625) {simulator.py:208}INFO - Test | 23/40 | loss = 921223481433.0435; \n",
      "[2023-02-16 19:34:05] (32625) {simulator.py:208}INFO - Test | 24/40 | loss = 921223626752.0000; \n",
      "[2023-02-16 19:34:05] (32625) {simulator.py:208}INFO - Test | 25/40 | loss = 921223755202.5601; \n",
      "[2023-02-16 19:34:05] (32625) {simulator.py:208}INFO - Test | 26/40 | loss = 921223934267.0769; \n",
      "[2023-02-16 19:34:05] (32625) {simulator.py:208}INFO - Test | 27/40 | loss = 921224104922.0741; \n",
      "[2023-02-16 19:34:05] (32625) {simulator.py:208}INFO - Test | 28/40 | loss = 921224263387.4286; \n",
      "[2023-02-16 19:34:05] (32625) {simulator.py:208}INFO - Test | 29/40 | loss = 921224406404.4138; \n",
      "[2023-02-16 19:34:05] (32625) {simulator.py:208}INFO - Test | 30/40 | loss = 921224544256.0000; \n",
      "[2023-02-16 19:34:05] (32625) {simulator.py:208}INFO - Test | 31/40 | loss = 921224723951.4839; \n",
      "[2023-02-16 19:34:05] (32625) {simulator.py:208}INFO - Test | 32/40 | loss = 921224888320.0000; \n",
      "[2023-02-16 19:34:05] (32625) {simulator.py:208}INFO - Test | 33/40 | loss = 921225042726.7878; \n",
      "[2023-02-16 19:34:05] (32625) {simulator.py:208}INFO - Test | 34/40 | loss = 921225191905.8823; \n",
      "[2023-02-16 19:34:05] (32625) {simulator.py:208}INFO - Test | 35/40 | loss = 921225328815.5428; \n",
      "[2023-02-16 19:34:05] (32625) {simulator.py:208}INFO - Test | 36/40 | loss = 921225501809.7778; \n",
      "[2023-02-16 19:34:05] (32625) {simulator.py:208}INFO - Test | 37/40 | loss = 921225668995.4595; \n",
      "[2023-02-16 19:34:05] (32625) {simulator.py:208}INFO - Test | 38/40 | loss = 921225823932.6316; \n",
      "[2023-02-16 19:34:05] (32625) {simulator.py:208}INFO - Test | 39/40 | loss = 921225970924.3077; \n",
      "[2023-02-16 19:34:05] (32625) {simulator.py:208}INFO - Test | 40/40 | loss = 921226110566.4000; \n"
     ]
    }
   ],
   "source": [
    "full_metrics = init_metrics_meter(metrics)\n",
    "model_dir = create_model_dir(args)\n",
    "# create model directory\n",
    "os.makedirs(model_dir, exist_ok=True)\n",
    "test_metric = test_evaluator.evaluate(0)\n",
    "extend_metrics_dict(\n",
    "    full_metrics, metric_to_dict(test_metric, metrics, 0, 'test'))\n",
    "\n",
    "# prepare progress snapshots\n",
    "trainer.set_data_loaders(1)\n",
    "for worker in trainer.workers:\n",
    "    worker.progress_frames = []\n",
    "    x, y = next(iter(worker.data_loader))\n",
    "    worker.fixed_x = x.to(worker.device)\n",
    "    worker.fixed_y = y.to(worker.device)\n",
    "\n",
    "for comm_round in range(1, args.comm_rounds + 1):\n",
    "    Logger.get().info(f\"Communication round {comm_round}/{args.comm_rounds}\")\n",
    "    train_metric = trainer.train(comm_round)\n",
    "    # add progress snapshots\n",
    "    for worker in trainer.workers:\n",
    "        y = worker.model(worker.fixed_x)\n",
    "        worker.progress_frames.append(y.detach())\n",
    "    extend_metrics_dict(\n",
    "        full_metrics, metric_to_dict(train_metric, metrics, comm_round, 'train'))\n",
    "    if comm_round % args.eval_every == 0 or comm_round == args.comm_rounds:\n",
    "        test_metric = test_evaluator.evaluate(comm_round)\n",
    "        extend_metrics_dict(\n",
    "            full_metrics, metric_to_dict(test_metric, metrics, comm_round, 'test'))\n",
    "#  store the run\n",
    "with open(os.path.join(\n",
    "        model_dir, 'full_metrics.json'), 'w') as f:\n",
    "    json.dump(full_metrics, f, indent=4)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "tags": []
   },
   "source": [
    "## Visualize"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[2023-02-17 10:37:39] (32625) {animation.py:1050}INFO - Animation.save using <class 'matplotlib.animation.FFMpegWriter'>\n",
      "[2023-02-17 10:37:39] (32625) {animation.py:328}INFO - MovieWriter._run: running command: ffmpeg -f rawvideo -vcodec rawvideo -s 1000x600 -pix_fmt rgba -r 10.0 -loglevel error -i pipe: -vcodec h264 -pix_fmt yuv420p -y simpson_paradox_fedregression.mp4\n"
     ]
    }
   ],
   "source": [
    "from matplotlib import animation\n",
    "from IPython.display import HTML\n",
    "\n",
    "plt.ioff()\n",
    "fig, ax = plt.subplots()\n",
    "\n",
    "def animate(progress_idx):\n",
    "    ax.cla()\n",
    "    dicts = []\n",
    "    for worker in trainer.workers:\n",
    "        frame = worker.progress_frames[progress_idx]\n",
    "        for x, y, y_pred in zip(worker.fixed_x.tolist(), worker.fixed_y.tolist(), frame.tolist()):\n",
    "            dicts.append({'worker_id': worker.worker_id, 'type': \"real\", 'x': x[0], 'y': y[0]})\n",
    "            dicts.append({'worker_id': worker.worker_id, 'type': \"fixed_x\", 'x': x[0], 'y': y_pred[0]})\n",
    "    df = pd.DataFrame(dicts)\n",
    "    # sns.scatterplot(x='x', y='y', hue='worker_id', style='type', palette='tab10', data=df, ax=ax, animated=True)\n",
    "    sns.scatterplot(x='x', y='y', hue='worker_id', palette='tab10', data=df[df['type'] == \"real\"], ax=ax, animated=True, legend=False)\n",
    "    sns.lineplot(x='x', y='y', hue='worker_id', palette='tab10', data=df[df['type'] == \"fixed_x\"], ax=ax, animated=True, legend=False)\n",
    "\n",
    "ani = animation.FuncAnimation(fig, animate, frames=len(trainer.workers[0].progress_frames), interval=100)\n",
    "# ani.save(\"simpson_paradox_fedregression.mp4\")\n",
    "HTML(ani.to_html5_video())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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UmP3Wfv27UlISOCTTz5hzpw5ng+i48ePs379eq9neidMmMCnn36K0+mkb9++FxRX5f4NBoOnTFEU3n777Sptq7tSq20cQ4cOBWDhwoX07NnTU/75559XGWhWnREjRvDwww/zj3/8gxYtWnieeR4xYgRfffUVmZmZXq+vyWRi2LBhbNu2ja5du1Z7xeJLcHAwvXr1YunSpbzwwguebUtKSrxGHp+vyte6pistjUZD37596dChAwsXLmTr1q3VJlxf5xDgrbfeuuAYhw0bxueff85XX33l1a388ccfX/A+L5YZM2Zw++238/PPP/P1118zZ84cNBqNp96f7+nz5XQ62bVrFwaDgdDQ0GrbqVSqKudz2bJlpKen06ZNG5/bhIeHc80115Cens69995LamoqnTp1uqD3f3X7aswk4TYiycnJPP744/z973/n6NGjjBkzhoiICLKysti4cSPBwcE89thjqNVqnnjiCWbNmsXkyZOZPXs2hYWFzJ07t0p33pQpU1i4cCHjxo3jnnvuoU+fPuh0OtLS0lizZg2TJk2qsdsKYOTIkej1em644QYeeOABKioqeOONNygoKKjStkuXLixZsoQ33niDnj17olar6dWrV63j6NixI3/+8595+eWX0el0jBgxgt27d/PCCy/U+OFztp49exIREcHKlSu9uhFHjBjBE0884fnvs73yyitcdtllDBo0iNtvv53k5GQsFguHDx/m66+/rjKK92yPP/4448ePZ/To0dxzzz04nU6ef/55QkJCyM/Pr1XMv1c5evqVV15h+vTp6HQ62rdvz8KFC1m9ejXjx4+nZcuWVFRUeEbU/v6YzjZgwAAiIiK47bbbePTRR9HpdCxcuJAdO3ZcUHwA06ZN46WXXmLatGk8+eSTtG3bluXLl/Pdd99d8D4vlhtuuIE5c+Zwww03YLVaq8xQ5s/39Lls2bLF8yhQVlYW7733Hvv37+e+++6r0q1/tgkTJrBgwQI6dOhA165d2bJlC88//3yV55InTpzoefY/JiaG48eP8/LLL5OUlETbtm2B2r//a7OvRq2eB22J81A5SnnTpk01tlu6dKkybNgwJTQ0VDEYDEpSUpJyzTXXKN9//71Xu3feeUdp27atotfrlXbt2invvfeeMn369CojKu12u/LCCy8ol156qWI0GpWQkBClQ4cOyq233qocOnTI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DfW8XIjGdF7OFvAJd+7cuT5vrp/9s3nzZq9tMjIyGDNmDNdeey2zZs0659+oXOigkqIoVcouhgs5lvNx/fXXM378eDp37szEiRP59ttvOXjwIMuWLbuIR1H3xwEN85z4+vvnistf5+Rczvf19NXeV3l9OJ9jad++PbNnz6ZHjx7079+f119/nfHjx/PCCy/4I9SLriGfl/PR2M5LpYBfLeiuu+5iypQpNbZJTk72/HdGRgbDhg2jf//+zJs3r8bt4uPjAfc3x4SEBE95dnZ2lW+SF8P5HssflZCQQFJSEocOHbpo+4S6PY6Gek527txJVlZWlbqcnJzziquuzkl1oqOj0Wg0Va4Aa3o94+PjfbbXarVERUXVWaznciHH4ku/fv346KOPLnZ4da6hnpeLJVDPy9kCPuFGR0cTHR1dq7bp6ekMGzaMnj17Mn/+/BrXLQRISUkhPj6eVatW0b17d8B9n2jdunU8++yzfzj23zufY7kY8vLyOHnypFfiuhjq8jga6jnp378/RUVFbNy4kT59+gDw22+/UVRUxIABA2r99+rqnFRHr9fTs2dPVq1axeTJkz3lq1atYtKkST636d+/P19//bVX2cqVK+nVqxc6na5O463JhRyLL9u2bfPb638xNdTzcrEE6nnxUo8DtvwqPT1dadOmjTJ8+HAlLS1NOXXqlOfnbO3bt1eWLFni+f2ZZ55RwsLClCVLlii7du1SbrjhBiUhIUEpLi729yF4OX78uLJt2zblscceU0JCQpRt27Yp27ZtUywWi6fN2cdisViUv/71r8r69euVY8eOKWvWrFH69++vNG/evF6P5XyPQ1Ea7jkZM2aM0rVrV2XDhg3Khg0blC5duigTJkzwatMQz8mnn36q6HQ65d1331X27t2r3HvvvUpwcLCSmpqqKIqiPPjgg8qNN97oaX/06FHFZDIp9913n7J3717l3XffVXQ6nfLFF1/4LebqnO+xvPTSS8qXX36pHDx4UNm9e7fy4IMPKoCyePHi+joED4vF4vn3ACj//ve/lW3btinHjx9XFCWwzsv5HktDPi9/RJNJuPPnz1cAnz9nA5T58+d7fne5XMqjjz6qxMfHKwaDQRk8eLCya9cuP0df1fTp030ey5o1azxtzj6WsrIyZdSoUUpMTIyi0+mUli1bKtOnT1dOnDhRPwdw2vkeh6I03HOSl5en/OlPf1LMZrNiNpuVP/3pT1Uea2io5+S///2vkpSUpOj1eqVHjx7KunXrPHXTp09XhgwZ4tV+7dq1Svfu3RW9Xq8kJycrb7zxhp8jrt75HMuzzz6rtG7dWjEajUpERIRy2WWXKcuWLauHqKuqfDTm9z/Tp09XFCWwzsv5HktDPi9/hKwWJIQQQvhBwI9SFkIIIQKBJFwhhBDCDyThCiGEEH4gCVcIIYTwA0m4QgghhB9IwhVCCCH8QBKuEEII4QeScIUQQgg/kIQrhBBC+IEkXCGEEMIPJOEKIYQQfiAJVwjhkZOTQ3x8PE899ZSn7LfffkOv17Ny5cp6jEyIwCeLFwghvCxfvpwrr7yS9evX06FDB7p378748eN5+eWX6zs0IQKaJFwhRBV33nkn33//Pb1792bHjh1s2rQJo9FY32EJEdAk4QohqigvL6dz586cPHmSzZs307Vr1/oOSYiAJ/dwhRBVHD16lIyMDFwuF8ePH6/vcIRoFOQKVwjhxWaz0adPH7p160aHDh3497//za5du4iLi6vv0IQIaJJwhRBe/va3v/HFF1+wY8cOQkJCGDZsGGazmW+++aa+QxMioEmXshDCY+3atbz88st8+OGHhIaGolar+fDDD/n5559544036js8IQKaXOEKIYQQfiBXuEIIIYQfSMIVQggh/EASrhBCCOEHknCFEEIIP5CEK4QQQviBJFwhhBDCDyThCiGEEH4gCVcIIYTwA0m4QgghhB9IwhVCCCH8QBKuEEII4QeScIUQQgg/+H9LwT0Eao7wDwAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 500x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig = plt.figure(figsize=(5,3))\n",
    "\n",
    "dicts = []\n",
    "for worker in trainer.workers:\n",
    "    frame = worker.progress_frames[-1]\n",
    "    for x, y, y_pred in zip(worker.fixed_x.tolist(), worker.fixed_y.tolist(), frame.tolist()):\n",
    "        dicts.append({'worker_id': worker.worker_id, 'type': \"real\", 'x': x[0], 'y': y[0]})\n",
    "        dicts.append({'worker_id': worker.worker_id, 'type': \"fixed_x\", 'x': x[0], 'y': y_pred[0]})\n",
    "df = pd.DataFrame(dicts)\n",
    "sns.scatterplot(x='x', y='y', hue='worker_id', palette='tab10', data=df[df['type'] == \"real\"], legend=False)\n",
    "sns.lineplot(x='x', y='y', hue='worker_id', palette='tab10', data=df[df['type'] == \"fixed_x\"], legend=False)\n",
    "plt.title(\"Federated weights and Private Biases\")\n",
    "plt.tight_layout()\n",
    "plt.savefig(\"simpson_paradox_fedregression.pdf\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Train a linear classifier on all data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [],
   "source": [
    "linear_model = nn.Linear(1, 1)\n",
    "linear_optim = torch.optim.Adam(linear_model.parameters(), lr=0.1)\n",
    "alldata_loader = DataLoader(test_dataset, args.batch_size*4, shuffle=True, **loader_kwargs)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.24006228148937225\n",
      "0.20184089839458466\n",
      "0.19150727391242983\n",
      "0.18994962796568868\n",
      "0.18912838399410248\n",
      "0.18474136739969255\n",
      "0.18380270153284073\n",
      "0.18446296155452727\n",
      "0.1803038254380226\n",
      "0.18134823441505435\n",
      "0.18311881721019743\n",
      "0.18406795859336855\n",
      "0.1828628584742546\n",
      "0.1842046469449997\n",
      "0.18304609209299086\n",
      "0.1826089359819889\n",
      "0.18420877382159231\n",
      "0.18324331194162372\n",
      "0.18219542950391768\n",
      "0.17916562855243684\n",
      "0.18517103269696236\n",
      "0.1808949023485184\n",
      "0.18306987658143042\n",
      "0.18394317999482157\n",
      "0.188259656727314\n",
      "0.18193000480532642\n",
      "0.1831439882516861\n",
      "0.18045624271035193\n",
      "0.1805746540427208\n",
      "0.1809545859694481\n",
      "0.18206479102373124\n",
      "0.18595266044139863\n",
      "0.18417822271585463\n",
      "0.1842657074332237\n",
      "0.182031811773777\n",
      "0.18499785736203198\n",
      "0.18237262070178983\n",
      "0.18070545867085458\n",
      "0.18268442451953887\n",
      "0.18113679885864256\n",
      "0.18190670311450954\n",
      "0.18642211109399795\n",
      "0.18770300149917601\n",
      "0.18279824331402778\n",
      "0.18802454918622968\n",
      "0.1814034581184387\n",
      "0.18868277147412302\n",
      "0.1874359890818596\n",
      "0.18948833048343658\n",
      "0.1867571085691452\n"
     ]
    }
   ],
   "source": [
    "linear_progress_frames = []\n",
    "x, y = next(iter(alldata_loader))\n",
    "linear_fixed_x, linear_fixed_y = x.to(args.device), y.to(args.device)\n",
    "\n",
    "for e in range(args.comm_rounds):\n",
    "    loss_mean = 0.\n",
    "    for i, (data, target) in enumerate(alldata_loader):\n",
    "        data, target = data.to(args.device), target.to(args.device)\n",
    "        batch_size = data.shape[0]\n",
    "        linear_optim.zero_grad()\n",
    "        output = linear_model(data)\n",
    "        loss = loss_func(output, target)\n",
    "        loss.backward()\n",
    "        linear_optim.step()\n",
    "        loss_mean += loss.item() / len(alldata_loader)\n",
    "\n",
    "    print(loss_mean)\n",
    "    y = linear_model(linear_fixed_x)\n",
    "    linear_progress_frames.append(y.detach())\n",
    "\n",
    "linear_mse = loss.item()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[2023-02-17 10:38:08] (32625) {animation.py:1050}INFO - Animation.save using <class 'matplotlib.animation.FFMpegWriter'>\n",
      "[2023-02-17 10:38:08] (32625) {animation.py:328}INFO - MovieWriter._run: running command: ffmpeg -f rawvideo -vcodec rawvideo -s 1000x600 -pix_fmt rgba -r 10.0 -loglevel error -i pipe: -vcodec h264 -pix_fmt yuv420p -y simpson_paradox_simpleregression.mp4\n"
     ]
    }
   ],
   "source": [
    "from matplotlib import animation\n",
    "from IPython.display import HTML\n",
    "\n",
    "plt.ioff()\n",
    "fig, ax = plt.subplots()\n",
    "\n",
    "def animate(progress_idx):\n",
    "    ax.cla()\n",
    "    dicts = []\n",
    "    frame = linear_progress_frames[progress_idx]\n",
    "    for x, y, y_pred in zip(linear_fixed_x.tolist(), linear_fixed_y.tolist(), frame.tolist()):\n",
    "        dicts.append({'type': \"real\", 'x': x[0], 'y': y[0]})\n",
    "        dicts.append({'type': \"fixed_x\", 'x': x[0], 'y': y_pred[0]})\n",
    "    df = pd.DataFrame(dicts)\n",
    "    sns.scatterplot(x='x', y='y', data=df[df['type'] == \"real\"], ax=ax, animated=True)\n",
    "    sns.lineplot(x='x', y='y', data=df[df['type'] == \"fixed_x\"], ax=ax, animated=True)\n",
    "\n",
    "ani = animation.FuncAnimation(fig, animate, frames=len(linear_progress_frames), interval=100)\n",
    "# ani.save(\"simpson_paradox_simpleregression.mp4\")\n",
    "HTML(ani.to_html5_video())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 500x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig = plt.figure(figsize=(5,3))\n",
    "\n",
    "dicts = []\n",
    "for worker in trainer.workers:\n",
    "    frame = linear_progress_frames[-1]\n",
    "    for x, y, y_pred in zip(linear_fixed_x.tolist(), linear_fixed_y.tolist(), frame.tolist()):\n",
    "        dicts.append({'worker_id': worker.worker_id, 'type': \"real\", 'x': x[0], 'y': y[0]})\n",
    "        dicts.append({'worker_id': worker.worker_id, 'type': \"fixed_x\", 'x': x[0], 'y': y_pred[0]})\n",
    "df = pd.DataFrame(dicts)\n",
    "sns.scatterplot(x='x', y='y', data=df[df['type'] == \"real\"], legend=False)\n",
    "sns.lineplot(x='x', y='y', data=df[df['type'] == \"fixed_x\"], legend=False)\n",
    "plt.title(\"Federated weights and Biases\")\n",
    "plt.tight_layout()\n",
    "plt.savefig(\"simpson_paradox_simpleregression.pdf\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Train a routing classifier"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "E01: loss = 0.3855285782366992\n",
      "E02: loss = 0.04737822022289037\n",
      "E03: loss = 0.018313259468413886\n",
      "E04: loss = 0.016819135250989346\n",
      "E05: loss = 0.016865742625668634\n",
      "E06: loss = 0.017165550799109044\n",
      "E07: loss = 0.017568982997909186\n",
      "E08: loss = 0.01648696372285485\n",
      "E09: loss = 0.0160809505963698\n",
      "E10: loss = 0.0179647148004733\n",
      "E11: loss = 0.01845117311459035\n",
      "E12: loss = 0.016310101223643868\n",
      "E13: loss = 0.01568606169894338\n",
      "E14: loss = 0.016943427524529396\n",
      "E15: loss = 0.01574603690532967\n",
      "E16: loss = 0.016039495228324086\n",
      "E17: loss = 0.014786727691534902\n",
      "E18: loss = 0.015376129024662078\n",
      "E19: loss = 0.014505891315639017\n",
      "E20: loss = 0.013839472946710882\n",
      "E21: loss = 0.012685895594768225\n",
      "E22: loss = 0.01242288138018921\n",
      "E23: loss = 0.01244816113321576\n",
      "E24: loss = 0.010538346905377693\n",
      "E25: loss = 0.00991565624717623\n",
      "E26: loss = 0.009151770250173285\n",
      "E27: loss = 0.008439057599753143\n",
      "E28: loss = 0.008197712179389782\n",
      "E29: loss = 0.007326450879918412\n",
      "E30: loss = 0.007017213126528075\n",
      "E31: loss = 0.006664948863908649\n",
      "E32: loss = 0.006262131204130127\n",
      "E33: loss = 0.005631786899175494\n",
      "E34: loss = 0.0055820918030804025\n",
      "E35: loss = 0.005052652483573184\n",
      "E36: loss = 0.004801647225394844\n",
      "E37: loss = 0.004558724301750773\n",
      "E38: loss = 0.004122595276567154\n",
      "E39: loss = 0.004076706912019289\n",
      "E40: loss = 0.004004744038684293\n",
      "E41: loss = 0.003627353017509449\n",
      "E42: loss = 0.003923604650481138\n",
      "E43: loss = 0.0033207444022991697\n",
      "E44: loss = 0.004034287450485862\n",
      "E45: loss = 0.003378960271948017\n",
      "E46: loss = 0.004481263048364782\n",
      "E47: loss = 0.0029456522985128685\n",
      "E48: loss = 0.002867139071167912\n",
      "E49: loss = 0.0028991200641030447\n",
      "E50: loss = 0.0027715332951629527\n"
     ]
    }
   ],
   "source": [
    "alldata_loader = DataLoader(test_dataset, args.batch_size, shuffle=True, **loader_kwargs)\n",
    "router = nn.Linear(2, len(trainer.workers))\n",
    "torch.nn.init.constant_(router.weight.data, 1 / len(trainer.workers))\n",
    "router_optim = torch.optim.Adam(router.parameters(), lr=0.1)\n",
    "\n",
    "for e in range(args.comm_rounds):\n",
    "    loss_mean = 0.\n",
    "    for i, (data, target) in enumerate(alldata_loader):\n",
    "        data, target = data.to(args.device), target.to(args.device)\n",
    "        batch_size = data.shape[0]\n",
    "        router_optim.zero_grad()\n",
    "\n",
    "        # route model then run regression inside model\n",
    "        router_probs = F.softmax(router(torch.cat([data, target], dim=1)), dim=1)\n",
    "        with torch.no_grad():\n",
    "            outputs = torch.stack([worker.model(data) for worker in trainer.workers], dim=1)\n",
    "        output = torch.sum(router_probs.unsqueeze(-1) * outputs, dim=1)\n",
    "\n",
    "        loss = loss_func(output, target)\n",
    "        loss.backward()\n",
    "        router_optim.step()\n",
    "\n",
    "        loss_mean += loss.item() / len(alldata_loader)\n",
    "    print(f\"E{e+1:02d}: loss = {loss_mean}\")\n",
    "\n",
    "routing_mse = loss_mean"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Simple Classifier MSE = 0.13682714104652405\n",
      "Mxiture-of-Classifiers MSE = 0.0027715332951629527\n"
     ]
    }
   ],
   "source": [
    "print(f\"Simple Classifier MSE = {linear_mse}\")\n",
    "print(f\"Mxiture-of-Classifiers MSE = {routing_mse}\")"
   ]
  },
  {
   "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.10.8"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
