{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-21T03:07:15.086664Z",
     "iopub.status.busy": "2025-09-21T03:07:15.086317Z",
     "iopub.status.idle": "2025-09-21T03:07:23.534235Z",
     "shell.execute_reply": "2025-09-21T03:07:23.533398Z"
    },
    "id": "OHJWesKs-tqd"
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-09-21 05:07:20.672670: E external/local_xla/xla/stream_executor/cuda/cuda_fft.cc:467] Unable to register cuFFT factory: Attempting to register factory for plugin cuFFT when one has already been registered\n",
      "WARNING: All log messages before absl::InitializeLog() is called are written to STDERR\n",
      "E0000 00:00:1758424040.699729 1488169 cuda_dnn.cc:8579] Unable to register cuDNN factory: Attempting to register factory for plugin cuDNN when one has already been registered\n",
      "E0000 00:00:1758424040.708141 1488169 cuda_blas.cc:1407] Unable to register cuBLAS factory: Attempting to register factory for plugin cuBLAS when one has already been registered\n",
      "W0000 00:00:1758424040.731786 1488169 computation_placer.cc:177] computation placer already registered. Please check linkage and avoid linking the same target more than once.\n",
      "W0000 00:00:1758424040.731819 1488169 computation_placer.cc:177] computation placer already registered. Please check linkage and avoid linking the same target more than once.\n",
      "W0000 00:00:1758424040.731821 1488169 computation_placer.cc:177] computation placer already registered. Please check linkage and avoid linking the same target more than once.\n",
      "W0000 00:00:1758424040.731824 1488169 computation_placer.cc:177] computation placer already registered. Please check linkage and avoid linking the same target more than once.\n",
      "2025-09-21 05:07:20.739057: I tensorflow/core/platform/cpu_feature_guard.cc:210] This TensorFlow binary is optimized to use available CPU instructions in performance-critical operations.\n",
      "To enable the following instructions: AVX2 FMA, in other operations, rebuild TensorFlow with the appropriate compiler flags.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "WARNING:tensorflow:From /home/kirch/local/python-3.11/lib/python3.11/site-packages/tensorflow/python/compat/v2_compat.py:98: disable_resource_variables (from tensorflow.python.ops.resource_variables_toggle) is deprecated and will be removed in a future version.\n",
      "Instructions for updating:\n",
      "non-resource variables are not supported in the long term\n"
     ]
    }
   ],
   "source": [
    "import json\n",
    "import os\n",
    "import time\n",
    "import ipyparallel as ipp\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "import torch\n",
    "import DFedAvgM as FedAvgM\n",
    "import dfca as DFCA\n",
    "import ifca as IFCA\n",
    "\n",
    "import numpy as np\n",
    "\n",
    "from util import *"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "QAghP_o0-tqe"
   },
   "source": [
    "Reads Config file and prepares the arguments you can choose in the config_dfca.json/config_ifca.json"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-21T03:07:23.537573Z",
     "iopub.status.busy": "2025-09-21T03:07:23.537076Z",
     "iopub.status.idle": "2025-09-21T03:07:23.540878Z",
     "shell.execute_reply": "2025-09-21T03:07:23.540215Z"
    }
   },
   "outputs": [],
   "source": [
    "learning_rates = [0.25]\n",
    "\n",
    "dec_ifca = []"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-21T03:07:23.543269Z",
     "iopub.status.busy": "2025-09-21T03:07:23.543015Z",
     "iopub.status.idle": "2025-09-21T03:07:23.547244Z",
     "shell.execute_reply": "2025-09-21T03:07:23.546581Z"
    }
   },
   "outputs": [],
   "source": [
    "import sys\n",
    "import os\n",
    "import random\n",
    "sys.path.append(os.getcwd())\n",
    "\n",
    "random.seed(42)\n",
    "seeds = random.sample(range(10000), 5)\n",
    "learning_rates = [0.25]\n",
    "\n",
    "d_fedavg_m = []"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "7ADsUSUi-tqf"
   },
   "source": [
    "Running the dfca experiment"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 1000
    },
    "execution": {
     "iopub.execute_input": "2025-09-21T03:07:23.549694Z",
     "iopub.status.busy": "2025-09-21T03:07:23.549447Z",
     "iopub.status.idle": "2025-09-22T21:16:46.567481Z",
     "shell.execute_reply": "2025-09-22T21:16:46.566497Z"
    },
    "id": "T_XDv25r-tqf",
    "outputId": "9c8f4300-c792-4e49-be40-c694fa066e6f"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "---------------------------------DFedAvgM, lr: 0.25, seed: 1824---------------------------------\n",
      "config: {'m': 50, 'm_test': 10, 'p': 2, 'n': 2000, 'local_model_init': False, 'participation_rate': 1, 'Gp': 0.25, 'graph': 'er', 'agg': 'seq', 'num_epochs': 150, 'batch_size': 50, 'tau': 10, 'lr': 0.25, 'data_seed': 1824, 'train_seed': 1824, 'project_dir': 'output'}\n",
      "Using device: cuda:0\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "WARNING:tensorflow:From /home/kirch/repos/dfca_paper/cifar/cifar10.py:143: calling TruncatedNormal.__init__ (from tensorflow.python.ops.init_ops) with dtype is deprecated and will be removed in a future version.\n",
      "Instructions for updating:\n",
      "Call initializer instance with the dtype argument instead of passing it to the constructor\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "I0000 00:00:1758424050.611501 1488169 gpu_device.cc:2019] Created device /job:localhost/replica:0/task:0/device:GPU:0 with 33884 MB memory:  -> device: 2, name: NVIDIA A100-SXM4-40GB, pci bus id: 0000:81:00.0, compute capability: 8.0\n",
      "WARNING: All log messages before absl::InitializeLog() is called are written to STDERR\n",
      "I0000 00:00:1758424050.664236 1488169 mlir_graph_optimization_pass.cc:425] MLIR V1 optimization pass is not enabled\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "I0000 00:00:1758424052.356743 1489313 cuda_dnn.cc:529] Loaded cuDNN version 90501\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch -1 tr: l 4.678 a 0.107  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] cl_acc 0.500 8.352sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch -1 tst: l 4.678 a 0.107  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.437sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0 tr: l 3.277 a 0.233  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.250000 cl_acc 0.500 183.663sec(train) 6.445sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0 tst: l 3.295 a 0.227  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.314sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1 tr: l 2.434 a 0.344  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.247500 cl_acc 0.500 181.122sec(train) 6.303sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1 tst: l 2.429 a 0.344  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.332sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2 tr: l 1.949 a 0.429  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.245025 cl_acc 0.500 198.074sec(train) 7.211sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2 tst: l 1.958 a 0.411  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.351sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3 tr: l 1.698 a 0.489  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.242575 cl_acc 0.500 199.858sec(train) 7.406sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3 tst: l 1.721 a 0.468  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.277sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4 tr: l 1.562 a 0.518  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.240149 cl_acc 0.500 177.459sec(train) 7.526sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4 tst: l 1.591 a 0.499  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.314sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5 tr: l 1.469 a 0.547  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.237748 cl_acc 0.500 178.404sec(train) 7.682sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5 tst: l 1.513 a 0.525  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.429sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6 tr: l 1.388 a 0.579  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.235370 cl_acc 0.500 177.176sec(train) 6.938sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6 tst: l 1.476 a 0.534  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.343sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7 tr: l 1.345 a 0.589  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.233016 cl_acc 0.500 169.468sec(train) 7.052sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7 tst: l 1.417 a 0.554  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.308sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8 tr: l 1.321 a 0.599  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.230686 cl_acc 0.500 161.427sec(train) 7.111sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8 tst: l 1.424 a 0.553  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.434sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9 tr: l 1.287 a 0.614  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.228379 cl_acc 0.500 164.088sec(train) 7.597sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9 tst: l 1.382 a 0.573  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.603sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10 tr: l 1.269 a 0.620  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.226096 cl_acc 0.500 173.754sec(train) 8.548sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10 tst: l 1.375 a 0.578  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 2.414sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11 tr: l 1.252 a 0.627  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.223835 cl_acc 0.500 224.734sec(train) 8.394sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11 tst: l 1.362 a 0.584  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.530sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12 tr: l 1.230 a 0.636  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.221596 cl_acc 0.500 198.366sec(train) 6.894sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12 tst: l 1.335 a 0.593  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.323sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13 tr: l 1.207 a 0.645  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.219380 cl_acc 0.500 173.739sec(train) 7.010sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13 tst: l 1.341 a 0.590  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.348sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14 tr: l 1.169 a 0.663  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.217186 cl_acc 0.500 171.059sec(train) 6.521sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14 tst: l 1.322 a 0.599  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.318sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15 tr: l 1.202 a 0.649  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.215015 cl_acc 0.500 173.301sec(train) 7.038sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15 tst: l 1.321 a 0.602  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.436sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16 tr: l 1.184 a 0.653  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.212864 cl_acc 0.500 161.645sec(train) 5.499sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16 tst: l 1.313 a 0.602  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.171sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17 tr: l 1.138 a 0.673  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.210736 cl_acc 0.500 170.769sec(train) 6.848sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17 tst: l 1.301 a 0.610  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.339sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18 tr: l 1.157 a 0.668  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.208628 cl_acc 0.500 163.755sec(train) 6.138sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18 tst: l 1.277 a 0.620  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.384sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19 tr: l 1.130 a 0.677  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.206542 cl_acc 0.500 169.393sec(train) 6.934sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19 tst: l 1.279 a 0.620  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.470sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20 tr: l 1.151 a 0.669  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.204477 cl_acc 0.500 178.043sec(train) 7.138sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20 tst: l 1.259 a 0.629  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.415sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21 tr: l 1.135 a 0.673  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.202432 cl_acc 0.500 176.780sec(train) 7.785sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21 tst: l 1.257 a 0.627  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.339sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22 tr: l 1.101 a 0.686  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.200408 cl_acc 0.500 172.680sec(train) 6.818sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22 tst: l 1.243 a 0.633  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.621sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23 tr: l 1.113 a 0.683  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.198404 cl_acc 0.500 167.327sec(train) 6.915sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23 tst: l 1.259 a 0.627  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.295sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24 tr: l 1.086 a 0.691  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.196420 cl_acc 0.500 171.125sec(train) 6.096sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24 tst: l 1.234 a 0.633  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.178sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25 tr: l 1.076 a 0.699  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.194455 cl_acc 0.500 177.617sec(train) 6.485sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25 tst: l 1.230 a 0.639  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 26 tr: l 1.093 a 0.693  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.192511 cl_acc 0.500 166.462sec(train) 7.609sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 26 tst: l 1.240 a 0.638  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.437sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 27 tr: l 1.065 a 0.699  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.190586 cl_acc 0.500 164.027sec(train) 7.042sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 27 tst: l 1.224 a 0.639  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.565sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 28 tr: l 1.055 a 0.705  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.188680 cl_acc 0.500 163.980sec(train) 7.585sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 28 tst: l 1.212 a 0.646  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.620sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 29 tr: l 1.032 a 0.715  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.186793 cl_acc 0.500 181.975sec(train) 7.198sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 29 tst: l 1.209 a 0.648  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.382sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 30 tr: l 1.047 a 0.708  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.184925 cl_acc 0.500 189.641sec(train) 8.348sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 30 tst: l 1.204 a 0.649  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.518sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 31 tr: l 1.055 a 0.706  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.183076 cl_acc 0.500 181.439sec(train) 7.635sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 31 tst: l 1.200 a 0.653  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.756sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 32 tr: l 1.006 a 0.719  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.181245 cl_acc 0.500 185.042sec(train) 6.315sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 32 tst: l 1.189 a 0.653  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.214sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 33 tr: l 0.993 a 0.727  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.179433 cl_acc 0.500 163.489sec(train) 6.780sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 33 tst: l 1.186 a 0.655  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.256sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 34 tr: l 0.995 a 0.727  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.177638 cl_acc 0.500 157.247sec(train) 7.103sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 34 tst: l 1.174 a 0.661  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.384sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 35 tr: l 1.014 a 0.719  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.175862 cl_acc 0.500 159.061sec(train) 7.143sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 35 tst: l 1.181 a 0.660  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.383sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 36 tr: l 1.003 a 0.723  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.174103 cl_acc 0.500 168.368sec(train) 6.617sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 36 tst: l 1.169 a 0.661  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.365sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 37 tr: l 1.037 a 0.710  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.172362 cl_acc 0.500 164.615sec(train) 6.962sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 37 tst: l 1.181 a 0.658  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.387sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 38 tr: l 0.981 a 0.732  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.170639 cl_acc 0.500 163.812sec(train) 6.976sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 38 tst: l 1.162 a 0.668  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.699sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 39 tr: l 0.982 a 0.730  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.168932 cl_acc 0.500 186.709sec(train) 7.430sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 39 tst: l 1.164 a 0.663  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.559sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 40 tr: l 0.968 a 0.736  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.167243 cl_acc 0.500 197.721sec(train) 6.350sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 40 tst: l 1.147 a 0.670  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.171sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 41 tr: l 0.971 a 0.733  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.165571 cl_acc 0.500 193.457sec(train) 7.998sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 41 tst: l 1.147 a 0.670  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.901sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 42 tr: l 0.952 a 0.741  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.163915 cl_acc 0.500 176.249sec(train) 7.302sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 42 tst: l 1.153 a 0.668  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.392sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 43 tr: l 0.973 a 0.733  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.162276 cl_acc 0.500 167.237sec(train) 6.901sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 43 tst: l 1.149 a 0.671  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.404sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 44 tr: l 0.951 a 0.741  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.160653 cl_acc 0.500 162.935sec(train) 6.398sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 44 tst: l 1.138 a 0.674  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.239sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 45 tr: l 0.967 a 0.734  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.159046 cl_acc 0.500 159.416sec(train) 7.087sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 45 tst: l 1.134 a 0.672  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.473sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 46 tr: l 0.947 a 0.742  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.157456 cl_acc 0.500 169.534sec(train) 7.817sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 46 tst: l 1.135 a 0.675  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.684sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 47 tr: l 0.937 a 0.744  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.155881 cl_acc 0.500 161.391sec(train) 7.262sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 47 tst: l 1.126 a 0.678  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.557sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 48 tr: l 0.942 a 0.743  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.154323 cl_acc 0.500 159.182sec(train) 7.152sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 48 tst: l 1.115 a 0.682  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.433sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 49 tr: l 0.911 a 0.754  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.152779 cl_acc 0.500 171.978sec(train) 7.454sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 49 tst: l 1.116 a 0.682  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.503sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 50 tr: l 0.915 a 0.753  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.151252 cl_acc 0.500 186.062sec(train) 6.746sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 50 tst: l 1.108 a 0.686  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.449sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 51 tr: l 0.912 a 0.753  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.149739 cl_acc 0.500 171.798sec(train) 7.750sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 51 tst: l 1.106 a 0.687  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.475sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 52 tr: l 0.930 a 0.746  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.148242 cl_acc 0.500 182.991sec(train) 6.323sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 52 tst: l 1.110 a 0.684  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.439sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 53 tr: l 0.903 a 0.758  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.146759 cl_acc 0.500 167.573sec(train) 6.539sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 53 tst: l 1.100 a 0.687  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.799sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 54 tr: l 0.907 a 0.754  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.145292 cl_acc 0.500 167.616sec(train) 6.977sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 54 tst: l 1.098 a 0.687  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.262sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 55 tr: l 0.889 a 0.760  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.143839 cl_acc 0.500 170.259sec(train) 7.943sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 55 tst: l 1.099 a 0.686  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.890sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 56 tr: l 0.895 a 0.757  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.142400 cl_acc 0.500 165.886sec(train) 7.047sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 56 tst: l 1.091 a 0.691  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.475sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 57 tr: l 0.878 a 0.763  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.140976 cl_acc 0.500 161.223sec(train) 6.967sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 57 tst: l 1.092 a 0.688  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.492sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 58 tr: l 0.909 a 0.751  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.139567 cl_acc 0.500 159.803sec(train) 5.992sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 58 tst: l 1.083 a 0.691  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.301sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 59 tr: l 0.890 a 0.758  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.138171 cl_acc 0.500 168.378sec(train) 7.373sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 59 tst: l 1.083 a 0.692  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.397sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 60 tr: l 0.910 a 0.754  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.136789 cl_acc 0.500 173.864sec(train) 6.910sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 60 tst: l 1.074 a 0.697  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.557sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 61 tr: l 0.878 a 0.761  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.135421 cl_acc 0.500 177.225sec(train) 7.256sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 61 tst: l 1.068 a 0.698  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.414sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 62 tr: l 0.881 a 0.760  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.134067 cl_acc 0.500 182.307sec(train) 7.440sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 62 tst: l 1.071 a 0.698  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.448sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 63 tr: l 0.895 a 0.756  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.132726 cl_acc 0.500 161.776sec(train) 5.780sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 63 tst: l 1.069 a 0.701  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.140sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 64 tr: l 0.863 a 0.769  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.131399 cl_acc 0.500 149.923sec(train) 6.348sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 64 tst: l 1.059 a 0.701  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.262sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 65 tr: l 0.837 a 0.777  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.130085 cl_acc 0.500 156.355sec(train) 6.816sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 65 tst: l 1.058 a 0.701  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.305sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 66 tr: l 0.856 a 0.768  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.128784 cl_acc 0.500 157.567sec(train) 5.367sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 66 tst: l 1.053 a 0.704  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.052sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 67 tr: l 0.847 a 0.773  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.127496 cl_acc 0.500 154.525sec(train) 6.377sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 67 tst: l 1.054 a 0.704  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.334sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 68 tr: l 0.849 a 0.772  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.126221 cl_acc 0.500 162.545sec(train) 6.095sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 68 tst: l 1.048 a 0.704  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.221sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 69 tr: l 0.838 a 0.775  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.124959 cl_acc 0.500 207.821sec(train) 7.588sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 69 tst: l 1.045 a 0.704  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.414sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 70 tr: l 0.806 a 0.786  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.123710 cl_acc 0.500 171.099sec(train) 7.682sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 70 tst: l 1.038 a 0.707  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.436sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 71 tr: l 0.845 a 0.772  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.122473 cl_acc 0.500 191.792sec(train) 6.179sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 71 tst: l 1.044 a 0.703  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.163sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 72 tr: l 0.817 a 0.782  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.121248 cl_acc 0.500 154.982sec(train) 6.771sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 72 tst: l 1.032 a 0.709  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.360sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 73 tr: l 0.829 a 0.778  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.120035 cl_acc 0.500 152.412sec(train) 5.840sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 73 tst: l 1.040 a 0.707  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.160sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 74 tr: l 0.819 a 0.782  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.118835 cl_acc 0.500 151.626sec(train) 7.641sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 74 tst: l 1.031 a 0.713  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.579sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 75 tr: l 0.821 a 0.780  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.117647 cl_acc 0.500 162.041sec(train) 7.060sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 75 tst: l 1.029 a 0.713  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.609sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 76 tr: l 0.803 a 0.785  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.116470 cl_acc 0.500 176.190sec(train) 7.436sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 76 tst: l 1.021 a 0.714  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.805sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 77 tr: l 0.823 a 0.779  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.115305 cl_acc 0.500 167.917sec(train) 6.606sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 77 tst: l 1.025 a 0.711  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.306sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 78 tr: l 0.814 a 0.781  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.114152 cl_acc 0.500 196.712sec(train) 7.960sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 78 tst: l 1.021 a 0.714  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.410sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 79 tr: l 0.810 a 0.783  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.113011 cl_acc 0.500 198.812sec(train) 7.521sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 79 tst: l 1.017 a 0.714  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.244sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 80 tr: l 0.817 a 0.780  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.111881 cl_acc 0.500 173.018sec(train) 6.980sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 80 tst: l 1.012 a 0.715  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.426sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 81 tr: l 0.803 a 0.784  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.110762 cl_acc 0.500 182.700sec(train) 7.617sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 81 tst: l 1.016 a 0.713  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.588sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 82 tr: l 0.813 a 0.781  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.109654 cl_acc 0.500 174.551sec(train) 6.725sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 82 tst: l 1.012 a 0.714  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.351sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 83 tr: l 0.805 a 0.783  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.108558 cl_acc 0.500 157.482sec(train) 5.981sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 83 tst: l 1.002 a 0.717  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.518sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 84 tr: l 0.796 a 0.786  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.107472 cl_acc 0.500 164.352sec(train) 6.445sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 84 tst: l 1.003 a 0.720  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.176sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 85 tr: l 0.769 a 0.795  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.106398 cl_acc 0.500 172.262sec(train) 5.996sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 85 tst: l 0.992 a 0.722  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.288sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 86 tr: l 0.800 a 0.784  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.105334 cl_acc 0.500 166.823sec(train) 5.987sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 86 tst: l 0.992 a 0.721  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.245sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 87 tr: l 0.762 a 0.798  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.104280 cl_acc 0.500 224.585sec(train) 8.230sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 87 tst: l 1.004 a 0.716  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.857sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 88 tr: l 0.758 a 0.800  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.103237 cl_acc 0.500 184.781sec(train) 7.410sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 88 tst: l 0.994 a 0.721  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.649sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 89 tr: l 0.779 a 0.790  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.102205 cl_acc 0.500 183.906sec(train) 6.329sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 89 tst: l 0.996 a 0.722  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.179sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 90 tr: l 0.779 a 0.792  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.101183 cl_acc 0.500 162.751sec(train) 6.280sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 90 tst: l 0.991 a 0.722  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.048sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 91 tr: l 0.752 a 0.801  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.100171 cl_acc 0.500 169.436sec(train) 6.210sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 91 tst: l 0.980 a 0.726  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.142sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 92 tr: l 0.765 a 0.795  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.099169 cl_acc 0.500 162.563sec(train) 6.049sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 92 tst: l 0.990 a 0.721  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.258sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 93 tr: l 0.737 a 0.805  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.098178 cl_acc 0.500 166.934sec(train) 6.254sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 93 tst: l 0.986 a 0.724  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.168sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 94 tr: l 0.751 a 0.799  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.097196 cl_acc 0.500 167.312sec(train) 6.527sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 94 tst: l 0.978 a 0.726  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.304sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 95 tr: l 0.761 a 0.795  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.096224 cl_acc 0.500 169.575sec(train) 5.642sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 95 tst: l 0.966 a 0.729  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.301sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 96 tr: l 0.760 a 0.797  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.095262 cl_acc 0.500 195.969sec(train) 7.125sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 96 tst: l 0.973 a 0.725  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.272sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 97 tr: l 0.721 a 0.809  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.094309 cl_acc 0.500 214.648sec(train) 7.166sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 97 tst: l 0.970 a 0.729  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.240sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 98 tr: l 0.752 a 0.797  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.093366 cl_acc 0.500 170.133sec(train) 6.272sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 98 tst: l 0.976 a 0.725  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.181sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 99 tr: l 0.745 a 0.800  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.092432 cl_acc 0.500 167.178sec(train) 7.131sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 99 tst: l 0.966 a 0.726  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.519sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 100 tr: l 0.742 a 0.803  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.091508 cl_acc 0.500 182.720sec(train) 7.697sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 100 tst: l 0.965 a 0.729  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.634sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 101 tr: l 0.744 a 0.800  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.090593 cl_acc 0.500 170.901sec(train) 6.236sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 101 tst: l 0.964 a 0.729  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.204sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 102 tr: l 0.736 a 0.803  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.089687 cl_acc 0.500 169.176sec(train) 7.369sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 102 tst: l 0.961 a 0.730  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.460sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 103 tr: l 0.733 a 0.803  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.088790 cl_acc 0.500 171.029sec(train) 6.901sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 103 tst: l 0.961 a 0.729  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.270sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 104 tr: l 0.728 a 0.806  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.087902 cl_acc 0.500 171.098sec(train) 7.064sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 104 tst: l 0.958 a 0.730  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.334sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 105 tr: l 0.723 a 0.807  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.087023 cl_acc 0.500 210.010sec(train) 6.879sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 105 tst: l 0.962 a 0.730  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.311sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 106 tr: l 0.708 a 0.813  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.086153 cl_acc 0.500 193.305sec(train) 7.234sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 106 tst: l 0.954 a 0.733  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.583sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 107 tr: l 0.714 a 0.810  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.085292 cl_acc 0.500 174.638sec(train) 7.235sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 107 tst: l 0.956 a 0.733  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.595sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 108 tr: l 0.721 a 0.807  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.084439 cl_acc 0.500 178.072sec(train) 7.353sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 108 tst: l 0.946 a 0.733  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.602sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 109 tr: l 0.710 a 0.811  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.083594 cl_acc 0.500 163.256sec(train) 7.975sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 109 tst: l 0.955 a 0.731  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.590sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 110 tr: l 0.704 a 0.812  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.082758 cl_acc 0.500 172.978sec(train) 6.472sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 110 tst: l 0.947 a 0.735  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.407sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 111 tr: l 0.699 a 0.815  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.081931 cl_acc 0.500 164.823sec(train) 6.054sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 111 tst: l 0.942 a 0.735  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.348sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 112 tr: l 0.727 a 0.805  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.081111 cl_acc 0.500 163.222sec(train) 6.573sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 112 tst: l 0.940 a 0.736  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.188sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 113 tr: l 0.692 a 0.817  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.080300 cl_acc 0.500 194.375sec(train) 7.194sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 113 tst: l 0.943 a 0.736  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.268sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 114 tr: l 0.708 a 0.811  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.079497 cl_acc 0.500 234.819sec(train) 6.677sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 114 tst: l 0.935 a 0.737  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.425sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 115 tr: l 0.706 a 0.810  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.078702 cl_acc 0.500 204.863sec(train) 6.151sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 115 tst: l 0.941 a 0.737  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.251sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 116 tr: l 0.687 a 0.817  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.077915 cl_acc 0.500 177.224sec(train) 5.701sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 116 tst: l 0.937 a 0.739  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.740sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 117 tr: l 0.704 a 0.810  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.077136 cl_acc 0.500 176.459sec(train) 6.973sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 117 tst: l 0.936 a 0.739  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.245sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 118 tr: l 0.685 a 0.818  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.076365 cl_acc 0.500 174.201sec(train) 6.817sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 118 tst: l 0.932 a 0.740  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.511sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 119 tr: l 0.680 a 0.818  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.075601 cl_acc 0.500 182.835sec(train) 8.100sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 119 tst: l 0.933 a 0.738  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.289sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 120 tr: l 0.701 a 0.811  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.074845 cl_acc 0.500 168.826sec(train) 8.170sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 120 tst: l 0.924 a 0.741  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.398sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 121 tr: l 0.697 a 0.814  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.074097 cl_acc 0.500 215.608sec(train) 6.669sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 121 tst: l 0.930 a 0.739  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.361sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 122 tr: l 0.688 a 0.815  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.073356 cl_acc 0.500 233.327sec(train) 8.972sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 122 tst: l 0.925 a 0.741  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.365sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 123 tr: l 0.677 a 0.821  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.072622 cl_acc 0.500 195.557sec(train) 7.122sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 123 tst: l 0.919 a 0.741  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.502sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 124 tr: l 0.689 a 0.816  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.071896 cl_acc 0.500 170.325sec(train) 5.956sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 124 tst: l 0.925 a 0.741  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.121sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 125 tr: l 0.686 a 0.816  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.071177 cl_acc 0.500 155.134sec(train) 6.798sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 125 tst: l 0.919 a 0.743  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.415sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 126 tr: l 0.661 a 0.825  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.070465 cl_acc 0.500 170.120sec(train) 6.696sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 126 tst: l 0.911 a 0.745  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.192sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 127 tr: l 0.675 a 0.819  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.069761 cl_acc 0.500 175.757sec(train) 8.106sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 127 tst: l 0.918 a 0.742  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.652sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 128 tr: l 0.691 a 0.813  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.069063 cl_acc 0.500 178.126sec(train) 6.915sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 128 tst: l 0.917 a 0.741  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.203sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 129 tr: l 0.672 a 0.819  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.068372 cl_acc 0.500 184.175sec(train) 7.134sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 129 tst: l 0.922 a 0.741  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.532sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 130 tr: l 0.646 a 0.828  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.067689 cl_acc 0.500 189.162sec(train) 6.990sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 130 tst: l 0.919 a 0.743  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.587sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 131 tr: l 0.666 a 0.822  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.067012 cl_acc 0.500 196.954sec(train) 8.213sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 131 tst: l 0.909 a 0.744  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.517sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 132 tr: l 0.661 a 0.824  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.066342 cl_acc 0.500 172.265sec(train) 8.109sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 132 tst: l 0.913 a 0.745  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.840sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 133 tr: l 0.664 a 0.823  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.065678 cl_acc 0.500 170.970sec(train) 6.166sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 133 tst: l 0.912 a 0.743  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.101sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 134 tr: l 0.646 a 0.828  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.065021 cl_acc 0.500 177.187sec(train) 6.308sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 134 tst: l 0.909 a 0.745  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.121sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 135 tr: l 0.681 a 0.816  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.064371 cl_acc 0.500 174.655sec(train) 6.105sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 135 tst: l 0.906 a 0.745  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.196sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 136 tr: l 0.645 a 0.829  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.063727 cl_acc 0.500 166.316sec(train) 8.031sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 136 tst: l 0.902 a 0.746  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.458sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 137 tr: l 0.653 a 0.824  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.063090 cl_acc 0.500 167.302sec(train) 5.788sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 137 tst: l 0.906 a 0.747  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.381sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 138 tr: l 0.654 a 0.824  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.062459 cl_acc 0.500 156.794sec(train) 5.700sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 138 tst: l 0.903 a 0.748  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.066sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 139 tr: l 0.649 a 0.828  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.061835 cl_acc 0.500 179.074sec(train) 6.728sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 139 tst: l 0.896 a 0.751  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.403sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 140 tr: l 0.637 a 0.830  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.061216 cl_acc 0.500 210.387sec(train) 7.512sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 140 tst: l 0.897 a 0.747  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.351sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 141 tr: l 0.637 a 0.829  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.060604 cl_acc 0.500 188.019sec(train) 6.820sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 141 tst: l 0.898 a 0.747  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.194sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 142 tr: l 0.662 a 0.822  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.059998 cl_acc 0.500 179.157sec(train) 6.896sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 142 tst: l 0.896 a 0.748  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.200sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 143 tr: l 0.648 a 0.824  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.059398 cl_acc 0.500 161.652sec(train) 7.520sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 143 tst: l 0.894 a 0.749  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.387sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 144 tr: l 0.636 a 0.830  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.058804 cl_acc 0.500 163.227sec(train) 5.976sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 144 tst: l 0.895 a 0.748  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.244sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 145 tr: l 0.631 a 0.832  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.058216 cl_acc 0.500 182.773sec(train) 9.152sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 145 tst: l 0.883 a 0.753  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.922sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 146 tr: l 0.624 a 0.833  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.057634 cl_acc 0.500 175.871sec(train) 7.090sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 146 tst: l 0.894 a 0.747  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.227sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 147 tr: l 0.620 a 0.835  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.057058 cl_acc 0.500 170.801sec(train) 6.863sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 147 tst: l 0.889 a 0.753  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.431sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 148 tr: l 0.635 a 0.829  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.056487 cl_acc 0.500 177.152sec(train) 6.557sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 148 tst: l 0.894 a 0.749  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.379sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 149 tr: l 0.621 a 0.834  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.055922 cl_acc 0.500 208.310sec(train) 6.507sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 149 tst: l 0.891 a 0.747  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.293sec\n",
      "result written at output/results.pickle\n",
      "---train cluster Ended in 7.69 hour (27685.977 sec) \n",
      "---------------------------------DFedAvgM, lr: 0.25, seed: 409---------------------------------\n",
      "config: {'m': 50, 'm_test': 10, 'p': 2, 'n': 2000, 'local_model_init': False, 'participation_rate': 1, 'Gp': 0.25, 'graph': 'er', 'agg': 'seq', 'num_epochs': 150, 'batch_size': 50, 'tau': 10, 'lr': 0.25, 'data_seed': 409, 'train_seed': 409, 'project_dir': 'output'}\n",
      "Using device: cuda:0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "I0000 00:00:1758451736.744155 1488169 gpu_device.cc:2019] Created device /job:localhost/replica:0/task:0/device:GPU:0 with 33884 MB memory:  -> device: 2, name: NVIDIA A100-SXM4-40GB, pci bus id: 0000:81:00.0, compute capability: 8.0\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch -1 tr: l 4.676 a 0.125  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] cl_acc 0.500 8.008sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch -1 tst: l 4.676 a 0.123  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.290sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0 tr: l 3.305 a 0.211  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.250000 cl_acc 0.500 189.202sec(train) 7.382sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0 tst: l 3.320 a 0.192  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.420sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1 tr: l 2.471 a 0.344  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.247500 cl_acc 0.500 171.917sec(train) 6.241sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1 tst: l 2.480 a 0.338  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.272sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2 tr: l 2.004 a 0.400  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.245025 cl_acc 0.500 165.218sec(train) 5.987sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2 tst: l 1.981 a 0.404  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.019sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3 tr: l 1.721 a 0.475  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.242575 cl_acc 0.500 163.870sec(train) 5.666sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3 tst: l 1.722 a 0.471  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.296sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4 tr: l 1.581 a 0.516  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.240149 cl_acc 0.500 172.756sec(train) 5.977sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4 tst: l 1.626 a 0.494  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.168sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5 tr: l 1.451 a 0.561  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.237748 cl_acc 0.500 170.282sec(train) 6.540sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5 tst: l 1.494 a 0.531  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.820sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6 tr: l 1.381 a 0.580  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.235370 cl_acc 0.500 170.229sec(train) 7.479sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6 tst: l 1.442 a 0.549  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.283sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7 tr: l 1.359 a 0.589  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.233016 cl_acc 0.500 207.885sec(train) 7.758sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7 tst: l 1.420 a 0.560  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.419sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8 tr: l 1.302 a 0.610  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.230686 cl_acc 0.500 210.324sec(train) 7.326sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8 tst: l 1.368 a 0.580  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.412sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9 tr: l 1.275 a 0.617  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.228379 cl_acc 0.500 195.138sec(train) 6.438sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9 tst: l 1.341 a 0.587  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.899sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10 tr: l 1.259 a 0.624  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.226096 cl_acc 0.500 190.654sec(train) 6.939sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10 tst: l 1.336 a 0.590  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.033sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11 tr: l 1.216 a 0.639  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.223835 cl_acc 0.500 164.608sec(train) 6.935sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11 tst: l 1.308 a 0.601  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.232sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12 tr: l 1.214 a 0.647  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.221596 cl_acc 0.500 153.200sec(train) 4.996sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12 tst: l 1.303 a 0.605  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.030sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13 tr: l 1.188 a 0.654  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.219380 cl_acc 0.500 152.875sec(train) 5.166sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13 tst: l 1.285 a 0.612  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.948sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14 tr: l 1.197 a 0.652  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.217186 cl_acc 0.500 147.098sec(train) 5.166sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14 tst: l 1.286 a 0.613  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.954sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15 tr: l 1.169 a 0.661  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.215015 cl_acc 0.500 146.599sec(train) 5.860sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15 tst: l 1.278 a 0.611  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.299sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16 tr: l 1.152 a 0.668  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.212864 cl_acc 0.500 223.323sec(train) 6.619sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16 tst: l 1.260 a 0.622  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.514sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17 tr: l 1.125 a 0.679  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.210736 cl_acc 0.500 226.454sec(train) 6.319sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17 tst: l 1.240 a 0.628  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.221sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18 tr: l 1.130 a 0.678  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.208628 cl_acc 0.500 152.682sec(train) 5.003sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18 tst: l 1.237 a 0.631  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.876sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19 tr: l 1.089 a 0.692  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.206542 cl_acc 0.500 138.292sec(train) 5.776sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19 tst: l 1.224 a 0.636  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.164sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20 tr: l 1.087 a 0.692  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.204477 cl_acc 0.500 147.246sec(train) 4.848sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20 tst: l 1.227 a 0.634  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.961sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21 tr: l 1.088 a 0.691  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.202432 cl_acc 0.500 131.737sec(train) 7.008sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21 tst: l 1.208 a 0.641  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.315sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22 tr: l 1.096 a 0.685  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.200408 cl_acc 0.500 157.206sec(train) 6.383sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22 tst: l 1.220 a 0.638  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.131sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23 tr: l 1.063 a 0.701  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.198404 cl_acc 0.500 141.751sec(train) 6.169sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23 tst: l 1.201 a 0.646  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.253sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24 tr: l 1.076 a 0.695  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.196420 cl_acc 0.500 129.320sec(train) 5.394sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24 tst: l 1.200 a 0.646  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.991sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25 tr: l 1.072 a 0.699  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.194455 cl_acc 0.500 246.623sec(train) 6.548sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25 tst: l 1.201 a 0.650  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.235sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 26 tr: l 1.029 a 0.715  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.192511 cl_acc 0.500 249.381sec(train) 6.849sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 26 tst: l 1.190 a 0.653  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.374sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 27 tr: l 1.026 a 0.717  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.190586 cl_acc 0.500 143.083sec(train) 6.266sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 27 tst: l 1.171 a 0.661  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.222sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 28 tr: l 1.013 a 0.719  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.188680 cl_acc 0.500 144.750sec(train) 4.912sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 28 tst: l 1.170 a 0.658  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.957sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 29 tr: l 1.059 a 0.701  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.186793 cl_acc 0.500 137.323sec(train) 5.522sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 29 tst: l 1.173 a 0.658  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.214sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 30 tr: l 0.993 a 0.726  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.184925 cl_acc 0.500 131.981sec(train) 4.478sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 30 tst: l 1.161 a 0.659  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.885sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 31 tr: l 1.029 a 0.713  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.183076 cl_acc 0.500 127.922sec(train) 6.241sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 31 tst: l 1.166 a 0.659  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.212sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 32 tr: l 0.976 a 0.733  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.181245 cl_acc 0.500 125.381sec(train) 5.856sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 32 tst: l 1.152 a 0.665  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.217sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 33 tr: l 0.983 a 0.732  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.179433 cl_acc 0.500 130.461sec(train) 4.458sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 33 tst: l 1.147 a 0.667  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.846sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 34 tr: l 0.981 a 0.732  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.177638 cl_acc 0.500 181.780sec(train) 5.306sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 34 tst: l 1.150 a 0.668  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.059sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 35 tr: l 0.994 a 0.727  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.175862 cl_acc 0.500 225.246sec(train) 6.014sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 35 tst: l 1.143 a 0.669  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.112sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 36 tr: l 0.981 a 0.728  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.174103 cl_acc 0.500 197.444sec(train) 4.550sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 36 tst: l 1.142 a 0.667  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.875sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 37 tr: l 0.969 a 0.735  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.172362 cl_acc 0.500 140.198sec(train) 5.452sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 37 tst: l 1.121 a 0.678  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.107sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 38 tr: l 0.970 a 0.733  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.170639 cl_acc 0.500 125.606sec(train) 4.552sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 38 tst: l 1.126 a 0.675  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.875sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 39 tr: l 0.967 a 0.735  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.168932 cl_acc 0.500 128.074sec(train) 5.957sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 39 tst: l 1.113 a 0.682  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.194sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 40 tr: l 0.946 a 0.744  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.167243 cl_acc 0.500 152.924sec(train) 5.858sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 40 tst: l 1.116 a 0.680  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.115sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 41 tr: l 0.942 a 0.744  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.165571 cl_acc 0.500 143.474sec(train) 4.509sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 41 tst: l 1.109 a 0.684  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.879sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 42 tr: l 0.935 a 0.747  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.163915 cl_acc 0.500 134.252sec(train) 4.890sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 42 tst: l 1.112 a 0.682  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.960sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 43 tr: l 0.922 a 0.749  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.162276 cl_acc 0.500 152.395sec(train) 5.912sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 43 tst: l 1.103 a 0.684  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.237sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 44 tr: l 0.922 a 0.751  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.160653 cl_acc 0.500 226.530sec(train) 6.804sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 44 tst: l 1.099 a 0.684  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.250sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 45 tr: l 0.908 a 0.756  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.159046 cl_acc 0.500 226.363sec(train) 5.977sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 45 tst: l 1.096 a 0.685  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.326sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 46 tr: l 0.951 a 0.740  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.157456 cl_acc 0.500 139.620sec(train) 4.721sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 46 tst: l 1.102 a 0.683  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.023sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 47 tr: l 0.924 a 0.749  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.155881 cl_acc 0.500 161.498sec(train) 7.138sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 47 tst: l 1.091 a 0.688  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.366sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 48 tr: l 0.933 a 0.744  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.154323 cl_acc 0.500 166.869sec(train) 5.916sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 48 tst: l 1.090 a 0.688  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.207sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 49 tr: l 0.898 a 0.758  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.152779 cl_acc 0.500 173.764sec(train) 5.374sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 49 tst: l 1.075 a 0.695  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.114sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 50 tr: l 0.904 a 0.757  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.151252 cl_acc 0.500 163.134sec(train) 5.385sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 50 tst: l 1.082 a 0.693  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.947sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 51 tr: l 0.884 a 0.764  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.149739 cl_acc 0.500 176.577sec(train) 5.908sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 51 tst: l 1.081 a 0.690  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.114sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 52 tr: l 0.910 a 0.754  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.148242 cl_acc 0.500 211.391sec(train) 6.055sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 52 tst: l 1.076 a 0.692  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.089sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 53 tr: l 0.893 a 0.760  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.146759 cl_acc 0.500 217.557sec(train) 6.084sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 53 tst: l 1.068 a 0.698  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.126sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 54 tr: l 0.897 a 0.758  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.145292 cl_acc 0.500 179.619sec(train) 5.472sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 54 tst: l 1.074 a 0.693  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.160sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 55 tr: l 0.879 a 0.762  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.143839 cl_acc 0.500 170.338sec(train) 5.223sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 55 tst: l 1.057 a 0.698  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.007sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 56 tr: l 0.859 a 0.769  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.142400 cl_acc 0.500 177.905sec(train) 5.332sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 56 tst: l 1.056 a 0.698  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.037sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 57 tr: l 0.849 a 0.775  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.140976 cl_acc 0.500 170.973sec(train) 5.202sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 57 tst: l 1.052 a 0.704  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.984sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 58 tr: l 0.856 a 0.771  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.139567 cl_acc 0.500 174.777sec(train) 5.259sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 58 tst: l 1.046 a 0.701  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.950sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 59 tr: l 0.860 a 0.769  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.138171 cl_acc 0.500 173.451sec(train) 5.827sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 59 tst: l 1.054 a 0.700  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.043sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 60 tr: l 0.846 a 0.774  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.136789 cl_acc 0.500 220.732sec(train) 6.987sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 60 tst: l 1.041 a 0.705  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.214sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 61 tr: l 0.876 a 0.761  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.135421 cl_acc 0.500 231.558sec(train) 6.310sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 61 tst: l 1.047 a 0.702  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.176sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 62 tr: l 0.828 a 0.780  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.134067 cl_acc 0.500 185.368sec(train) 4.961sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 62 tst: l 1.034 a 0.707  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.926sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 63 tr: l 0.836 a 0.777  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.132726 cl_acc 0.500 171.244sec(train) 5.121sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 63 tst: l 1.029 a 0.709  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.019sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 64 tr: l 0.833 a 0.778  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.131399 cl_acc 0.500 170.221sec(train) 5.579sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 64 tst: l 1.029 a 0.708  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.016sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 65 tr: l 0.868 a 0.765  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.130085 cl_acc 0.500 171.863sec(train) 5.218sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 65 tst: l 1.030 a 0.709  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.040sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 66 tr: l 0.821 a 0.782  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.128784 cl_acc 0.500 174.280sec(train) 5.766sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 66 tst: l 1.030 a 0.708  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.185sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 67 tr: l 0.813 a 0.785  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.127496 cl_acc 0.500 177.761sec(train) 6.220sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 67 tst: l 1.020 a 0.711  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.212sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 68 tr: l 0.832 a 0.778  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.126221 cl_acc 0.500 223.594sec(train) 6.411sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 68 tst: l 1.018 a 0.710  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.116sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 69 tr: l 0.840 a 0.773  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.124959 cl_acc 0.500 224.042sec(train) 7.062sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 69 tst: l 1.012 a 0.713  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.364sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 70 tr: l 0.795 a 0.790  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.123710 cl_acc 0.500 181.576sec(train) 6.151sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 70 tst: l 1.015 a 0.711  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.280sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 71 tr: l 0.824 a 0.781  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.122473 cl_acc 0.500 164.983sec(train) 5.209sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 71 tst: l 1.016 a 0.712  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.065sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 72 tr: l 0.807 a 0.785  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.121248 cl_acc 0.500 173.644sec(train) 5.181sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 72 tst: l 1.009 a 0.713  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.013sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 73 tr: l 0.834 a 0.776  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.120035 cl_acc 0.500 174.837sec(train) 5.065sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 73 tst: l 1.008 a 0.714  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.026sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 74 tr: l 0.828 a 0.777  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.118835 cl_acc 0.500 167.272sec(train) 5.501sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 74 tst: l 0.999 a 0.716  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.043sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 75 tr: l 0.796 a 0.789  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.117647 cl_acc 0.500 168.526sec(train) 5.748sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 75 tst: l 0.995 a 0.717  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.150sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 76 tr: l 0.797 a 0.788  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.116470 cl_acc 0.500 191.874sec(train) 6.040sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 76 tst: l 0.998 a 0.719  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.127sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 77 tr: l 0.791 a 0.790  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.115305 cl_acc 0.500 231.509sec(train) 6.891sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 77 tst: l 0.998 a 0.719  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.183sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 78 tr: l 0.793 a 0.789  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.114152 cl_acc 0.500 217.092sec(train) 5.439sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 78 tst: l 0.988 a 0.719  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.031sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 79 tr: l 0.788 a 0.790  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.113011 cl_acc 0.500 177.714sec(train) 5.023sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 79 tst: l 0.992 a 0.716  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.947sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 80 tr: l 0.764 a 0.798  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.111881 cl_acc 0.500 177.622sec(train) 5.346sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 80 tst: l 0.994 a 0.718  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.084sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 81 tr: l 0.761 a 0.801  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.110762 cl_acc 0.500 180.490sec(train) 5.242sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 81 tst: l 0.985 a 0.720  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.955sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 82 tr: l 0.768 a 0.796  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.109654 cl_acc 0.500 174.315sec(train) 5.590sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 82 tst: l 0.993 a 0.718  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.994sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 83 tr: l 0.787 a 0.790  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.108558 cl_acc 0.500 177.219sec(train) 4.919sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 83 tst: l 0.983 a 0.721  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.953sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 84 tr: l 0.761 a 0.798  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.107472 cl_acc 0.500 205.257sec(train) 5.873sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 84 tst: l 0.982 a 0.722  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.086sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 85 tr: l 0.761 a 0.799  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.106398 cl_acc 0.500 224.387sec(train) 6.866sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 85 tst: l 0.979 a 0.724  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.304sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 86 tr: l 0.762 a 0.798  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.105334 cl_acc 0.500 211.091sec(train) 5.107sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 86 tst: l 0.975 a 0.724  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.087sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 87 tr: l 0.740 a 0.807  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.104280 cl_acc 0.500 210.268sec(train) 6.514sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 87 tst: l 0.973 a 0.722  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.243sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 88 tr: l 0.750 a 0.802  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.103237 cl_acc 0.500 212.783sec(train) 6.462sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 88 tst: l 0.964 a 0.725  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.238sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 89 tr: l 0.760 a 0.797  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.102205 cl_acc 0.500 211.910sec(train) 6.918sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 89 tst: l 0.966 a 0.726  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.229sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 90 tr: l 0.728 a 0.809  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.101183 cl_acc 0.500 186.616sec(train) 5.495sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 90 tst: l 0.965 a 0.725  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.125sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 91 tr: l 0.751 a 0.801  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.100171 cl_acc 0.500 164.462sec(train) 5.557sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 91 tst: l 0.964 a 0.727  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.152sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 92 tr: l 0.732 a 0.807  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.099169 cl_acc 0.500 197.285sec(train) 6.246sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 92 tst: l 0.967 a 0.725  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.150sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 93 tr: l 0.751 a 0.799  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.098178 cl_acc 0.500 195.474sec(train) 6.061sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 93 tst: l 0.962 a 0.727  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.180sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 94 tr: l 0.738 a 0.804  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.097196 cl_acc 0.500 198.773sec(train) 5.977sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 94 tst: l 0.953 a 0.728  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.163sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 95 tr: l 0.721 a 0.808  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.096224 cl_acc 0.500 199.484sec(train) 5.912sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 95 tst: l 0.947 a 0.731  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.171sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 96 tr: l 0.733 a 0.806  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.095262 cl_acc 0.500 203.127sec(train) 6.547sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 96 tst: l 0.945 a 0.732  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.159sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 97 tr: l 0.737 a 0.804  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.094309 cl_acc 0.500 204.280sec(train) 5.750sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 97 tst: l 0.947 a 0.731  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.126sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 98 tr: l 0.718 a 0.811  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.093366 cl_acc 0.500 202.424sec(train) 6.061sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 98 tst: l 0.941 a 0.735  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.269sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 99 tr: l 0.724 a 0.809  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.092432 cl_acc 0.500 205.035sec(train) 6.142sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 99 tst: l 0.947 a 0.731  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.248sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 100 tr: l 0.748 a 0.799  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.091508 cl_acc 0.500 204.712sec(train) 6.492sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 100 tst: l 0.945 a 0.730  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.259sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 101 tr: l 0.701 a 0.817  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.090593 cl_acc 0.500 206.038sec(train) 6.137sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 101 tst: l 0.942 a 0.728  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.205sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 102 tr: l 0.697 a 0.817  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.089687 cl_acc 0.500 201.433sec(train) 6.414sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 102 tst: l 0.939 a 0.735  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.292sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 103 tr: l 0.687 a 0.821  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.088790 cl_acc 0.500 201.458sec(train) 6.052sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 103 tst: l 0.939 a 0.733  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.151sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 104 tr: l 0.708 a 0.813  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.087902 cl_acc 0.500 198.904sec(train) 6.256sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 104 tst: l 0.937 a 0.733  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.233sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 105 tr: l 0.696 a 0.816  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.087023 cl_acc 0.500 196.466sec(train) 6.204sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 105 tst: l 0.934 a 0.734  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.242sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 106 tr: l 0.701 a 0.815  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.086153 cl_acc 0.500 221.588sec(train) 5.870sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 106 tst: l 0.932 a 0.735  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.176sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 107 tr: l 0.689 a 0.819  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.085292 cl_acc 0.500 219.003sec(train) 5.918sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 107 tst: l 0.928 a 0.736  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.278sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 108 tr: l 0.684 a 0.820  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.084439 cl_acc 0.500 233.337sec(train) 7.338sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 108 tst: l 0.924 a 0.736  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.411sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 109 tr: l 0.686 a 0.822  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.083594 cl_acc 0.500 252.858sec(train) 7.296sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 109 tst: l 0.925 a 0.738  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.479sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 110 tr: l 0.699 a 0.816  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.082758 cl_acc 0.500 240.166sec(train) 5.819sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 110 tst: l 0.925 a 0.738  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.094sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 111 tr: l 0.690 a 0.818  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.081931 cl_acc 0.500 203.578sec(train) 5.675sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 111 tst: l 0.917 a 0.741  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.122sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 112 tr: l 0.702 a 0.814  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.081111 cl_acc 0.500 204.307sec(train) 6.618sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 112 tst: l 0.928 a 0.736  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.146sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 113 tr: l 0.689 a 0.818  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.080300 cl_acc 0.500 204.936sec(train) 5.778sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 113 tst: l 0.915 a 0.740  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.087sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 114 tr: l 0.672 a 0.824  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.079497 cl_acc 0.500 207.223sec(train) 5.942sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 114 tst: l 0.917 a 0.739  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.217sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 115 tr: l 0.679 a 0.821  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.078702 cl_acc 0.500 213.558sec(train) 6.264sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 115 tst: l 0.915 a 0.736  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.093sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 116 tr: l 0.677 a 0.821  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.077915 cl_acc 0.500 236.503sec(train) 8.012sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 116 tst: l 0.909 a 0.742  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 2.000sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 117 tr: l 0.665 a 0.826  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.077136 cl_acc 0.500 259.160sec(train) 7.632sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 117 tst: l 0.911 a 0.740  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.542sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 118 tr: l 0.677 a 0.821  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.076365 cl_acc 0.500 228.507sec(train) 6.106sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 118 tst: l 0.913 a 0.742  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.151sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 119 tr: l 0.665 a 0.826  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.075601 cl_acc 0.500 203.292sec(train) 5.639sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 119 tst: l 0.910 a 0.743  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.094sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 120 tr: l 0.665 a 0.824  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.074845 cl_acc 0.500 206.164sec(train) 6.237sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 120 tst: l 0.909 a 0.741  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.203sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 121 tr: l 0.670 a 0.823  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.074097 cl_acc 0.500 210.399sec(train) 6.669sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 121 tst: l 0.906 a 0.745  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.237sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 122 tr: l 0.637 a 0.833  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.073356 cl_acc 0.500 212.383sec(train) 6.025sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 122 tst: l 0.909 a 0.744  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.163sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 123 tr: l 0.667 a 0.823  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.072622 cl_acc 0.500 214.597sec(train) 8.486sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 123 tst: l 0.902 a 0.744  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.498sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 124 tr: l 0.681 a 0.817  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.071896 cl_acc 0.500 237.651sec(train) 6.527sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 124 tst: l 0.904 a 0.742  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.283sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 125 tr: l 0.665 a 0.825  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.071177 cl_acc 0.500 197.788sec(train) 5.861sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 125 tst: l 0.896 a 0.745  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.148sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 126 tr: l 0.642 a 0.832  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.070465 cl_acc 0.500 190.796sec(train) 5.361sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 126 tst: l 0.894 a 0.746  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.067sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 127 tr: l 0.662 a 0.824  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.069761 cl_acc 0.500 192.798sec(train) 5.605sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 127 tst: l 0.898 a 0.747  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.038sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 128 tr: l 0.669 a 0.821  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.069063 cl_acc 0.500 195.819sec(train) 5.940sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 128 tst: l 0.896 a 0.746  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.098sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 129 tr: l 0.631 a 0.834  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.068372 cl_acc 0.500 195.512sec(train) 6.342sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 129 tst: l 0.896 a 0.746  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.170sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 130 tr: l 0.645 a 0.829  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.067689 cl_acc 0.500 190.586sec(train) 5.345sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 130 tst: l 0.897 a 0.746  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.089sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 131 tr: l 0.640 a 0.832  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.067012 cl_acc 0.500 185.462sec(train) 5.307sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 131 tst: l 0.897 a 0.746  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.164sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 132 tr: l 0.644 a 0.830  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.066342 cl_acc 0.500 170.941sec(train) 5.987sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 132 tst: l 0.886 a 0.748  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.053sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 133 tr: l 0.644 a 0.830  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.065678 cl_acc 0.500 239.465sec(train) 5.656sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 133 tst: l 0.893 a 0.748  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.035sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 134 tr: l 0.639 a 0.830  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.065021 cl_acc 0.500 198.287sec(train) 5.401sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 134 tst: l 0.889 a 0.748  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.025sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 135 tr: l 0.642 a 0.830  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.064371 cl_acc 0.500 201.412sec(train) 5.328sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 135 tst: l 0.888 a 0.746  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.969sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 136 tr: l 0.636 a 0.832  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.063727 cl_acc 0.500 200.969sec(train) 5.294sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 136 tst: l 0.877 a 0.751  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.993sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 137 tr: l 0.626 a 0.835  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.063090 cl_acc 0.500 199.098sec(train) 5.233sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 137 tst: l 0.880 a 0.750  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.126sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 138 tr: l 0.640 a 0.831  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.062459 cl_acc 0.500 199.489sec(train) 5.394sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 138 tst: l 0.879 a 0.751  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.008sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 139 tr: l 0.638 a 0.830  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.061835 cl_acc 0.500 206.024sec(train) 6.629sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 139 tst: l 0.885 a 0.747  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.257sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 140 tr: l 0.599 a 0.845  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.061216 cl_acc 0.500 240.978sec(train) 6.961sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 140 tst: l 0.873 a 0.751  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.280sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 141 tr: l 0.629 a 0.834  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.060604 cl_acc 0.500 241.026sec(train) 5.977sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 141 tst: l 0.874 a 0.752  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.124sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 142 tr: l 0.618 a 0.836  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.059998 cl_acc 0.500 196.498sec(train) 6.340sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 142 tst: l 0.881 a 0.750  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.087sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 143 tr: l 0.629 a 0.834  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.059398 cl_acc 0.500 191.778sec(train) 5.136sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 143 tst: l 0.873 a 0.752  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.073sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 144 tr: l 0.603 a 0.841  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.058804 cl_acc 0.500 179.474sec(train) 5.310sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 144 tst: l 0.872 a 0.751  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.024sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 145 tr: l 0.617 a 0.836  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.058216 cl_acc 0.500 183.623sec(train) 5.361sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 145 tst: l 0.875 a 0.753  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.959sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 146 tr: l 0.618 a 0.837  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.057634 cl_acc 0.500 189.044sec(train) 5.217sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 146 tst: l 0.874 a 0.752  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.023sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 147 tr: l 0.602 a 0.841  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.057058 cl_acc 0.500 180.521sec(train) 5.332sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 147 tst: l 0.871 a 0.754  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.057sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 148 tr: l 0.612 a 0.836  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.056487 cl_acc 0.500 208.646sec(train) 8.182sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 148 tst: l 0.872 a 0.754  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.630sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 149 tr: l 0.598 a 0.842  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.055922 cl_acc 0.500 237.084sec(train) 8.616sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 149 tst: l 0.866 a 0.754  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.797sec\n",
      "result written at output/results.pickle\n",
      "---train cluster Ended in 8.17 hour (29407.204 sec) \n",
      "---------------------------------DFedAvgM, lr: 0.25, seed: 4506---------------------------------\n",
      "config: {'m': 50, 'm_test': 10, 'p': 2, 'n': 2000, 'local_model_init': False, 'participation_rate': 1, 'Gp': 0.25, 'graph': 'er', 'agg': 'seq', 'num_epochs': 150, 'batch_size': 50, 'tau': 10, 'lr': 0.25, 'data_seed': 4506, 'train_seed': 4506, 'project_dir': 'output'}\n",
      "Using device: cuda:0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "I0000 00:00:1758481144.318321 1488169 gpu_device.cc:2019] Created device /job:localhost/replica:0/task:0/device:GPU:0 with 33884 MB memory:  -> device: 2, name: NVIDIA A100-SXM4-40GB, pci bus id: 0000:81:00.0, compute capability: 8.0\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch -1 tr: l 4.677 a 0.099  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] cl_acc 0.500 8.493sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch -1 tst: l 4.677 a 0.101  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.556sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0 tr: l 3.298 a 0.215  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.250000 cl_acc 0.500 210.256sec(train) 5.327sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0 tst: l 3.283 a 0.234  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.110sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1 tr: l 2.448 a 0.351  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.247500 cl_acc 0.500 183.676sec(train) 5.200sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1 tst: l 2.411 a 0.374  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.992sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2 tr: l 1.957 a 0.420  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.245025 cl_acc 0.500 182.252sec(train) 5.356sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2 tst: l 1.902 a 0.447  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.109sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3 tr: l 1.689 a 0.477  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.242575 cl_acc 0.500 180.575sec(train) 5.612sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3 tst: l 1.641 a 0.497  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.103sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4 tr: l 1.542 a 0.524  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.240149 cl_acc 0.500 182.163sec(train) 5.724sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4 tst: l 1.501 a 0.534  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.061sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5 tr: l 1.445 a 0.560  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.237748 cl_acc 0.500 183.375sec(train) 5.786sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5 tst: l 1.405 a 0.572  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.032sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6 tr: l 1.378 a 0.578  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.235370 cl_acc 0.500 187.328sec(train) 6.112sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6 tst: l 1.344 a 0.585  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.205sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7 tr: l 1.339 a 0.595  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.233016 cl_acc 0.500 225.681sec(train) 7.278sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7 tst: l 1.318 a 0.601  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.296sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8 tr: l 1.289 a 0.615  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.230686 cl_acc 0.500 232.779sec(train) 6.326sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8 tst: l 1.286 a 0.614  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.285sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9 tr: l 1.265 a 0.621  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.228379 cl_acc 0.500 184.934sec(train) 5.624sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9 tst: l 1.268 a 0.615  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.063sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10 tr: l 1.238 a 0.633  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.226096 cl_acc 0.500 192.622sec(train) 5.853sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10 tst: l 1.245 a 0.628  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.114sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11 tr: l 1.218 a 0.642  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.223835 cl_acc 0.500 186.148sec(train) 5.471sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11 tst: l 1.241 a 0.630  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.113sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12 tr: l 1.212 a 0.648  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.221596 cl_acc 0.500 176.529sec(train) 5.289sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12 tst: l 1.220 a 0.641  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.057sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13 tr: l 1.193 a 0.653  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.219380 cl_acc 0.500 171.307sec(train) 5.338sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13 tst: l 1.208 a 0.648  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.004sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14 tr: l 1.171 a 0.659  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.217186 cl_acc 0.500 169.549sec(train) 5.103sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14 tst: l 1.201 a 0.647  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.989sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15 tr: l 1.136 a 0.674  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.215015 cl_acc 0.500 169.194sec(train) 5.068sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15 tst: l 1.191 a 0.651  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.033sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16 tr: l 1.143 a 0.670  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.212864 cl_acc 0.500 172.017sec(train) 5.267sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16 tst: l 1.179 a 0.660  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.000sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17 tr: l 1.124 a 0.679  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.210736 cl_acc 0.500 166.251sec(train) 4.905sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17 tst: l 1.170 a 0.661  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.853sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18 tr: l 1.116 a 0.681  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.208628 cl_acc 0.500 166.423sec(train) 4.964sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18 tst: l 1.167 a 0.661  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.941sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19 tr: l 1.132 a 0.677  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.206542 cl_acc 0.500 163.088sec(train) 4.754sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19 tst: l 1.169 a 0.662  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.879sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20 tr: l 1.075 a 0.697  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.204477 cl_acc 0.500 157.600sec(train) 5.010sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20 tst: l 1.154 a 0.668  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.050sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21 tr: l 1.097 a 0.690  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.202432 cl_acc 0.500 158.280sec(train) 4.986sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21 tst: l 1.149 a 0.669  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.021sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22 tr: l 1.072 a 0.699  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.200408 cl_acc 0.500 155.039sec(train) 5.169sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22 tst: l 1.156 a 0.668  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.044sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23 tr: l 1.061 a 0.704  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.198404 cl_acc 0.500 153.284sec(train) 5.084sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23 tst: l 1.140 a 0.672  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.952sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24 tr: l 1.074 a 0.698  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.196420 cl_acc 0.500 159.994sec(train) 5.020sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24 tst: l 1.129 a 0.676  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.074sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25 tr: l 1.038 a 0.713  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.194455 cl_acc 0.500 155.016sec(train) 4.833sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25 tst: l 1.128 a 0.679  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.052sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 26 tr: l 1.078 a 0.696  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.192511 cl_acc 0.500 221.109sec(train) 5.964sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 26 tst: l 1.126 a 0.678  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.346sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 27 tr: l 1.022 a 0.716  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.190586 cl_acc 0.500 211.427sec(train) 6.741sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 27 tst: l 1.113 a 0.685  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.079sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 28 tr: l 1.032 a 0.715  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.188680 cl_acc 0.500 227.815sec(train) 6.339sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 28 tst: l 1.117 a 0.683  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.258sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 29 tr: l 1.028 a 0.715  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.186793 cl_acc 0.500 236.773sec(train) 7.053sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 29 tst: l 1.106 a 0.687  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.374sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 30 tr: l 1.009 a 0.723  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.184925 cl_acc 0.500 252.919sec(train) 6.715sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 30 tst: l 1.103 a 0.685  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.323sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 31 tr: l 1.033 a 0.712  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.183076 cl_acc 0.500 229.885sec(train) 6.053sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 31 tst: l 1.094 a 0.689  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.159sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 32 tr: l 0.967 a 0.737  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.181245 cl_acc 0.500 206.673sec(train) 5.372sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 32 tst: l 1.096 a 0.690  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.080sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 33 tr: l 0.977 a 0.732  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.179433 cl_acc 0.500 206.567sec(train) 6.150sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 33 tst: l 1.083 a 0.696  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.195sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 34 tr: l 0.973 a 0.733  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.177638 cl_acc 0.500 209.738sec(train) 5.710sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 34 tst: l 1.083 a 0.694  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.125sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 35 tr: l 0.986 a 0.731  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.175862 cl_acc 0.500 204.048sec(train) 5.810sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 35 tst: l 1.074 a 0.700  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 36 tr: l 0.977 a 0.734  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.174103 cl_acc 0.500 209.115sec(train) 6.675sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 36 tst: l 1.076 a 0.698  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.394sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 37 tr: l 0.952 a 0.742  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.172362 cl_acc 0.500 238.590sec(train) 6.251sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 37 tst: l 1.070 a 0.699  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.201sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 38 tr: l 0.984 a 0.728  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.170639 cl_acc 0.500 240.367sec(train) 6.765sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 38 tst: l 1.069 a 0.699  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.282sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 39 tr: l 0.943 a 0.746  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.168932 cl_acc 0.500 203.160sec(train) 5.672sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 39 tst: l 1.065 a 0.701  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.175sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 40 tr: l 0.957 a 0.740  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.167243 cl_acc 0.500 203.119sec(train) 6.170sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 40 tst: l 1.055 a 0.705  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.166sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 41 tr: l 0.940 a 0.745  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.165571 cl_acc 0.500 197.252sec(train) 5.833sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 41 tst: l 1.056 a 0.702  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.035sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 42 tr: l 0.928 a 0.751  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.163915 cl_acc 0.500 197.415sec(train) 6.231sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 42 tst: l 1.046 a 0.709  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.222sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 43 tr: l 0.930 a 0.748  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.162276 cl_acc 0.500 198.496sec(train) 5.803sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 43 tst: l 1.044 a 0.707  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.127sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 44 tr: l 0.921 a 0.751  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.160653 cl_acc 0.500 218.191sec(train) 7.101sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 44 tst: l 1.040 a 0.708  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.345sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 45 tr: l 0.915 a 0.753  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.159046 cl_acc 0.500 223.551sec(train) 6.775sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 45 tst: l 1.035 a 0.712  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.490sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 46 tr: l 0.906 a 0.756  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.157456 cl_acc 0.500 221.087sec(train) 6.818sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 46 tst: l 1.031 a 0.712  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.313sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 47 tr: l 0.907 a 0.757  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.155881 cl_acc 0.500 227.909sec(train) 6.581sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 47 tst: l 1.026 a 0.713  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.268sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 48 tr: l 0.896 a 0.760  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.154323 cl_acc 0.500 215.638sec(train) 6.387sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 48 tst: l 1.029 a 0.713  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.371sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 49 tr: l 0.910 a 0.754  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.152779 cl_acc 0.500 212.755sec(train) 6.342sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 49 tst: l 1.019 a 0.714  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.257sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 50 tr: l 0.919 a 0.749  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.151252 cl_acc 0.500 211.234sec(train) 6.383sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 50 tst: l 1.024 a 0.712  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.206sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 51 tr: l 0.887 a 0.760  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.149739 cl_acc 0.500 212.028sec(train) 6.154sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 51 tst: l 1.016 a 0.718  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.071sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 52 tr: l 0.885 a 0.761  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.148242 cl_acc 0.500 206.529sec(train) 6.519sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 52 tst: l 1.016 a 0.715  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.162sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 53 tr: l 0.868 a 0.768  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.146759 cl_acc 0.500 203.738sec(train) 6.338sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 53 tst: l 1.009 a 0.719  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.202sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 54 tr: l 0.853 a 0.775  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.145292 cl_acc 0.500 203.441sec(train) 6.108sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 54 tst: l 1.014 a 0.719  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.037sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 55 tr: l 0.877 a 0.764  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.143839 cl_acc 0.500 203.866sec(train) 6.433sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 55 tst: l 1.003 a 0.721  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.318sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 56 tr: l 0.880 a 0.763  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.142400 cl_acc 0.500 204.667sec(train) 6.273sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 56 tst: l 1.010 a 0.719  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.176sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 57 tr: l 0.879 a 0.763  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.140976 cl_acc 0.500 206.137sec(train) 6.557sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 57 tst: l 1.000 a 0.721  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.170sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 58 tr: l 0.862 a 0.770  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.139567 cl_acc 0.500 202.733sec(train) 6.724sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 58 tst: l 0.991 a 0.724  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.103sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 59 tr: l 0.851 a 0.771  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.138171 cl_acc 0.500 201.077sec(train) 6.271sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 59 tst: l 0.991 a 0.722  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.258sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 60 tr: l 0.840 a 0.777  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.136789 cl_acc 0.500 213.402sec(train) 6.332sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 60 tst: l 0.991 a 0.725  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.257sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 61 tr: l 0.850 a 0.772  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.135421 cl_acc 0.500 196.922sec(train) 6.014sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 61 tst: l 0.986 a 0.724  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.172sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 62 tr: l 0.850 a 0.772  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.134067 cl_acc 0.500 202.105sec(train) 6.812sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 62 tst: l 0.985 a 0.723  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.246sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 63 tr: l 0.809 a 0.786  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.132726 cl_acc 0.500 224.644sec(train) 6.408sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 63 tst: l 0.978 a 0.729  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.306sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 64 tr: l 0.843 a 0.773  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.131399 cl_acc 0.500 234.316sec(train) 5.892sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 64 tst: l 0.984 a 0.726  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.152sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 65 tr: l 0.830 a 0.777  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.130085 cl_acc 0.500 219.996sec(train) 6.091sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 65 tst: l 0.977 a 0.730  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.186sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 66 tr: l 0.827 a 0.779  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.128784 cl_acc 0.500 220.345sec(train) 5.768sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 66 tst: l 0.972 a 0.731  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.152sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 67 tr: l 0.791 a 0.791  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.127496 cl_acc 0.500 238.580sec(train) 6.491sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 67 tst: l 0.962 a 0.732  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.315sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 68 tr: l 0.823 a 0.780  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.126221 cl_acc 0.500 241.812sec(train) 6.003sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 68 tst: l 0.965 a 0.731  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.200sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 69 tr: l 0.827 a 0.778  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.124959 cl_acc 0.500 239.882sec(train) 6.046sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 69 tst: l 0.964 a 0.733  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.140sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 70 tr: l 0.793 a 0.789  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.123710 cl_acc 0.500 208.958sec(train) 5.493sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 70 tst: l 0.963 a 0.732  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.086sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 71 tr: l 0.816 a 0.781  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.122473 cl_acc 0.500 200.297sec(train) 5.886sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 71 tst: l 0.961 a 0.734  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.153sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 72 tr: l 0.786 a 0.793  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.121248 cl_acc 0.500 200.655sec(train) 5.883sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 72 tst: l 0.953 a 0.736  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.212sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 73 tr: l 0.816 a 0.779  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.120035 cl_acc 0.500 195.852sec(train) 5.303sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 73 tst: l 0.955 a 0.734  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.099sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 74 tr: l 0.794 a 0.789  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.118835 cl_acc 0.500 192.817sec(train) 5.912sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 74 tst: l 0.954 a 0.734  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 75 tr: l 0.806 a 0.784  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.117647 cl_acc 0.500 224.426sec(train) 6.693sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 75 tst: l 0.957 a 0.733  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.201sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 76 tr: l 0.766 a 0.797  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.116470 cl_acc 0.500 238.660sec(train) 6.638sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 76 tst: l 0.948 a 0.735  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.376sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 77 tr: l 0.771 a 0.797  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.115305 cl_acc 0.500 226.435sec(train) 5.779sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 77 tst: l 0.940 a 0.739  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.125sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 78 tr: l 0.776 a 0.794  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.114152 cl_acc 0.500 202.934sec(train) 7.851sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 78 tst: l 0.944 a 0.739  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.783sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 79 tr: l 0.769 a 0.794  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.113011 cl_acc 0.500 198.814sec(train) 6.582sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 79 tst: l 0.938 a 0.741  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.169sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 80 tr: l 0.781 a 0.789  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.111881 cl_acc 0.500 211.638sec(train) 6.528sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 80 tst: l 0.932 a 0.743  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.183sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 81 tr: l 0.760 a 0.798  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.110762 cl_acc 0.500 215.607sec(train) 6.576sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 81 tst: l 0.937 a 0.741  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.343sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 82 tr: l 0.787 a 0.788  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.109654 cl_acc 0.500 216.209sec(train) 6.905sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 82 tst: l 0.932 a 0.739  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.286sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 83 tr: l 0.760 a 0.797  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.108558 cl_acc 0.500 215.115sec(train) 6.712sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 83 tst: l 0.932 a 0.741  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.301sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 84 tr: l 0.785 a 0.787  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.107472 cl_acc 0.500 210.881sec(train) 6.232sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 84 tst: l 0.927 a 0.743  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.254sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 85 tr: l 0.747 a 0.802  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.106398 cl_acc 0.500 206.966sec(train) 6.316sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 85 tst: l 0.929 a 0.742  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.096sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 86 tr: l 0.742 a 0.804  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.105334 cl_acc 0.500 207.986sec(train) 7.090sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 86 tst: l 0.930 a 0.740  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.250sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 87 tr: l 0.756 a 0.800  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.104280 cl_acc 0.500 201.673sec(train) 6.257sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 87 tst: l 0.918 a 0.746  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.358sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 88 tr: l 0.754 a 0.801  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.103237 cl_acc 0.500 203.634sec(train) 5.805sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 88 tst: l 0.921 a 0.745  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.252sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 89 tr: l 0.745 a 0.802  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.102205 cl_acc 0.500 202.869sec(train) 6.180sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 89 tst: l 0.913 a 0.748  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.323sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 90 tr: l 0.731 a 0.808  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.101183 cl_acc 0.500 189.170sec(train) 6.060sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 90 tst: l 0.921 a 0.746  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.185sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 91 tr: l 0.730 a 0.806  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.100171 cl_acc 0.500 199.941sec(train) 6.099sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 91 tst: l 0.914 a 0.746  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.273sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 92 tr: l 0.740 a 0.805  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.099169 cl_acc 0.500 190.481sec(train) 6.281sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 92 tst: l 0.915 a 0.747  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.057sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 93 tr: l 0.739 a 0.803  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.098178 cl_acc 0.500 189.332sec(train) 5.550sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 93 tst: l 0.913 a 0.746  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.165sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 94 tr: l 0.733 a 0.805  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.097196 cl_acc 0.500 219.672sec(train) 6.141sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 94 tst: l 0.915 a 0.745  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.272sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 95 tr: l 0.729 a 0.806  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.096224 cl_acc 0.500 224.968sec(train) 6.518sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 95 tst: l 0.912 a 0.745  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.580sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 96 tr: l 0.710 a 0.815  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.095262 cl_acc 0.500 195.094sec(train) 6.100sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 96 tst: l 0.908 a 0.748  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.125sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 97 tr: l 0.725 a 0.807  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.094309 cl_acc 0.500 229.361sec(train) 6.483sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 97 tst: l 0.909 a 0.749  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.268sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 98 tr: l 0.730 a 0.803  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.093366 cl_acc 0.500 241.296sec(train) 5.941sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 98 tst: l 0.904 a 0.751  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.139sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 99 tr: l 0.702 a 0.816  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.092432 cl_acc 0.500 241.180sec(train) 6.418sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 99 tst: l 0.898 a 0.749  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.315sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 100 tr: l 0.718 a 0.809  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.091508 cl_acc 0.500 250.199sec(train) 6.195sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 100 tst: l 0.900 a 0.749  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.173sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 101 tr: l 0.736 a 0.802  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.090593 cl_acc 0.500 243.643sec(train) 6.391sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 101 tst: l 0.894 a 0.752  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.350sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 102 tr: l 0.699 a 0.815  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.089687 cl_acc 0.500 245.193sec(train) 6.296sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 102 tst: l 0.893 a 0.753  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.233sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 103 tr: l 0.707 a 0.812  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.088790 cl_acc 0.500 215.416sec(train) 6.084sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 103 tst: l 0.896 a 0.754  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.178sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 104 tr: l 0.707 a 0.812  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.087902 cl_acc 0.500 215.726sec(train) 6.084sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 104 tst: l 0.893 a 0.750  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.249sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 105 tr: l 0.677 a 0.822  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.087023 cl_acc 0.500 215.584sec(train) 6.247sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 105 tst: l 0.890 a 0.751  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.185sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 106 tr: l 0.700 a 0.814  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.086153 cl_acc 0.500 211.812sec(train) 6.922sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 106 tst: l 0.880 a 0.754  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.325sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 107 tr: l 0.683 a 0.820  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.085292 cl_acc 0.500 229.629sec(train) 7.968sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 107 tst: l 0.883 a 0.755  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.592sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 108 tr: l 0.700 a 0.813  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.084439 cl_acc 0.500 250.989sec(train) 8.590sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 108 tst: l 0.880 a 0.755  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.633sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 109 tr: l 0.683 a 0.819  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.083594 cl_acc 0.500 236.178sec(train) 6.681sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 109 tst: l 0.882 a 0.753  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.276sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 110 tr: l 0.706 a 0.812  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.082758 cl_acc 0.500 201.152sec(train) 6.384sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 110 tst: l 0.891 a 0.751  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.203sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 111 tr: l 0.691 a 0.817  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.081931 cl_acc 0.500 199.500sec(train) 6.680sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 111 tst: l 0.881 a 0.756  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.346sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 112 tr: l 0.674 a 0.823  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.081111 cl_acc 0.500 206.376sec(train) 6.157sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 112 tst: l 0.883 a 0.755  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.137sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 113 tr: l 0.674 a 0.823  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.080300 cl_acc 0.500 201.507sec(train) 5.970sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 113 tst: l 0.877 a 0.758  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.254sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 114 tr: l 0.661 a 0.826  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.079497 cl_acc 0.500 226.251sec(train) 6.469sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 114 tst: l 0.878 a 0.757  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.304sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 115 tr: l 0.667 a 0.826  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.078702 cl_acc 0.500 238.876sec(train) 5.990sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 115 tst: l 0.878 a 0.756  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.195sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 116 tr: l 0.667 a 0.823  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.077915 cl_acc 0.500 199.162sec(train) 5.554sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 116 tst: l 0.867 a 0.761  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.041sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 117 tr: l 0.657 a 0.826  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.077136 cl_acc 0.500 196.058sec(train) 5.645sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 117 tst: l 0.873 a 0.758  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.034sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 118 tr: l 0.654 a 0.827  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.076365 cl_acc 0.500 188.058sec(train) 5.544sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 118 tst: l 0.863 a 0.760  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.096sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 119 tr: l 0.684 a 0.816  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.075601 cl_acc 0.500 228.647sec(train) 7.050sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 119 tst: l 0.863 a 0.761  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.289sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 120 tr: l 0.654 a 0.826  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.074845 cl_acc 0.500 236.192sec(train) 7.881sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 120 tst: l 0.866 a 0.759  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 2.392sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 121 tr: l 0.670 a 0.822  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.074097 cl_acc 0.500 214.861sec(train) 5.743sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 121 tst: l 0.866 a 0.761  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.183sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 122 tr: l 0.664 a 0.823  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.073356 cl_acc 0.500 193.614sec(train) 5.870sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 122 tst: l 0.869 a 0.758  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.124sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 123 tr: l 0.638 a 0.832  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.072622 cl_acc 0.500 192.422sec(train) 6.154sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 123 tst: l 0.857 a 0.762  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.062sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 124 tr: l 0.634 a 0.833  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.071896 cl_acc 0.500 191.654sec(train) 6.554sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 124 tst: l 0.862 a 0.763  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.279sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 125 tr: l 0.631 a 0.835  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.071177 cl_acc 0.500 190.990sec(train) 5.755sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 125 tst: l 0.860 a 0.760  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.108sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 126 tr: l 0.652 a 0.827  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.070465 cl_acc 0.500 208.914sec(train) 6.854sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 126 tst: l 0.849 a 0.764  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.279sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 127 tr: l 0.649 a 0.827  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.069761 cl_acc 0.500 236.845sec(train) 6.771sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 127 tst: l 0.856 a 0.764  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.202sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 128 tr: l 0.650 a 0.828  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.069063 cl_acc 0.500 232.677sec(train) 6.706sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 128 tst: l 0.853 a 0.763  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.404sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 129 tr: l 0.640 a 0.830  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.068372 cl_acc 0.500 183.732sec(train) 5.243sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 129 tst: l 0.856 a 0.764  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.023sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 130 tr: l 0.625 a 0.834  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.067689 cl_acc 0.500 183.764sec(train) 5.952sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 130 tst: l 0.852 a 0.765  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.119sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 131 tr: l 0.632 a 0.832  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.067012 cl_acc 0.500 182.130sec(train) 5.516sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 131 tst: l 0.846 a 0.765  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.047sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 132 tr: l 0.653 a 0.824  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.066342 cl_acc 0.500 175.231sec(train) 5.651sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 132 tst: l 0.845 a 0.766  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.116sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 133 tr: l 0.636 a 0.831  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.065678 cl_acc 0.500 178.950sec(train) 5.943sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 133 tst: l 0.841 a 0.767  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.037sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 134 tr: l 0.615 a 0.838  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.065021 cl_acc 0.500 177.804sec(train) 6.404sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 134 tst: l 0.839 a 0.767  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.268sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 135 tr: l 0.631 a 0.833  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.064371 cl_acc 0.500 225.696sec(train) 6.489sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 135 tst: l 0.839 a 0.767  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.206sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 136 tr: l 0.649 a 0.826  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.063727 cl_acc 0.500 234.510sec(train) 5.950sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 136 tst: l 0.839 a 0.769  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.180sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 137 tr: l 0.638 a 0.829  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.063090 cl_acc 0.500 186.867sec(train) 4.844sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 137 tst: l 0.839 a 0.768  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.015sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 138 tr: l 0.608 a 0.839  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.062459 cl_acc 0.500 169.279sec(train) 5.565sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 138 tst: l 0.841 a 0.768  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.073sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 139 tr: l 0.637 a 0.829  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.061835 cl_acc 0.500 168.494sec(train) 5.912sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 139 tst: l 0.840 a 0.769  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.152sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 140 tr: l 0.623 a 0.834  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.061216 cl_acc 0.500 171.305sec(train) 5.248sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 140 tst: l 0.840 a 0.768  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.025sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 141 tr: l 0.629 a 0.831  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.060604 cl_acc 0.500 171.887sec(train) 5.199sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 141 tst: l 0.834 a 0.770  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.172sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 142 tr: l 0.628 a 0.832  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.059998 cl_acc 0.500 174.294sec(train) 6.176sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 142 tst: l 0.836 a 0.769  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.182sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 143 tr: l 0.597 a 0.842  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.059398 cl_acc 0.500 220.471sec(train) 6.136sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 143 tst: l 0.843 a 0.765  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.328sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 144 tr: l 0.621 a 0.834  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.058804 cl_acc 0.500 222.539sec(train) 5.663sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 144 tst: l 0.836 a 0.770  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.150sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 145 tr: l 0.606 a 0.840  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.058216 cl_acc 0.500 184.399sec(train) 5.947sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 145 tst: l 0.826 a 0.773  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.116sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 146 tr: l 0.615 a 0.835  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.057634 cl_acc 0.500 172.373sec(train) 6.354sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 146 tst: l 0.828 a 0.770  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.306sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 147 tr: l 0.601 a 0.840  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.057058 cl_acc 0.500 164.390sec(train) 4.941sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 147 tst: l 0.829 a 0.772  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.005sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 148 tr: l 0.600 a 0.841  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.056487 cl_acc 0.500 159.842sec(train) 5.939sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 148 tst: l 0.825 a 0.772  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.046sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 149 tr: l 0.612 a 0.836  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.055922 cl_acc 0.500 158.860sec(train) 4.903sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 149 tst: l 0.829 a 0.771  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.927sec\n",
      "result written at output/results.pickle\n",
      "---train cluster Ended in 8.81 hour (31704.267 sec) \n",
      "---------------------------------DFedAvgM, lr: 0.25, seed: 4012---------------------------------\n",
      "config: {'m': 50, 'm_test': 10, 'p': 2, 'n': 2000, 'local_model_init': False, 'participation_rate': 1, 'Gp': 0.25, 'graph': 'er', 'agg': 'seq', 'num_epochs': 150, 'batch_size': 50, 'tau': 10, 'lr': 0.25, 'data_seed': 4012, 'train_seed': 4012, 'project_dir': 'output'}\n",
      "Using device: cuda:0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "I0000 00:00:1758512846.167302 1488169 gpu_device.cc:2019] Created device /job:localhost/replica:0/task:0/device:GPU:0 with 33884 MB memory:  -> device: 2, name: NVIDIA A100-SXM4-40GB, pci bus id: 0000:81:00.0, compute capability: 8.0\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch -1 tr: l 4.680 a 0.092  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] cl_acc 0.500 5.578sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch -1 tst: l 4.681 a 0.084  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.938sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0 tr: l 3.273 a 0.246  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.250000 cl_acc 0.500 160.643sec(train) 4.868sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0 tst: l 3.274 a 0.240  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.080sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1 tr: l 2.417 a 0.358  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.247500 cl_acc 0.500 233.530sec(train) 6.143sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1 tst: l 2.401 a 0.368  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.220sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2 tr: l 1.966 a 0.415  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.245025 cl_acc 0.500 259.642sec(train) 7.208sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2 tst: l 1.917 a 0.431  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.364sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3 tr: l 1.712 a 0.478  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.242575 cl_acc 0.500 188.903sec(train) 6.329sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3 tst: l 1.672 a 0.490  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.188sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4 tr: l 1.566 a 0.518  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.240149 cl_acc 0.500 168.919sec(train) 6.697sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4 tst: l 1.538 a 0.526  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.406sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5 tr: l 1.462 a 0.558  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.237748 cl_acc 0.500 164.297sec(train) 4.879sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5 tst: l 1.446 a 0.554  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.948sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6 tr: l 1.378 a 0.582  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.235370 cl_acc 0.500 162.163sec(train) 5.130sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6 tst: l 1.385 a 0.573  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.976sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7 tr: l 1.355 a 0.590  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.233016 cl_acc 0.500 167.632sec(train) 5.413sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7 tst: l 1.353 a 0.587  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.991sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8 tr: l 1.305 a 0.608  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.230686 cl_acc 0.500 163.182sec(train) 6.287sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8 tst: l 1.323 a 0.598  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.156sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9 tr: l 1.266 a 0.625  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.228379 cl_acc 0.500 194.230sec(train) 7.267sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9 tst: l 1.306 a 0.606  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.169sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10 tr: l 1.280 a 0.620  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.226096 cl_acc 0.500 266.840sec(train) 7.691sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10 tst: l 1.301 a 0.610  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.677sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11 tr: l 1.232 a 0.636  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.223835 cl_acc 0.500 214.051sec(train) 5.282sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11 tst: l 1.273 a 0.618  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.989sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12 tr: l 1.194 a 0.653  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.221596 cl_acc 0.500 161.947sec(train) 5.216sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12 tst: l 1.257 a 0.622  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.993sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13 tr: l 1.193 a 0.655  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.219380 cl_acc 0.500 164.664sec(train) 4.810sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13 tst: l 1.254 a 0.626  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.927sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14 tr: l 1.176 a 0.662  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.217186 cl_acc 0.500 161.438sec(train) 6.561sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14 tst: l 1.239 a 0.634  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.159sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15 tr: l 1.167 a 0.665  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.215015 cl_acc 0.500 161.354sec(train) 5.316sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15 tst: l 1.232 a 0.636  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.033sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16 tr: l 1.168 a 0.665  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.212864 cl_acc 0.500 155.610sec(train) 6.597sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16 tst: l 1.226 a 0.643  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.219sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17 tr: l 1.152 a 0.674  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.210736 cl_acc 0.500 232.111sec(train) 6.633sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17 tst: l 1.220 a 0.643  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.326sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18 tr: l 1.141 a 0.677  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.208628 cl_acc 0.500 247.932sec(train) 9.376sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18 tst: l 1.203 a 0.651  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.426sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19 tr: l 1.108 a 0.690  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.206542 cl_acc 0.500 177.681sec(train) 5.642sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19 tst: l 1.206 a 0.650  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.002sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20 tr: l 1.095 a 0.693  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.204477 cl_acc 0.500 167.456sec(train) 5.080sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20 tst: l 1.191 a 0.656  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.990sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21 tr: l 1.102 a 0.689  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.202432 cl_acc 0.500 165.654sec(train) 4.848sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21 tst: l 1.197 a 0.652  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.925sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22 tr: l 1.074 a 0.701  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.200408 cl_acc 0.500 160.865sec(train) 5.868sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22 tst: l 1.186 a 0.660  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.052sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23 tr: l 1.060 a 0.706  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.198404 cl_acc 0.500 165.696sec(train) 5.276sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23 tst: l 1.176 a 0.660  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.020sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24 tr: l 1.068 a 0.704  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.196420 cl_acc 0.500 162.687sec(train) 6.171sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24 tst: l 1.169 a 0.666  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.248sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25 tr: l 1.083 a 0.701  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.194455 cl_acc 0.500 248.534sec(train) 6.069sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25 tst: l 1.167 a 0.667  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.198sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 26 tr: l 1.069 a 0.703  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.192511 cl_acc 0.500 248.036sec(train) 5.197sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 26 tst: l 1.160 a 0.667  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.993sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 27 tr: l 1.070 a 0.700  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.190586 cl_acc 0.500 168.852sec(train) 5.056sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 27 tst: l 1.147 a 0.671  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.992sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 28 tr: l 1.036 a 0.715  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.188680 cl_acc 0.500 156.861sec(train) 6.389sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 28 tst: l 1.145 a 0.674  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.298sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 29 tr: l 1.034 a 0.715  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.186793 cl_acc 0.500 156.874sec(train) 4.738sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 29 tst: l 1.140 a 0.674  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.917sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 30 tr: l 1.026 a 0.716  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.184925 cl_acc 0.500 157.604sec(train) 4.820sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 30 tst: l 1.141 a 0.676  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.966sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 31 tr: l 0.984 a 0.733  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.183076 cl_acc 0.500 156.619sec(train) 5.705sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 31 tst: l 1.126 a 0.682  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.110sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 32 tr: l 1.046 a 0.713  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.181245 cl_acc 0.500 175.136sec(train) 7.140sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 32 tst: l 1.132 a 0.683  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.348sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 33 tr: l 0.993 a 0.730  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.179433 cl_acc 0.500 274.273sec(train) 6.390sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 33 tst: l 1.121 a 0.683  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.266sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 34 tr: l 0.980 a 0.735  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.177638 cl_acc 0.500 239.416sec(train) 5.654sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 34 tst: l 1.121 a 0.682  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.004sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 35 tr: l 0.989 a 0.732  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.175862 cl_acc 0.500 164.091sec(train) 5.121sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 35 tst: l 1.117 a 0.687  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.970sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 36 tr: l 0.979 a 0.735  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.174103 cl_acc 0.500 154.466sec(train) 4.669sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 36 tst: l 1.100 a 0.689  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.910sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 37 tr: l 1.001 a 0.726  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.172362 cl_acc 0.500 150.240sec(train) 6.062sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 37 tst: l 1.107 a 0.688  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.955sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 38 tr: l 0.960 a 0.742  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.170639 cl_acc 0.500 154.992sec(train) 4.728sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 38 tst: l 1.088 a 0.693  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.918sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 39 tr: l 0.962 a 0.741  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.168932 cl_acc 0.500 159.268sec(train) 4.491sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 39 tst: l 1.092 a 0.694  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.935sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 40 tr: l 0.964 a 0.738  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.167243 cl_acc 0.500 185.299sec(train) 6.218sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 40 tst: l 1.085 a 0.697  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.207sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 41 tr: l 0.940 a 0.748  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.165571 cl_acc 0.500 257.522sec(train) 8.288sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 41 tst: l 1.084 a 0.694  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.422sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 42 tr: l 0.915 a 0.757  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.163915 cl_acc 0.500 222.928sec(train) 5.155sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 42 tst: l 1.078 a 0.697  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.018sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 43 tr: l 0.937 a 0.748  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.162276 cl_acc 0.500 165.197sec(train) 5.467sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 43 tst: l 1.075 a 0.697  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.010sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 44 tr: l 0.916 a 0.756  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.160653 cl_acc 0.500 159.048sec(train) 5.891sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 44 tst: l 1.073 a 0.697  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.051sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 45 tr: l 0.948 a 0.744  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.159046 cl_acc 0.500 165.222sec(train) 5.138sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 45 tst: l 1.068 a 0.701  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.999sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 46 tr: l 0.933 a 0.748  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.157456 cl_acc 0.500 164.459sec(train) 5.310sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 46 tst: l 1.065 a 0.700  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.039sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 47 tr: l 0.925 a 0.750  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.155881 cl_acc 0.500 160.063sec(train) 5.078sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 47 tst: l 1.054 a 0.702  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.994sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 48 tr: l 0.949 a 0.742  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.154323 cl_acc 0.500 188.919sec(train) 6.526sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 48 tst: l 1.066 a 0.703  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.354sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 49 tr: l 0.897 a 0.761  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.152779 cl_acc 0.500 240.420sec(train) 7.424sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 49 tst: l 1.054 a 0.707  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.644sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 50 tr: l 0.919 a 0.753  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.151252 cl_acc 0.500 218.363sec(train) 5.764sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 50 tst: l 1.050 a 0.704  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.039sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 51 tr: l 0.883 a 0.765  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.149739 cl_acc 0.500 166.887sec(train) 4.931sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 51 tst: l 1.047 a 0.708  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.948sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 52 tr: l 0.898 a 0.760  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.148242 cl_acc 0.500 161.987sec(train) 5.145sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 52 tst: l 1.036 a 0.711  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.100sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 53 tr: l 0.906 a 0.756  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.146759 cl_acc 0.500 168.448sec(train) 5.960sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 53 tst: l 1.048 a 0.706  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.212sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 54 tr: l 0.881 a 0.763  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.145292 cl_acc 0.500 161.557sec(train) 5.170sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 54 tst: l 1.030 a 0.713  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.007sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 55 tr: l 0.890 a 0.760  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.143839 cl_acc 0.500 155.243sec(train) 5.004sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 55 tst: l 1.036 a 0.708  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.942sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 56 tr: l 0.877 a 0.766  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.142400 cl_acc 0.500 183.621sec(train) 6.176sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 56 tst: l 1.030 a 0.713  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.270sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 57 tr: l 0.871 a 0.768  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.140976 cl_acc 0.500 242.516sec(train) 6.043sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 57 tst: l 1.030 a 0.710  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.227sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 58 tr: l 0.868 a 0.771  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.139567 cl_acc 0.500 221.050sec(train) 4.996sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 58 tst: l 1.016 a 0.715  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.928sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 59 tr: l 0.853 a 0.775  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.138171 cl_acc 0.500 161.246sec(train) 5.140sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 59 tst: l 1.023 a 0.716  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.995sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 60 tr: l 0.864 a 0.769  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.136789 cl_acc 0.500 171.140sec(train) 5.124sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 60 tst: l 1.008 a 0.719  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.971sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 61 tr: l 0.840 a 0.777  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.135421 cl_acc 0.500 161.041sec(train) 4.561sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 61 tst: l 1.010 a 0.719  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.874sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 62 tr: l 0.848 a 0.776  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.134067 cl_acc 0.500 159.307sec(train) 5.520sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 62 tst: l 1.002 a 0.720  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.008sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 63 tr: l 0.847 a 0.776  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.132726 cl_acc 0.500 164.996sec(train) 5.762sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 63 tst: l 1.003 a 0.721  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.068sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 64 tr: l 0.824 a 0.784  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.131399 cl_acc 0.500 166.802sec(train) 4.739sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 64 tst: l 1.004 a 0.722  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.919sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 65 tr: l 0.824 a 0.784  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.130085 cl_acc 0.500 191.918sec(train) 6.000sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 65 tst: l 1.002 a 0.721  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.099sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 66 tr: l 0.842 a 0.777  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.128784 cl_acc 0.500 246.391sec(train) 7.246sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 66 tst: l 0.999 a 0.721  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.326sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 67 tr: l 0.814 a 0.783  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.127496 cl_acc 0.500 218.642sec(train) 5.195sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 67 tst: l 0.990 a 0.725  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.990sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 68 tr: l 0.826 a 0.781  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.126221 cl_acc 0.500 161.407sec(train) 4.755sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 68 tst: l 0.992 a 0.724  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.964sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 69 tr: l 0.821 a 0.783  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.124959 cl_acc 0.500 158.464sec(train) 4.892sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 69 tst: l 0.990 a 0.726  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.019sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 70 tr: l 0.826 a 0.780  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.123710 cl_acc 0.500 157.416sec(train) 5.307sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 70 tst: l 0.987 a 0.725  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.024sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 71 tr: l 0.804 a 0.789  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.122473 cl_acc 0.500 159.122sec(train) 5.087sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 71 tst: l 0.985 a 0.726  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.043sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 72 tr: l 0.790 a 0.793  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.121248 cl_acc 0.500 154.193sec(train) 6.159sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 72 tst: l 0.988 a 0.726  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.253sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 73 tr: l 0.784 a 0.794  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.120035 cl_acc 0.500 156.798sec(train) 4.770sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 73 tst: l 0.981 a 0.727  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.933sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 74 tr: l 0.799 a 0.788  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.118835 cl_acc 0.500 221.360sec(train) 6.732sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 74 tst: l 0.976 a 0.729  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.276sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 75 tr: l 0.779 a 0.794  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.117647 cl_acc 0.500 248.478sec(train) 7.130sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 75 tst: l 0.980 a 0.727  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.283sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 76 tr: l 0.795 a 0.790  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.116470 cl_acc 0.500 186.318sec(train) 4.513sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 76 tst: l 0.963 a 0.733  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.959sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 77 tr: l 0.800 a 0.789  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.115305 cl_acc 0.500 163.369sec(train) 4.671sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 77 tst: l 0.973 a 0.728  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.898sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 78 tr: l 0.783 a 0.794  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.114152 cl_acc 0.500 156.387sec(train) 5.158sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 78 tst: l 0.963 a 0.731  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.996sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 79 tr: l 0.780 a 0.794  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.113011 cl_acc 0.500 151.810sec(train) 4.538sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 79 tst: l 0.961 a 0.733  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.214sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 80 tr: l 0.787 a 0.790  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.111881 cl_acc 0.500 157.678sec(train) 5.613sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 80 tst: l 0.970 a 0.730  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.129sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 81 tr: l 0.787 a 0.790  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.110762 cl_acc 0.500 153.832sec(train) 4.496sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 81 tst: l 0.959 a 0.733  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.861sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 82 tr: l 0.763 a 0.800  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.109654 cl_acc 0.500 209.824sec(train) 7.163sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 82 tst: l 0.953 a 0.735  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.300sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 83 tr: l 0.749 a 0.805  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.108558 cl_acc 0.500 251.503sec(train) 6.357sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 83 tst: l 0.953 a 0.733  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.306sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 84 tr: l 0.756 a 0.801  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.107472 cl_acc 0.500 178.662sec(train) 6.169sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 84 tst: l 0.954 a 0.734  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.279sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 85 tr: l 0.779 a 0.792  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.106398 cl_acc 0.500 156.992sec(train) 4.929sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 85 tst: l 0.946 a 0.737  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.922sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 86 tr: l 0.736 a 0.807  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.105334 cl_acc 0.500 149.715sec(train) 4.565sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 86 tst: l 0.945 a 0.737  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.890sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 87 tr: l 0.765 a 0.797  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.104280 cl_acc 0.500 157.954sec(train) 4.922sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 87 tst: l 0.943 a 0.738  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.954sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 88 tr: l 0.723 a 0.811  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.103237 cl_acc 0.500 154.269sec(train) 4.995sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 88 tst: l 0.942 a 0.738  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.936sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 89 tr: l 0.753 a 0.800  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.102205 cl_acc 0.500 153.060sec(train) 5.156sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 89 tst: l 0.941 a 0.741  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.123sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 90 tr: l 0.748 a 0.802  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.101183 cl_acc 0.500 184.433sec(train) 6.979sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 90 tst: l 0.939 a 0.738  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.330sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 91 tr: l 0.734 a 0.808  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.100171 cl_acc 0.500 237.098sec(train) 10.958sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 91 tst: l 0.937 a 0.739  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.455sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 92 tr: l 0.723 a 0.810  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.099169 cl_acc 0.500 236.458sec(train) 5.190sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 92 tst: l 0.931 a 0.742  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.979sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 93 tr: l 0.732 a 0.808  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.098178 cl_acc 0.500 160.661sec(train) 5.221sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 93 tst: l 0.935 a 0.740  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.013sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 94 tr: l 0.718 a 0.812  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.097196 cl_acc 0.500 155.764sec(train) 5.530sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 94 tst: l 0.931 a 0.743  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.002sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 95 tr: l 0.706 a 0.814  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.096224 cl_acc 0.500 155.327sec(train) 4.763sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 95 tst: l 0.923 a 0.745  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.932sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 96 tr: l 0.736 a 0.805  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.095262 cl_acc 0.500 150.608sec(train) 4.743sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 96 tst: l 0.935 a 0.742  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.932sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 97 tr: l 0.729 a 0.807  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.094309 cl_acc 0.500 147.715sec(train) 5.240sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 97 tst: l 0.920 a 0.743  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.002sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 98 tr: l 0.756 a 0.797  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.093366 cl_acc 0.500 158.570sec(train) 7.255sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 98 tst: l 0.927 a 0.743  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.442sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 99 tr: l 0.712 a 0.812  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.092432 cl_acc 0.500 244.463sec(train) 6.746sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 99 tst: l 0.927 a 0.744  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.234sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 100 tr: l 0.718 a 0.810  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.091508 cl_acc 0.500 225.757sec(train) 5.673sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 100 tst: l 0.922 a 0.744  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.184sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 101 tr: l 0.719 a 0.809  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.090593 cl_acc 0.500 169.684sec(train) 5.614sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 101 tst: l 0.916 a 0.748  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.109sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 102 tr: l 0.722 a 0.809  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.089687 cl_acc 0.500 172.498sec(train) 5.469sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 102 tst: l 0.914 a 0.747  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.026sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 103 tr: l 0.692 a 0.818  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.088790 cl_acc 0.500 170.557sec(train) 5.832sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 103 tst: l 0.913 a 0.748  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.089sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 104 tr: l 0.687 a 0.820  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.087902 cl_acc 0.500 162.262sec(train) 4.811sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 104 tst: l 0.909 a 0.746  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.921sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 105 tr: l 0.699 a 0.816  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.087023 cl_acc 0.500 195.154sec(train) 6.924sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 105 tst: l 0.917 a 0.745  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.183sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 106 tr: l 0.692 a 0.819  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.086153 cl_acc 0.500 275.209sec(train) 7.366sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 106 tst: l 0.910 a 0.747  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.273sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 107 tr: l 0.718 a 0.807  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.085292 cl_acc 0.500 309.270sec(train) 6.232sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 107 tst: l 0.905 a 0.750  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.165sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 108 tr: l 0.683 a 0.820  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.084439 cl_acc 0.500 227.931sec(train) 5.787sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 108 tst: l 0.902 a 0.751  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.057sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 109 tr: l 0.690 a 0.818  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.083594 cl_acc 0.500 232.843sec(train) 7.230sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 109 tst: l 0.910 a 0.750  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.397sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 110 tr: l 0.662 a 0.828  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.082758 cl_acc 0.500 234.388sec(train) 7.378sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 110 tst: l 0.898 a 0.754  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.131sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 111 tr: l 0.659 a 0.829  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.081931 cl_acc 0.500 230.630sec(train) 5.865sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 111 tst: l 0.899 a 0.750  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.035sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 112 tr: l 0.693 a 0.816  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.081111 cl_acc 0.500 313.518sec(train) 8.358sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 112 tst: l 0.895 a 0.756  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.744sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 113 tr: l 0.665 a 0.826  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.080300 cl_acc 0.500 287.724sec(train) 6.957sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 113 tst: l 0.899 a 0.753  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.290sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 114 tr: l 0.674 a 0.823  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.079497 cl_acc 0.500 240.594sec(train) 6.646sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 114 tst: l 0.900 a 0.752  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.268sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 115 tr: l 0.697 a 0.815  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.078702 cl_acc 0.500 240.808sec(train) 6.180sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 115 tst: l 0.903 a 0.752  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.090sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 116 tr: l 0.675 a 0.821  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.077915 cl_acc 0.500 234.352sec(train) 6.347sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 116 tst: l 0.893 a 0.753  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.096sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 117 tr: l 0.656 a 0.829  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.077136 cl_acc 0.500 221.185sec(train) 5.931sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 117 tst: l 0.890 a 0.755  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.201sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 118 tr: l 0.659 a 0.826  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.076365 cl_acc 0.500 289.866sec(train) 6.651sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 118 tst: l 0.884 a 0.758  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.330sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 119 tr: l 0.676 a 0.821  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.075601 cl_acc 0.500 312.285sec(train) 5.931sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 119 tst: l 0.888 a 0.755  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.118sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 120 tr: l 0.689 a 0.818  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.074845 cl_acc 0.500 223.930sec(train) 5.486sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 120 tst: l 0.888 a 0.754  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.985sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 121 tr: l 0.668 a 0.823  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.074097 cl_acc 0.500 228.175sec(train) 5.964sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 121 tst: l 0.885 a 0.754  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.038sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 122 tr: l 0.674 a 0.821  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.073356 cl_acc 0.500 212.357sec(train) 5.321sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 122 tst: l 0.889 a 0.753  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.010sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 123 tr: l 0.656 a 0.826  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.072622 cl_acc 0.500 220.797sec(train) 5.587sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 123 tst: l 0.879 a 0.757  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.017sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 124 tr: l 0.670 a 0.824  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.071896 cl_acc 0.500 295.946sec(train) 6.672sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 124 tst: l 0.877 a 0.757  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.318sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 125 tr: l 0.637 a 0.834  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.071177 cl_acc 0.500 315.346sec(train) 6.385sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 125 tst: l 0.882 a 0.757  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.186sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 126 tr: l 0.649 a 0.829  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.070465 cl_acc 0.500 227.156sec(train) 5.424sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 126 tst: l 0.878 a 0.758  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.991sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 127 tr: l 0.629 a 0.835  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.069761 cl_acc 0.500 234.042sec(train) 5.649sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 127 tst: l 0.877 a 0.758  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.033sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 128 tr: l 0.635 a 0.833  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.069063 cl_acc 0.500 229.524sec(train) 6.001sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 128 tst: l 0.871 a 0.759  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.195sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 129 tr: l 0.657 a 0.828  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.068372 cl_acc 0.500 227.489sec(train) 6.174sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 129 tst: l 0.873 a 0.760  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.068sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 130 tr: l 0.646 a 0.829  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.067689 cl_acc 0.500 322.463sec(train) 7.190sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 130 tst: l 0.870 a 0.759  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.604sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 131 tr: l 0.626 a 0.837  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.067012 cl_acc 0.500 270.426sec(train) 5.675sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 131 tst: l 0.868 a 0.762  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.174sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 132 tr: l 0.627 a 0.836  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.066342 cl_acc 0.500 231.348sec(train) 6.099sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 132 tst: l 0.866 a 0.761  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.130sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 133 tr: l 0.635 a 0.831  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.065678 cl_acc 0.500 227.718sec(train) 5.459sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 133 tst: l 0.864 a 0.761  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.999sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 134 tr: l 0.657 a 0.825  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.065021 cl_acc 0.500 227.824sec(train) 6.485sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 134 tst: l 0.869 a 0.760  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.268sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 135 tr: l 0.649 a 0.827  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.064371 cl_acc 0.500 235.514sec(train) 6.096sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 135 tst: l 0.865 a 0.763  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.164sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 136 tr: l 0.619 a 0.838  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.063727 cl_acc 0.500 325.384sec(train) 9.226sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 136 tst: l 0.864 a 0.762  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.718sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 137 tr: l 0.633 a 0.832  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.063090 cl_acc 0.500 272.713sec(train) 5.952sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 137 tst: l 0.866 a 0.762  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.306sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 138 tr: l 0.621 a 0.835  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.062459 cl_acc 0.500 237.616sec(train) 7.164sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 138 tst: l 0.864 a 0.761  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.481sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 139 tr: l 0.634 a 0.832  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.061835 cl_acc 0.500 222.429sec(train) 4.705sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 139 tst: l 0.859 a 0.762  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.120sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 140 tr: l 0.632 a 0.832  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.061216 cl_acc 0.500 213.652sec(train) 5.623sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 140 tst: l 0.861 a 0.762  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.111sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 141 tr: l 0.644 a 0.828  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.060604 cl_acc 0.500 261.870sec(train) 6.863sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 141 tst: l 0.855 a 0.765  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.394sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 142 tr: l 0.618 a 0.838  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.059998 cl_acc 0.500 322.520sec(train) 8.260sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 142 tst: l 0.852 a 0.765  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.340sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 143 tr: l 0.601 a 0.840  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.059398 cl_acc 0.500 241.583sec(train) 8.050sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 143 tst: l 0.852 a 0.763  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.263sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 144 tr: l 0.608 a 0.840  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.058804 cl_acc 0.500 229.558sec(train) 5.933sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 144 tst: l 0.853 a 0.766  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.426sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 145 tr: l 0.594 a 0.844  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.058216 cl_acc 0.500 232.816sec(train) 6.694sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 145 tst: l 0.847 a 0.764  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.994sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 146 tr: l 0.598 a 0.843  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.057634 cl_acc 0.500 227.964sec(train) 5.336sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 146 tst: l 0.850 a 0.764  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.107sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 147 tr: l 0.630 a 0.831  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.057058 cl_acc 0.500 284.912sec(train) 6.906sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 147 tst: l 0.847 a 0.765  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.443sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 148 tr: l 0.601 a 0.841  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.056487 cl_acc 0.500 303.858sec(train) 5.826sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 148 tst: l 0.852 a 0.764  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.222sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 149 tr: l 0.615 a 0.837  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.055922 cl_acc 0.500 230.452sec(train) 6.172sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 149 tst: l 0.851 a 0.764  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.342sec\n",
      "result written at output/results.pickle\n",
      "---train cluster Ended in 8.78 hour (31608.262 sec) \n",
      "---------------------------------DFedAvgM, lr: 0.25, seed: 3657---------------------------------\n",
      "config: {'m': 50, 'm_test': 10, 'p': 2, 'n': 2000, 'local_model_init': False, 'participation_rate': 1, 'Gp': 0.25, 'graph': 'er', 'agg': 'seq', 'num_epochs': 150, 'batch_size': 50, 'tau': 10, 'lr': 0.25, 'data_seed': 3657, 'train_seed': 3657, 'project_dir': 'output'}\n",
      "Using device: cuda:0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "I0000 00:00:1758544454.428980 1488169 gpu_device.cc:2019] Created device /job:localhost/replica:0/task:0/device:GPU:0 with 33884 MB memory:  -> device: 2, name: NVIDIA A100-SXM4-40GB, pci bus id: 0000:81:00.0, compute capability: 8.0\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch -1 tr: l 4.673 a 0.112  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] cl_acc 0.500 6.435sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch -1 tst: l 4.673 a 0.110  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.270sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0 tr: l 3.285 a 0.234  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.250000 cl_acc 0.500 225.820sec(train) 5.807sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0 tst: l 3.292 a 0.235  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.194sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1 tr: l 2.436 a 0.359  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.247500 cl_acc 0.500 235.437sec(train) 5.943sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1 tst: l 2.435 a 0.364  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.109sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2 tr: l 1.982 a 0.414  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.245025 cl_acc 0.500 234.859sec(train) 5.399sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2 tst: l 1.960 a 0.427  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.029sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3 tr: l 1.691 a 0.492  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.242575 cl_acc 0.500 306.126sec(train) 8.565sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3 tst: l 1.680 a 0.486  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 2.359sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4 tr: l 1.570 a 0.521  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.240149 cl_acc 0.500 310.372sec(train) 6.286sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4 tst: l 1.557 a 0.521  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.361sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5 tr: l 1.467 a 0.552  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.237748 cl_acc 0.500 234.602sec(train) 6.453sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5 tst: l 1.473 a 0.538  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.247sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6 tr: l 1.390 a 0.577  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.235370 cl_acc 0.500 244.404sec(train) 6.009sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6 tst: l 1.403 a 0.565  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.069sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7 tr: l 1.341 a 0.594  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.233016 cl_acc 0.500 217.991sec(train) 7.105sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7 tst: l 1.369 a 0.575  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.206sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8 tr: l 1.306 a 0.607  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.230686 cl_acc 0.500 235.203sec(train) 6.693sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8 tst: l 1.339 a 0.585  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.273sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9 tr: l 1.271 a 0.620  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.228379 cl_acc 0.500 314.302sec(train) 7.614sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9 tst: l 1.322 a 0.593  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.334sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10 tr: l 1.226 a 0.641  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.226096 cl_acc 0.500 267.740sec(train) 5.659sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10 tst: l 1.305 a 0.602  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.118sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11 tr: l 1.200 a 0.650  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.223835 cl_acc 0.500 238.307sec(train) 5.269sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11 tst: l 1.285 a 0.610  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.063sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12 tr: l 1.197 a 0.654  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.221596 cl_acc 0.500 238.255sec(train) 6.609sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12 tst: l 1.267 a 0.621  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.100sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13 tr: l 1.189 a 0.655  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.219380 cl_acc 0.500 234.919sec(train) 5.450sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13 tst: l 1.256 a 0.625  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.035sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14 tr: l 1.148 a 0.671  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.217186 cl_acc 0.500 282.722sec(train) 6.564sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14 tst: l 1.246 a 0.627  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.378sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15 tr: l 1.191 a 0.654  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.215015 cl_acc 0.500 316.948sec(train) 6.533sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15 tst: l 1.240 a 0.632  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.207sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16 tr: l 1.173 a 0.661  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.212864 cl_acc 0.500 241.237sec(train) 5.668sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16 tst: l 1.232 a 0.634  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.066sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17 tr: l 1.136 a 0.674  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.210736 cl_acc 0.500 231.461sec(train) 6.780sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17 tst: l 1.215 a 0.639  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.408sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18 tr: l 1.123 a 0.683  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.208628 cl_acc 0.500 232.023sec(train) 5.997sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18 tst: l 1.219 a 0.642  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.151sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19 tr: l 1.087 a 0.697  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.206542 cl_acc 0.500 228.344sec(train) 5.914sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19 tst: l 1.196 a 0.651  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.337sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20 tr: l 1.105 a 0.689  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.204477 cl_acc 0.500 294.273sec(train) 6.724sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20 tst: l 1.202 a 0.647  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.294sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21 tr: l 1.057 a 0.707  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.202432 cl_acc 0.500 297.067sec(train) 5.785sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21 tst: l 1.195 a 0.651  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.096sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22 tr: l 1.085 a 0.697  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.200408 cl_acc 0.500 240.246sec(train) 5.779sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22 tst: l 1.190 a 0.655  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.117sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23 tr: l 1.078 a 0.697  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.198404 cl_acc 0.500 233.244sec(train) 5.176sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23 tst: l 1.174 a 0.661  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.960sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24 tr: l 1.032 a 0.716  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.196420 cl_acc 0.500 212.922sec(train) 5.790sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24 tst: l 1.169 a 0.660  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.126sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25 tr: l 1.029 a 0.717  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.194455 cl_acc 0.500 249.693sec(train) 6.368sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25 tst: l 1.171 a 0.660  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.093sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 26 tr: l 1.064 a 0.705  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.192511 cl_acc 0.500 322.266sec(train) 7.283sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 26 tst: l 1.152 a 0.669  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.411sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 27 tr: l 1.026 a 0.717  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.190586 cl_acc 0.500 276.459sec(train) 6.831sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 27 tst: l 1.149 a 0.667  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.210sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 28 tr: l 1.038 a 0.713  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.188680 cl_acc 0.500 235.766sec(train) 6.393sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 28 tst: l 1.160 a 0.664  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 29 tr: l 1.030 a 0.716  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.186793 cl_acc 0.500 239.362sec(train) 5.598sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 29 tst: l 1.149 a 0.666  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.022sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 30 tr: l 1.006 a 0.724  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.184925 cl_acc 0.500 240.037sec(train) 5.499sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 30 tst: l 1.134 a 0.676  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.074sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 31 tr: l 1.017 a 0.718  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.183076 cl_acc 0.500 268.553sec(train) 6.505sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 31 tst: l 1.124 a 0.676  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.419sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 32 tr: l 1.030 a 0.715  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.181245 cl_acc 0.500 319.796sec(train) 7.404sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 32 tst: l 1.125 a 0.678  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.431sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 33 tr: l 1.007 a 0.722  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.179433 cl_acc 0.500 239.433sec(train) 5.392sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 33 tst: l 1.124 a 0.680  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.022sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 34 tr: l 0.960 a 0.741  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.177638 cl_acc 0.500 230.862sec(train) 5.352sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 34 tst: l 1.111 a 0.683  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.004sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 35 tr: l 0.997 a 0.727  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.175862 cl_acc 0.500 227.561sec(train) 5.565sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 35 tst: l 1.109 a 0.684  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.298sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 36 tr: l 0.978 a 0.731  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.174103 cl_acc 0.500 233.814sec(train) 5.569sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 36 tst: l 1.114 a 0.681  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.985sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 37 tr: l 0.990 a 0.728  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.172362 cl_acc 0.500 292.494sec(train) 11.176sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 37 tst: l 1.107 a 0.685  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.872sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 38 tr: l 0.959 a 0.738  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.170639 cl_acc 0.500 301.358sec(train) 6.705sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 38 tst: l 1.100 a 0.687  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.258sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 39 tr: l 0.951 a 0.743  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.168932 cl_acc 0.500 235.117sec(train) 5.357sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 39 tst: l 1.099 a 0.686  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.077sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 40 tr: l 0.927 a 0.751  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.167243 cl_acc 0.500 233.894sec(train) 5.535sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 40 tst: l 1.089 a 0.691  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.008sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 41 tr: l 0.934 a 0.748  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.165571 cl_acc 0.500 161.312sec(train) 5.369sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 41 tst: l 1.086 a 0.691  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.045sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 42 tr: l 0.940 a 0.745  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.163915 cl_acc 0.500 155.815sec(train) 4.865sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 42 tst: l 1.085 a 0.693  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.941sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 43 tr: l 0.910 a 0.758  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.162276 cl_acc 0.500 197.910sec(train) 7.609sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 43 tst: l 1.081 a 0.695  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.503sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 44 tr: l 0.919 a 0.755  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.160653 cl_acc 0.500 260.903sec(train) 6.399sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 44 tst: l 1.076 a 0.695  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.186sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 45 tr: l 0.920 a 0.752  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.159046 cl_acc 0.500 202.306sec(train) 4.931sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 45 tst: l 1.062 a 0.698  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.965sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 46 tr: l 0.916 a 0.753  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.157456 cl_acc 0.500 153.417sec(train) 4.798sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 46 tst: l 1.060 a 0.698  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.943sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 47 tr: l 0.898 a 0.760  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.155881 cl_acc 0.500 159.968sec(train) 4.764sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 47 tst: l 1.057 a 0.702  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.952sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 48 tr: l 0.890 a 0.763  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.154323 cl_acc 0.500 153.812sec(train) 5.017sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 48 tst: l 1.046 a 0.705  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.965sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 49 tr: l 0.920 a 0.751  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.152779 cl_acc 0.500 161.390sec(train) 4.859sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 49 tst: l 1.043 a 0.709  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.956sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 50 tr: l 0.899 a 0.760  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.151252 cl_acc 0.500 154.013sec(train) 4.950sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 50 tst: l 1.046 a 0.704  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.970sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 51 tr: l 0.894 a 0.759  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.149739 cl_acc 0.500 159.823sec(train) 6.614sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 51 tst: l 1.045 a 0.705  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.208sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 52 tr: l 0.902 a 0.756  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.148242 cl_acc 0.500 246.487sec(train) 6.935sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 52 tst: l 1.047 a 0.707  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.336sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 53 tr: l 0.874 a 0.766  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.146759 cl_acc 0.500 237.802sec(train) 6.240sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 53 tst: l 1.036 a 0.707  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.263sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 54 tr: l 0.857 a 0.772  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.145292 cl_acc 0.500 165.997sec(train) 4.772sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 54 tst: l 1.029 a 0.710  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.928sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 55 tr: l 0.882 a 0.762  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.143839 cl_acc 0.500 157.189sec(train) 5.389sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 55 tst: l 1.035 a 0.708  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.043sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 56 tr: l 0.832 a 0.781  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.142400 cl_acc 0.500 158.744sec(train) 5.155sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 56 tst: l 1.024 a 0.712  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.932sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 57 tr: l 0.875 a 0.764  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.140976 cl_acc 0.500 163.896sec(train) 4.848sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 57 tst: l 1.019 a 0.714  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.930sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 58 tr: l 0.872 a 0.764  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.139567 cl_acc 0.500 158.238sec(train) 5.740sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 58 tst: l 1.017 a 0.716  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.091sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 59 tr: l 0.849 a 0.775  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.138171 cl_acc 0.500 167.459sec(train) 5.706sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 59 tst: l 1.021 a 0.713  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.034sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 60 tr: l 0.850 a 0.772  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.136789 cl_acc 0.500 238.691sec(train) 7.721sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 60 tst: l 1.014 a 0.715  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.675sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 61 tr: l 0.835 a 0.777  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.135421 cl_acc 0.500 240.192sec(train) 6.699sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 61 tst: l 1.013 a 0.713  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.292sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 62 tr: l 0.820 a 0.783  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.134067 cl_acc 0.500 168.613sec(train) 4.897sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 62 tst: l 1.004 a 0.718  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.982sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 63 tr: l 0.860 a 0.769  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.132726 cl_acc 0.500 169.775sec(train) 5.214sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 63 tst: l 1.013 a 0.715  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.023sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 64 tr: l 0.841 a 0.775  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.131399 cl_acc 0.500 166.814sec(train) 5.368sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 64 tst: l 1.001 a 0.716  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.039sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 65 tr: l 0.816 a 0.784  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.130085 cl_acc 0.500 163.708sec(train) 5.068sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 65 tst: l 0.995 a 0.722  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.974sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 66 tr: l 0.810 a 0.785  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.128784 cl_acc 0.500 168.773sec(train) 5.178sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 66 tst: l 1.006 a 0.715  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.105sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 67 tr: l 0.815 a 0.784  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.127496 cl_acc 0.500 187.797sec(train) 6.226sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 67 tst: l 0.996 a 0.722  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.217sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 68 tr: l 0.822 a 0.780  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.126221 cl_acc 0.500 237.266sec(train) 6.022sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 68 tst: l 0.985 a 0.727  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.154sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 69 tr: l 0.776 a 0.798  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.124959 cl_acc 0.500 222.517sec(train) 5.450sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 69 tst: l 0.984 a 0.725  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.993sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 70 tr: l 0.811 a 0.784  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.123710 cl_acc 0.500 166.891sec(train) 5.144sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 70 tst: l 0.992 a 0.719  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.986sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 71 tr: l 0.781 a 0.795  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.122473 cl_acc 0.500 163.816sec(train) 4.920sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 71 tst: l 0.979 a 0.724  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.969sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 72 tr: l 0.805 a 0.785  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.121248 cl_acc 0.500 162.661sec(train) 5.522sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 72 tst: l 0.984 a 0.724  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.099sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 73 tr: l 0.778 a 0.796  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.120035 cl_acc 0.500 164.268sec(train) 5.592sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 73 tst: l 0.967 a 0.729  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.024sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 74 tr: l 0.796 a 0.790  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.118835 cl_acc 0.500 157.001sec(train) 5.211sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 74 tst: l 0.980 a 0.725  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.994sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 75 tr: l 0.799 a 0.787  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.117647 cl_acc 0.500 161.237sec(train) 6.175sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 75 tst: l 0.978 a 0.725  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.078sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 76 tr: l 0.786 a 0.793  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.116470 cl_acc 0.500 219.307sec(train) 6.678sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 76 tst: l 0.967 a 0.728  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.244sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 77 tr: l 0.809 a 0.783  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.115305 cl_acc 0.500 255.284sec(train) 5.438sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 77 tst: l 0.965 a 0.729  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.119sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 78 tr: l 0.776 a 0.794  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.114152 cl_acc 0.500 193.146sec(train) 5.082sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 78 tst: l 0.964 a 0.729  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.031sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 79 tr: l 0.779 a 0.793  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.113011 cl_acc 0.500 159.779sec(train) 4.959sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 79 tst: l 0.966 a 0.729  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.927sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 80 tr: l 0.771 a 0.794  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.111881 cl_acc 0.500 154.465sec(train) 5.028sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 80 tst: l 0.957 a 0.732  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.918sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 81 tr: l 0.773 a 0.793  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.110762 cl_acc 0.500 162.838sec(train) 5.699sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 81 tst: l 0.954 a 0.734  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.022sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 82 tr: l 0.736 a 0.809  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.109654 cl_acc 0.500 158.704sec(train) 6.639sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 82 tst: l 0.953 a 0.731  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.201sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 83 tr: l 0.742 a 0.804  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.108558 cl_acc 0.500 158.656sec(train) 4.603sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 83 tst: l 0.953 a 0.734  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.899sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 84 tr: l 0.749 a 0.803  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.107472 cl_acc 0.500 198.675sec(train) 7.129sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 84 tst: l 0.954 a 0.731  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.337sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 85 tr: l 0.743 a 0.805  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.106398 cl_acc 0.500 240.043sec(train) 8.169sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 85 tst: l 0.954 a 0.733  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.367sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 86 tr: l 0.753 a 0.802  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.105334 cl_acc 0.500 224.584sec(train) 6.082sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 86 tst: l 0.945 a 0.736  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.288sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 87 tr: l 0.751 a 0.801  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.104280 cl_acc 0.500 164.960sec(train) 5.067sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 87 tst: l 0.945 a 0.734  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.001sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 88 tr: l 0.745 a 0.803  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.103237 cl_acc 0.500 163.208sec(train) 4.855sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 88 tst: l 0.942 a 0.737  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.949sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 89 tr: l 0.751 a 0.802  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.102205 cl_acc 0.500 155.693sec(train) 5.301sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 89 tst: l 0.934 a 0.736  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.015sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 90 tr: l 0.751 a 0.801  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.101183 cl_acc 0.500 158.107sec(train) 5.249sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 90 tst: l 0.943 a 0.734  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.999sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 91 tr: l 0.726 a 0.809  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.100171 cl_acc 0.500 155.855sec(train) 5.099sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 91 tst: l 0.939 a 0.736  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.938sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 92 tr: l 0.737 a 0.804  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.099169 cl_acc 0.500 183.614sec(train) 5.755sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 92 tst: l 0.940 a 0.736  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.134sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 93 tr: l 0.747 a 0.801  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.098178 cl_acc 0.500 240.787sec(train) 5.941sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 93 tst: l 0.931 a 0.738  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.131sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 94 tr: l 0.739 a 0.803  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.097196 cl_acc 0.500 227.978sec(train) 4.737sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 94 tst: l 0.944 a 0.733  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.988sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 95 tr: l 0.731 a 0.807  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.096224 cl_acc 0.500 163.828sec(train) 5.130sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 95 tst: l 0.926 a 0.742  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.992sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 96 tr: l 0.743 a 0.802  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.095262 cl_acc 0.500 163.343sec(train) 5.127sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 96 tst: l 0.930 a 0.740  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.079sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 97 tr: l 0.713 a 0.813  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.094309 cl_acc 0.500 163.098sec(train) 4.949sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 97 tst: l 0.921 a 0.742  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.962sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 98 tr: l 0.719 a 0.810  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.093366 cl_acc 0.500 163.384sec(train) 4.822sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 98 tst: l 0.919 a 0.743  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.972sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 99 tr: l 0.705 a 0.814  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.092432 cl_acc 0.500 160.580sec(train) 4.846sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 99 tst: l 0.926 a 0.741  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.005sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 100 tr: l 0.717 a 0.810  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.091508 cl_acc 0.500 179.832sec(train) 6.294sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 100 tst: l 0.915 a 0.744  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.249sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 101 tr: l 0.748 a 0.799  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.090593 cl_acc 0.500 248.477sec(train) 6.610sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 101 tst: l 0.925 a 0.740  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.274sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 102 tr: l 0.696 a 0.818  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.089687 cl_acc 0.500 249.569sec(train) 4.987sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 102 tst: l 0.913 a 0.745  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.953sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 103 tr: l 0.700 a 0.817  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.088790 cl_acc 0.500 164.156sec(train) 5.287sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 103 tst: l 0.912 a 0.744  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.031sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 104 tr: l 0.709 a 0.811  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.087902 cl_acc 0.500 164.775sec(train) 5.145sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 104 tst: l 0.914 a 0.744  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.004sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 105 tr: l 0.696 a 0.816  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.087023 cl_acc 0.500 167.190sec(train) 5.603sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 105 tst: l 0.917 a 0.744  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.087sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 106 tr: l 0.696 a 0.815  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.086153 cl_acc 0.500 162.693sec(train) 5.036sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 106 tst: l 0.914 a 0.746  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.971sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 107 tr: l 0.705 a 0.813  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.085292 cl_acc 0.500 159.837sec(train) 5.165sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 107 tst: l 0.905 a 0.746  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.003sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 108 tr: l 0.696 a 0.816  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.084439 cl_acc 0.500 176.137sec(train) 6.259sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 108 tst: l 0.904 a 0.747  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.119sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 109 tr: l 0.712 a 0.809  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.083594 cl_acc 0.500 249.818sec(train) 6.777sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 109 tst: l 0.904 a 0.747  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.239sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 110 tr: l 0.673 a 0.823  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.082758 cl_acc 0.500 247.332sec(train) 5.134sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 110 tst: l 0.902 a 0.746  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.002sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 111 tr: l 0.674 a 0.822  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.081931 cl_acc 0.500 166.000sec(train) 5.020sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 111 tst: l 0.894 a 0.749  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.985sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 112 tr: l 0.691 a 0.817  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.081111 cl_acc 0.500 168.632sec(train) 5.583sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 112 tst: l 0.893 a 0.748  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.117sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 113 tr: l 0.679 a 0.821  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.080300 cl_acc 0.500 166.165sec(train) 5.577sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 113 tst: l 0.895 a 0.748  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.141sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 114 tr: l 0.689 a 0.817  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.079497 cl_acc 0.500 164.240sec(train) 5.804sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 114 tst: l 0.892 a 0.750  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.121sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 115 tr: l 0.689 a 0.817  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.078702 cl_acc 0.500 164.238sec(train) 4.874sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 115 tst: l 0.891 a 0.750  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.956sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 116 tr: l 0.677 a 0.821  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.077915 cl_acc 0.500 159.366sec(train) 4.790sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 116 tst: l 0.891 a 0.752  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.948sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 117 tr: l 0.663 a 0.825  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.077136 cl_acc 0.500 236.550sec(train) 5.969sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 117 tst: l 0.884 a 0.753  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.215sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 118 tr: l 0.659 a 0.827  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.076365 cl_acc 0.500 246.294sec(train) 6.722sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 118 tst: l 0.881 a 0.753  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.553sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 119 tr: l 0.668 a 0.824  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.075601 cl_acc 0.500 179.410sec(train) 5.015sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 119 tst: l 0.882 a 0.753  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.955sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 120 tr: l 0.670 a 0.823  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.074845 cl_acc 0.500 152.251sec(train) 5.028sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 120 tst: l 0.882 a 0.753  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.993sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 121 tr: l 0.666 a 0.824  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.074097 cl_acc 0.500 158.707sec(train) 5.066sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 121 tst: l 0.881 a 0.753  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.970sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 122 tr: l 0.643 a 0.830  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.073356 cl_acc 0.500 156.360sec(train) 4.871sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 122 tst: l 0.883 a 0.754  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.959sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 123 tr: l 0.660 a 0.825  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.072622 cl_acc 0.500 154.156sec(train) 5.402sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 123 tst: l 0.879 a 0.756  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.961sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 124 tr: l 0.653 a 0.826  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.071896 cl_acc 0.500 161.875sec(train) 4.946sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 124 tst: l 0.881 a 0.752  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.034sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 125 tr: l 0.653 a 0.827  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.071177 cl_acc 0.500 163.160sec(train) 6.557sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 125 tst: l 0.872 a 0.756  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.212sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 126 tr: l 0.636 a 0.832  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.070465 cl_acc 0.500 237.861sec(train) 6.444sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 126 tst: l 0.875 a 0.754  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.367sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 127 tr: l 0.642 a 0.830  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.069761 cl_acc 0.500 247.070sec(train) 6.861sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 127 tst: l 0.872 a 0.758  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.313sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 128 tr: l 0.640 a 0.830  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.069063 cl_acc 0.500 172.388sec(train) 4.922sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 128 tst: l 0.872 a 0.759  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.998sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 129 tr: l 0.641 a 0.831  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.068372 cl_acc 0.500 155.789sec(train) 4.475sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 129 tst: l 0.867 a 0.758  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.886sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 130 tr: l 0.638 a 0.832  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.067689 cl_acc 0.500 160.664sec(train) 5.361sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 130 tst: l 0.871 a 0.757  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.029sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 131 tr: l 0.652 a 0.825  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.067012 cl_acc 0.500 153.950sec(train) 4.942sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 131 tst: l 0.872 a 0.756  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.976sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 132 tr: l 0.628 a 0.834  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.066342 cl_acc 0.500 160.443sec(train) 7.168sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 132 tst: l 0.867 a 0.757  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.340sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 133 tr: l 0.635 a 0.832  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.065678 cl_acc 0.500 152.485sec(train) 4.638sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 133 tst: l 0.866 a 0.757  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.906sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 134 tr: l 0.634 a 0.832  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.065021 cl_acc 0.500 215.549sec(train) 8.571sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 134 tst: l 0.859 a 0.759  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.625sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 135 tr: l 0.644 a 0.827  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.064371 cl_acc 0.500 250.585sec(train) 7.999sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 135 tst: l 0.862 a 0.757  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.447sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 136 tr: l 0.626 a 0.834  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.063727 cl_acc 0.500 193.686sec(train) 4.747sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 136 tst: l 0.853 a 0.761  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.951sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 137 tr: l 0.630 a 0.833  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.063090 cl_acc 0.500 155.837sec(train) 4.572sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 137 tst: l 0.862 a 0.759  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.885sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 138 tr: l 0.594 a 0.846  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.062459 cl_acc 0.500 160.238sec(train) 5.135sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 138 tst: l 0.864 a 0.759  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.957sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 139 tr: l 0.614 a 0.839  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.061835 cl_acc 0.500 157.584sec(train) 4.857sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 139 tst: l 0.852 a 0.761  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.966sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 140 tr: l 0.624 a 0.835  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.061216 cl_acc 0.500 158.149sec(train) 4.765sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 140 tst: l 0.851 a 0.761  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.955sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 141 tr: l 0.628 a 0.833  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.060604 cl_acc 0.500 163.769sec(train) 5.869sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 141 tst: l 0.853 a 0.762  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.983sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 142 tr: l 0.630 a 0.831  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.059998 cl_acc 0.500 194.978sec(train) 6.572sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 142 tst: l 0.849 a 0.762  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.285sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 143 tr: l 0.616 a 0.838  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.059398 cl_acc 0.500 238.521sec(train) 6.994sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 143 tst: l 0.849 a 0.763  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.490sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 144 tr: l 0.624 a 0.835  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.058804 cl_acc 0.500 223.044sec(train) 6.154sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 144 tst: l 0.847 a 0.763  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.348sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 145 tr: l 0.612 a 0.838  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.058216 cl_acc 0.500 160.197sec(train) 5.176sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 145 tst: l 0.843 a 0.766  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.021sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 146 tr: l 0.629 a 0.831  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.057634 cl_acc 0.500 152.473sec(train) 4.949sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 146 tst: l 0.848 a 0.761  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.992sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 147 tr: l 0.608 a 0.838  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.057058 cl_acc 0.500 164.245sec(train) 4.838sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 147 tst: l 0.841 a 0.766  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.941sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 148 tr: l 0.604 a 0.841  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.056487 cl_acc 0.500 156.997sec(train) 4.685sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 148 tst: l 0.843 a 0.766  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.895sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 149 tr: l 0.599 a 0.841  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] lr 0.055922 cl_acc 0.500 155.771sec(train) 4.961sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 149 tst: l 0.845 a 0.765  clct[np.int64(10), np.int64(0)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.932sec\n",
      "result written at output/results.pickle\n",
      "---train cluster Ended in 8.71 hour (31357.297 sec) \n"
     ]
    }
   ],
   "source": [
    "import DFedAvgM as DFedAvgM\n",
    "import json\n",
    "import time\n",
    "import torch\n",
    "import numpy as np\n",
    "\n",
    "\n",
    "with open(\"config.json\", \"r\") as read_file:\n",
    "    config = json.load(read_file)\n",
    "\n",
    "for lr in learning_rates:\n",
    "    config['lr'] = lr\n",
    "    res_final = []\n",
    "\n",
    "    for seed in seeds:\n",
    "        print(f\"---------------------------------DFedAvgM, lr: {lr}, seed: {seed}---------------------------------\")\n",
    "        start_time = time.time()\n",
    "        config['data_seed'] = seed\n",
    "        config['train_seed'] = config['data_seed']\n",
    "\n",
    "        print(\"config:\",config)\n",
    "        device = torch.device(\"cuda:0\" if torch.cuda.is_available() else \"cpu\")\n",
    "        print(f\"Using device: {device}\")\n",
    "\n",
    "        exp = DFedAvgM.TrainCIFARCluster(config)\n",
    "        exp.setup()\n",
    "        res = exp.run()\n",
    "        res_final.append([[r['test']['loss'] for r in res], [r['test']['acc'] for r in res], [r['test']['cl_acc'] for r in res]])\n",
    "        del exp\n",
    "        duration = (time.time() - start_time)\n",
    "        print(\"---train cluster Ended in %0.2f hour (%.3f sec) \" % (duration/float(3600), duration))\n",
    "\n",
    "    res_mean = np.mean(res_final, axis=0).tolist()\n",
    "    d_fedavg_m.append(res_mean)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-22T21:16:46.571800Z",
     "iopub.status.busy": "2025-09-22T21:16:46.571368Z",
     "iopub.status.idle": "2025-09-22T21:16:47.223143Z",
     "shell.execute_reply": "2025-09-22T21:16:47.222204Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Average Test Loss (Last Epoch): 0.8563\n",
      "Average Test Accuracy (Last Epoch): 0.7604\n",
      "Average Cluster Accuracy (Last Epoch): 0.5000\n",
      "Average Standard Deviation (Last Epoch): 0.0000\n"
     ]
    },
    {
     "data": {
      "image/png": "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KChweb2HHnrICAwMLPVaxbfiynOedZs6dWqF2uutt95yer233nqrQtczDMPYuHGjceaZZ5ap3vHx8cacOXNcXistLc249NJLy9UWffv2dXotd9+X8lq+fLnTa27bts249tprS3zeCy+80EhLSyvx+gsWLDAaN25cptcxfPhwIzk52eW1EhMTnf5Mvfrqq0ZoaKjHft7K836VhbPf98TERGPfvn1Gly5dXLaHxWIxpkyZUuK18/LyjClTpjh9/c62iy66yDhw4ECp15w6daoRERFRpmuOGTPG4Rqu3quvv/7aqFOnjstr1a1b19i8eXOF27q4O+64w+H6zz//fInnjBkzpkzv/a5du5zW//vvvzf+/e9/Oz1W0r/vnlZYWGgkJCQ41OHKK690Wv6ll15yWudNmzZVSX3Hjh3r9Pl//vlnp+X79u3r8PvkKZ999lmZ2w2oKIYCAl5UUFCgK6+8Ul9++WWZyufk5Gj69OnasmWL5s+f7zCU4p133tHDDz9cGVX1C19//bWGDRtW5snRp06d0s0336zNmzfrpZdecjg+ceLEEod+lpUvvS9jxozRmjVrSiyzZMkSDRkyRMuWLXM6XOfpp5/WPffcU+bn/OSTT7R582atXr3a5fzE0y1YsEC//vqrDMMo8/P4gvT0dJ1//vklLi9tGIYef/xxBQYG6pFHHnE4npubq4svvljff/99mZ/322+/1VlnnaUffvjBofdAMhd7GDx4sFauXFnma5bVkiVL9NhjjykvL89lmaNHj2rkyJHavHmzgoOD3Xo+Z3OLzj77bLeuWZp77723TD2DCxcu9FiPateuXfXqq6/a7fv777+dzl9ytcR8t27dnO7/5ZdfdOaZZ7pfyVLExMQ43d+gQYMynX/8+HGdd9552rp1q1JSUhQVFaW6deuqa9euuuSSSzRixAiFhISU6VrOfkaWLFmi/Px8BQXxcRiewU8S4EWTJ092GqoCAwPVuHFjhYeHa/fu3crOzrY7/umnn2r69OkO4+dfeeUVp8/ToEED1alTRzk5OTp69KhOnTrlsk7W/6BPnDjhdAUpZ/+B+8LE/r///lujRo1yGqoiIyOVlJSk48eP6/Dhww7HX375ZbVr107jxo2z7UtOTtb777/vUNY63CsmJkYZGRk6cOCAsrKySqybJ94XT7GGqsjISDVv3lxHjhxxOkxr5cqVev7553XXXXfZ7f/yyy917733Or12/fr1VatWLe3fv18pKSl2x7Zv367hw4eXedjUxo0bbY+jo6OVmJiolJQUj6/ktXLlSlkslhLLJCYmlnk1Nesy15JUp04d1a9fX7t27VJ6erpD2ccee0xDhw5Vjx497PZPnDjRZahq1qyZIiMjtX37docgc+zYMV1yySX6/fffFRERYXfshhtucBmqgoKC1KJFC4WEhOjAgQMuFx5w5eeff7Y9btGihQzDcDrUa+vWrfriiy/cmgt18uRJh2GAwcHB6ty5c4WvWRbFQ1XdunVVr149p787x48fL9Pw17KIiopy2Ldp0yanZZs2bep0f+PGjZ3ud3UdT1u7dq3Dvnr16qlJkyZlOj8jI0OrV6+2fZ+cnKzk5GRt375dH374oe677z69+eabuuCCC0q9VsOGDdW4cWO7Ia5paWnasmWLzjrrrDLVByiVl3vMgGqlPEMBt23bZgQFBTmUvemmm4xDhw7ZyqWmphqTJk1yKBcWFuYw9Of0IT5RUVHGmjVrHJ770KFDxqeffmqMHz/eqFu3rtPX4mqYnid5cijgyJEjnV7r3nvvNbKysmzlFixYYERFRTmUq127tpGammort3btWocynTp1Mg4ePGj3vAUFBcb27duNN954wxg+fLgxePBgh7p58n0pK1dDASUZt99+u5GZmWkYhjm0aN68eU6HnNWrV8/IycmxXTM3N9do3ry5Q7mzzz7bbmhRQUGB8dZbbxnBwcEOZT/77DOHujobXiaZQ19fe+01Izc311b2wIEDFR7G5Ko9SttcDUdy9fseHBxsvPvuu0ZhYaFhGIaRnZ1tTJ482WnZyy+/3O6aW7ZsMQICAhzKJSUlGRs2bLCVO378uDFs2DCn13z88cftrunqZyE0NNR45plnHIZ9btq0yZgwYYJxyy23OLxmV+9V06ZNjfXr19vKvfvuu06Hvt50003les9O5+y1tGnTptTz3B0KaH2N33//vV35TZs22f077OrftIpszuo3c+ZMp2W//vprp687IyPDaflRo0aV2mbuWrZsmdPnnj59ustzTh8KWJYtICDAmD9/fpnqNGjQIIfz3Rl6DpyOYAV4UHmC1b333utQrlevXi6v7WzOxukfoE7/AN+mTRvbhztX8vPzne73p2CVnJzs9EPcJZdc4rT8nDlznD7ve++9ZyvjLFiNHTu21Lo4a09Pvi9l5erDdJ8+fZyWf/jhh52WX7x4sa3M4sWLHY5HRUUZJ0+edHrNO++806H8RRdd5FDO1Yf1N9980602OF1FP+CWN1g99NBDTsuff/75DmUDAwPtgs1dd93l9Jrr1q1zuF52drbToNuyZUu7cqNHj3Z6zU8//bTE9srOznbY5+q9Wrp0qUPZCy+80KHc2WefXeJzluaNN94o17+bVu4Gq9DQUOOvv/4q9XkqO1g9/vjjTsueHvis8vPznZZ39nvoSVu3bjXq16/v8LytW7c20tPTXZ53erCqV6+e0bFjR6Np06ZO/+Bg3cLCwoy9e/eWWq+rr766zL+vQEWwKiDgJUuXLnXYt3PnTnXr1s3p5mwo0unDhU4fzrB161b17dtXTz75pL744gv99ddfys3NtSsTGBjo9mvxtpUrVzqskiVJN998s9Py1157rdMldpctW2Z73LZtW4ex+3PmzNFVV12ll19+WUuWLNGePXsc5gA5a09fel/+9a9/Od1/ww03ON1ffJiXs59ZyVzK2NnP7KeffupQ9ocffijTDU2bNGmiMWPGlFrOXVFRUeratWuJW3nnopSnjQsKCrRu3Trb98V/Bq3OOussp3NlQkNDdd111zns/+eff7Rv3z7b9999951DmbPPPlvDhg1zWs/i1y+Ljh07asCAAQ77nc31cne4q7NVNz2xGmBphg8f7vT1nO6GG26QYf7R2u2tPKsNnv7vUGn7K9OGDRvUt29fh2HXderU0cKFCxUZGeny3JiYGF1//fWaP3++jh49qsOHD2vz5s3as2eP0tPT9dxzzyk2NtbhvOzsbD3xxBOl1s3Zz4p16C7gCcyxArxkz549DvsOHTrk9AbDZb3GnXfeqZ9++slu36pVq7Rq1Srb94GBgWrbtq369Omj0aNHq3fv3uWsue/Zu3ev0/2dOnVyuj8sLEytW7fW5s2b7fYX/zAaFRWlW265xW5+VGFhoebNm6d58+bZ9oWHh6tLly4aMGCArrvuOrVs2dLh+XzpfXEVEpo0aaLY2FiHuVHF28TZz2x6enq55pRkZWXp6NGjpc7L69u3b6XcxPR0nr6PVVxcnMv5Lq5udFq8jZ39LLv6OS7p2L59+9SkSRNlZGQ4/eB4/vnnu7xmebman+JsjlBZF5Zxxdn5rm6+7kn9+/ev9OcoC2ehQpLDH2asXLW3dVl2T1u0aJFGjRrlcCuLunXr6vvvv1erVq1KPP+LL75w+XsfHh6uO+64Q927d1efPn0cQuPChQtLXUre2WIapc2RBcqDHivAS5KTk92+xukfmK688krNnj27xA8aBQUF2rJli2bOnKk+ffpoyJAhyszMdLsu3nR6GLAqqR2cHTv9PXnuuec0bty4Ej/gZ2VlafXq1Xr44YfVpk0bPfTQQw5lfOl9KW+bpKWl2R574mdWKttfiF1Nuvd1zsKElau2L97Gzn6Wy/ueSUXvlav3LCEhweU1y6tRo0ZO91fGSmvOetFSU1M9/jyn85WfR1erarr6nXK1v6yrc5bHa6+9pssuu8whVCUlJenHH39Uhw4dSr1GWf6Yct5556lnz54O+/fu3VtqSHL2+xUeHl7qcwJlRY8V4CVxcXEl3ky2LJwNfxs7dqyuuuoqffbZZ1q2bJl+++03/fPPPy7/w1m0aJHuvfdevfzyy27VxZtc/RU3LS3N5TCh4h9mrU7/K25wcLBmzZqlKVOm6JNPPtEPP/ygLVu2aM+ePU6HsxUUFOiRRx5Rp06ddOWVV9od85X3xdnqdFbO2qT4B3dP/ZXb2c/t6co6DM3XlLd9Jfs2jo2Ndfgw7Oq8ko5Z3ytX71l5V/4riav3qrTVFivC2e+zJ1+LK2X9eazs5dZd9Q666rUv3htalutUhGEYevDBB/XYY485HOvWrZsWLFig+vXre+z5JHOlztNHAUjmHxJKCkrOgqYn/8gAEKwAL0lMTHQIVhMmTPDIB+mYmBjdcMMNdnM6jh49qj/++EMzZsxwmPvy3nvv6cUXX6ySoVeVwdXQq02bNqlZs2YO+7OysrR9+3aH/a6WAG7atKnuvPNO3XnnnZLMYLB//35t3LhR06ZNcxhS+M477zgEK8k33pfNmzc7HT62b98+p3/NLd4miYmJDsc7dOig33//3WP183fJycm2YXinc9VOxcs2bdrU4cNfSUtjuzpmvWZkZKRq167t8G+Ns7lc/iApKclhny/Nkans5dZbtmyphIQEhzDp6jld7ffUfb9yc3N10003Ob01xaWXXqoPP/zQYel/T3A2LFkqPSQ5C+HOfqaAivLPT1FANeBssvcnn3yiY8eOlen8ZcuWOXwQPn0IRnF169ZV//799frrrzscS05Odvjg5eovtL44bLBv375OF3uYM2eO0/Lvv/++w73BJMd5J67aMzAwUImJibriiisc7iUmmYsHlOU6UvnfF3e9+eabTve//fbbTvefe+65tsfOfma3bNliN1esJFu3btWff/5ZprL+rDxtHBQUZHcfK2dzn3777TenN6fNzc3V3LlzHfa3bNnSLqw5u8fPL7/8UuqNyZ39jnibszmCO3bscHvulr+wWCy66qqrHPZ/++23TkPDhx9+6LCvQ4cOTuf73XDDDbJYLHZbv379XNYlOTlZgwYNchqqJk6cqM8//7xcoerll192uUBOcT/++KPdojpWLVq0KLVnccuWLQ77uIcVPIlgBXjJjTfe6BAGDh8+rIEDB+rbb791mJibkZGhH3/8UQ888IDOOOMMDRgwwGGFrcsuu0yDBw/W7NmztW3bNochVzk5OS5vVnv6Cnjx8fFOyy1YsKBMr68qxcbGOl3hbNGiRZoyZYrdB8SFCxfaep6Kq1Wrli699FK7ffXr19eYMWP00Ucf6eDBgw7nnDx5Um+99ZbD/tPb0pPvi7tWrFihu+66y9YmhmHoo48+0v/+9z+HsvXq1bObtD9gwACnf9297LLL9Oabbzp8EM/Ly9PmzZv13HPPqXfv3mrbtq3TG4ZWN4899pjef/992+9wTk6O7r33Xqe9REOHDrVbJe2GG25w2kM5cuRI/frrr7bvT548qauvvtrpjXhvuukmu+/Hjh3rtJ6jR4/WCy+84BD8//rrL9155526/fbbS3iV3lG7dm2HBWLy8vLs2qa6GzdunMP/HRkZGbruuutsc+ry8/M1depU2w3Bi7v11lvdrsPevXt13nnnafny5Xb7AwIC9Nxzz+mll14qd0/7hg0bdMEFF6hr166aMWOGw892dna2XnjhBQ0dOtTpaofDhw8v8foHDhxwuMF4VFSUy0VlgAqpomXdgRqhPPexMgzDuP32213elyMiIsJo1aqV0aFDB6NRo0aGxWJxKLNr1y67651+D5CQkBAjKSnJ6NSpk9GmTRsjMjLS6XO1aNHCoW779+93WbdmzZoZXbt2tW3FbyJbHq7u+XL69V1tH3zwge1a27Ztc/n6oqKijI4dOxoNGjRw+ZpmzJjhUL/Ty0RHRxutWrUyzjrrLKNFixZOb/AsyfjXv/5Vae9LWZV0g+DibVKvXj2XZZ555hmH63722WcuywcHBxtNmzY1OnXqZDRr1swICQlxKOPsHmXO7o00derUCr92V1y1Q1l+1q6++mqH67n6fbdudevWNTp27GhER0c7PR4QEGD88ssvDtf997//7fKaSUlJRvv27Z22rfW4s/sEubqBtvV9a9OmjdGxY0ejVq1atv1jxoxxuE553itn7ePqnmDlMXHiRIfrvvjiiyWe4+59rFz9G+4tru53Fh4ebrRv395ISEhwevzss882CgoKnF6zrG1kGIZxwQUXOL1+dHR0mX6fFixYUKbnr1WrltG+fXsjMTGxxPtY1alTx+X99Kw+/fRTh/OuuOKKcrc9UBLmWAFe9Mwzz2jXrl366quvHI5lZmbq77//duv6ubm52rVrV6nlHnjgAYd9jRo10rnnnut0gvDu3bvt7qtVWFjoVj1Lu74rR44csT1u3bq1PvzwQw0fPtxh6eH09PQS5wGNHz9e//nPf0p9vrS0tBIXEpDMpdyd9YgV58774q4hQ4Zo4cKFpbZJ3759NWnSJIf9V1xxhZ566indc889Dsfy8vK0d+9elxPpfVFZl4svy723JLOXr0mTJlq/fr2OHj2qo0ePuix7//332w0DtHrllVf0zz//OF0GvqSfm1q1arm8T9Dbb7+tI0eOaOXKlQ7H8vLytHXrVpfX9TUjRoxwmIv6/fff67bbbvNSjareo48+qj///FOLFy+225+VlaU//vjD6TlJSUmaN2+eR+ZsulrePS0trUy/T2Ud4nzixIlS59DFxMRowYIFLkdZWDkbZjhixIgy1QMoK4YCAl4UFBSkzz//XE8++WS57sUSGhqqYcOGOfxHUt5hY2FhYXr22Wd14403Oj0+Y8YMlyvu+aKhQ4fqp59+Uvv27ctUPjY2VrNmzdLMmTOdHg8ODi7X8zdo0EALFy5Uu3bt7PZ7+n1xx4svvqiJEyeWWObCCy/UwoULXd6kePLkyVq0aJHTxSxcsVgs6tWrV7lvtutvwsLC9M0335Q4N8Visei+++7TI4884vR4aGiolixZonvuuafMPzsDBgzQb7/95vCzZxUeHq6lS5dq6tSplbKYQFU677zzHIYDfvPNN27ffNifhIWF6YsvvtBtt91WpmXtBw0apFWrVjldzMdXdO/evdwr9PXr10/r1q0rdTGO/Px8ffzxx3b74uLidMUVV5S7nkBJ6LECvCwgIED33HOPxo8frw8++EDLly/Xxo0bdezYMaWlpSksLEwJCQlq2bKlzjzzTPXr10/9+/d3GngWL16sdevWafXq1dq4caO2b9+uvXv3KiUlRXl5eYqIiFDdunV1xhln6Pzzz9c111yjBg0auKzbWWedpU2bNumFF17Q999/r127dikjI8Pp+HZf0bVrV/3+++9avHixvvzyS61Zs0YHDhxQSkqKwsPDVbt2bXXu3FkDBw7UddddV+J9h06dOqVVq1ZpzZo1+u2337Rjxw4dOHBA6enpMgxDkZGRaty4sTp06KBBgwZp1KhRTpf69fT74o6AgAC99NJLGj58uGbPnq3Vq1fryJEjiomJUZcuXXTDDTdo9OjRpV7n4osv1o4dO/TVV19p8eLF+uWXX3Tw4EGlpKQoMDBQsbGxatasmdq3b6/zzjtPF1xwgc/cC6iy1apVS8uWLdN7772nuXPnavPmzTp16pTq1q2rfv36acKECaV+EAwODtaTTz6pO+64Q++8845WrFihP/74QydPnlReXp7i4uLUrFkz9erVS6NHj3ba83W6oKAgTZs2TZMmTdJ7772nlStX6rffftPx48eVnp6uhIQE1atXT+3bt9cFF1ygQYMGeapJPMpisei2226z66HKzc3Vxx9/rFtuucWLNataISEhevHFF3Xrrbfqvffe05IlS7R7926dPHlSUVFRatCggfr27auRI0eWGPR9xa233qpbbrlFq1at0ooVK7Rx40b9/fffOnLkiNLT0xUSEqK4uDi1atVKZ599tkaNGqWuXbuW6dpLlixx6CW7+eabFRYWVhkvBTWYxfDlT0gAgApZsWKF3cITVrt27fLpv1r7k2nTpjmsCpmYmFimYaxwT2Zmppo1a2a3imqvXr30448/erFW8FVXXXWV5s2bZ/s+NDRU//zzT435Yw+qDkMBAQCAX4mIiHCYg7h69Wqnc0JRs+3atcthGOD48eMJVagUBCsAAOB3xo8f7zDX6tFHH/VSbeCrnnzySbtbXMTHx1fKwkCARLACAAB+KCQkRC+99JLdvsWLF2vjxo1eqhF8zcGDBx1uzP3II4+odu3a3qkQqj0WrwAAAH5p8ODBPr2YDryrYcOGDjcuByoTPVYAAAAA4CZWBQQAAAAANzEU8DSFhYU6ePCgoqOjZbFYvF0dAAAAAF5iGIbS0tLUsGFDBQSUPNiPYHWagwcPqkmTJt6uBgAAAAAfsW/fvlKX6SdYnSY6OlqS2XgxMTFerg0AAAAAb0lNTVWTJk1sGaEkBKvTWIf/xcTEEKwAAAAAlGmKEKsCAgAAAICbCFYAAAAA4CaCFQAAAAC4iWAFAAAAAG4iWAEAAACAmwhWAAAAAOAmghUAAAAAuIlgBQAAAABuIlgBAAAAgJsIVgAAAADgpiBvVwAAAMDXGYahvLw8FRYWersqAMooICBAwcHBslgsVfJ8BCsAAAAXCgoKdPz4caWlpSkvL8/b1QFQTsHBwYqOjlbt2rUVGBhYqc9FsAIAAHCioKBA+/btU05OjmJjYxUVFaXAwMAq++s3gIozDEMFBQVKT09XcnKysrKy1KRJk0oNVwQrX/bcc9Jbb0k33ijdeae3awMAQI1y/Phx5eTkqGnTpgoPD/d2dQBUQFRUlGJjY7V3714dP35c9erVq7TnYvEKX3b0qLRli7Rvn7drAgBAjWIYhtLS0hQbG0uoAvxceHi4YmJilJaWJsMwKu15CFa+LCLC/JqV5d16AABQw+Tl5SkvL09RUVHergoAD4iOjrb9XlcWgpUvs/6FLDPTu/UAAKCGsa7+V9mT3QFUDevvcmWu7Emw8mX0WAEA4FUsVAFUD1Xxu0yw8mX0WAEAAAB+gWDly+ixAgAAAPwCwcqX0WMFAAAA+AWClS+jxwoAAADwCwQrX0aPFQAAQLU1bdo0WSwWFkmpJghWvoweKwAAUAOsWLHCFjCKb0FBQUpISFBSUpL69OmjO+64Q59++qlyc3NLvWazZs2cXtPZ1q9fv8p/kR7Sv39/W70vvPBCb1enzN5++227Nm/RokWZztu3b58CAwPtzt29e3flVraCCFa+zNpjRbACAAA1UEFBgU6dOqXdu3dr1apVeuGFFzR8+HA1btxYjz76qPLz871dxSq1Z88erVy50vb9999/r4MHD3qxRhW3c+dO/fTTT6WWe//99yv13lOeFOTtCqAE1h4rhgICAIAaYvz48frPf/5j+z49PV2nTp3S5s2b9f3332vp0qU6duyY/vvf/2rBggVauHCh6tSp4/J6DRs21Lffflvic0ZGRnqs/pVp7ty5MgxDoaGhKigoUH5+vt577z3dc8893q5auYSFhSk7O1tz587VueeeW2LZuXPn2p3jy+ix8mXWHqvsbMlPkjoAAIA76tatqw4dOti2c845R4MHD9a9996rJUuWaMuWLercubMkae3atbriiitKHBoYHBxsdz1nW1JSUlW9PLdYQ8aQIUNswwCt+/zJpZdeKkmaP39+ie/dxo0b9eeff0qSLrvssiqpmzsIVr7M2mMlmeEKAACghmvXrp1Wr15tC1erV6/WjBkzvFyryrdmzRpt375dknTNNdfo2muvlSRt2bJFGzdu9GbVym3UqFEKCQnRyZMntWjRIpflrKGxe/fuatOmTVVVr8IIVr7M2mMlMc8KAADg/4WHh2vu3Lm21fSeeeYZ5eXlefx5vvjiC40YMUJNmzZVWFiY4uLi1K1bN02fPl2nTp0q9fz9+/fr1ltvVfPmzRUWFqaGDRvq0ksv1dKlS8tdl3fffVeSFB8fr0suuUSXX365oqOj7Y4Vt2fPHgUEBMhiseiBBx4o9foffvihbXGIr7/+2uF4fn6+XnrpJfXo0UMxMTG2tnj++eeVm5ur3bt3285/++23S3yuhIQEXXLJJZJc97jl5+frww8/lCRdd911pdbfFxCsfFlgoBQSYj5mnhUAAIBN+/btdcEFF0iSDh48qHXr1nns2qdOndKAAQN0xRVX6JNPPtG+ffuUk5OjlJQUbdiwQdOmTVObNm20Zs0al9dYtWqV2rdvr5kzZ2rXrl3KycnRoUOHtGDBAl1wwQWaPn16meuTm5urjz76SJI0YsQIhYSEKDw8XMOGDZNkhqLTF/JITExUr169bMdL8/7770uS6tSp47DaYGpqqnr37q3bb79d69atU1pamq0t7rzzTvXu3VvJycllfj1SUVhatGiRTp486XB8yZIlOnLkiIKCgjR69OhyXdtbCFa+jpUBAQAAnBo4cKDt8apVqzxyzZycHA0cOFDLli1TYGCgrrvuOn344Ydas2aNVq1apf/973+qVauWjh49qosvvlh79uxxuMbevXs1ZMgQpaamKiAgQOPGjdPSpUu1bt06vfHGG2rVqpWmTZtW4jC44hYuXGgLH9YhgMUfHz16VN98843Deddcc40kadeuXSWuwHfixAktWbJEkjRy5EgFBdmvbzd69GhbiOzVq5fmzZun9evXa/Hixbrmmmu0du1ajRs3rkyvxeqSSy5RQkKCcnNzNX/+fIfj1p6sQYMGlbg4iS9hVUBfFxEhpaTQYwUAAHCaLl262B5b5x+dLi8vT1u2bHF5jZCQELVu3dr2/cMPP6yNGzcqLi5OS5cuVdeuXe3Kn3feebrmmmvUs2dPHTp0SPfff7+tt8fqrrvuUmpqqiTpvffe01VXXWU71q1bN40YMUK9e/fW+vXry/Q6rUP9mjVrpvPOO8+2//zzz1fDhg118OBBvfvuuxoyZIjdeSNGjNBtt92mvLw8ffDBBy5X4Pv4449tQymtYczqyy+/1OLFiyVJw4YN08cff6yAgKK+mUGDBqlz5866++67y/RarEJCQjRq1CjNmjVLc+fOtQtmaWlp+vLLLyVJ119/fbmu6030WPk6eqwAAPBdhiFlZFT/zTC83dJO1apVy/bY1ZyngwcPqmPHji634sPe0tPTbQthPPLIIw6hyioxMVH//e9/JZmhJCMjw3bs8OHD+vzzzyWZq/cVD1VW0dHReu2118r0Gk+cOGGb83T11Vfb5pVJUkBAgK6++mpJ0oIFCxyG49WqVUuDBg2SZK7A5+q+X9Zg2Lx5c/Xs2dPu2OzZsyWZ89pmz55tF6qs7rzzTruQW1bW4YA//fSTdu7cadv/ySefKCsrS7GxsRo6dGi5r+stBCtfx72sAADwXZmZUlRU9d989HNIVFSU7XFaWprb11u5cqVSUlIkScOHDy+xbJ8+fSSZPWIbNmyw7V++fLkKCgokSTfeeKPL83v06KH27duXWqcPP/zQ1ptUfBiglXVfdna2Pv74Y4fj1h6oY8eO6bvvvnM4vnfvXq1evVqSbCHNKj8/33ZD4pKG5FkslgotMNGzZ0+1bNlSktmzZ2UdBjhixAiFhYWV+7reQrDydfRYAQAAOFU8TMXExDgtk5iYKMMwXG67d++2lS0+NK9Bgwa2Ve6cbR06dLCVPXz4sO3x77//bnvcvXv3Euvfo0ePUl/jO++8I8kc9ti2bVuH4506dbLVxdnqgJdeeqlt9cDThyxKZnAz/r9H8vRhgDt27FDW/38GddV7Z9WtW7fSXopT1kBmDVb79u3TihUrJPnXMECJOVa+jx4rAAB8V0SElJ7u7VpUvuL31vQhx48ftz1OSEhw+3pHjx6t0HmZxT6nFV/hrm7duiWeV69evRKP//XXX7aw56y3yuq6667Tvffeq9WrV2vXrl12NzwODw/XFVdcoXfffVdffPGFMjMzFVHs/bSGrS5dujjcK6r48MrSFpCo6AIT1157raZOnaq///5ba9as0fLly2UYhsN8Mn9AsPJ19FgBAOC7LBYpMtLbtaixfv31V9vjM844w+3rWYfwSdLGjRsVHBxcpvMaN27sdH/x+VAVUbwH6s4779Sdd95ZYnnDMPTuu+9q6tSpdvuvueYavfvuu8rIyNCXX35pm/f1xx9/2HrYTu+tqirNmzdXr169tHr1as2dO1fLly+XZAYud9uvqhGsfB09VgAAAE4VnzPkid6N4oth1KlTx2VgKkl8fLzt8ZEjR9SkSROXZY8cOeLyWGFhodOhe6WZO3euQ7AaMGCA6tWrpyNHjuj999+3BSvr9QMCApzeK6r4azl27FiJz1va8ZJcf/31Wr16td58801lZ2dL8p+bAhdHsPJ19FgBAAA42LJli77//ntJUpMmTSo8x6e4zp072x6vXr1ao0aNKvc1OnbsaHu8bt26EoNVSTc1Xr58ufbt2ydJmjhxosul0q1++eUXvfDCC9qxY4dWr15tuzmwJAUGBmr06NF68cUXtWTJEp04cUIJCQm2Gwf3799fDRs2dLhmixYtFBYWpuzsbLsFOpwp69LxzowcOVK33XabLVSdffbZdkvg+wuCla+zBit6rAAAACRJWVlZuv76622LLtx9990ON7WtiIEDByoiIkKZmZl66aWXNHLkyHIPR+vfv78CAwNVUFCgd955R8OGDXNabt26dSXeX8s6DDAwMFAPPvhgqfO1Bg4cqFdeeUX5+fl699137YKVZA71e/HFF5WXl6f58+frzDPPtC3c4WoYYFBQkPr06aMlS5bom2++0bFjx5zOpTIMw7aSX0XExcXp8ssv1xdffCFJGjNmTIWv5U2sCujrrEMB6bECAADQn3/+qfPOO882v6pv374aP368R64dFxenCRMmSDLvrXTHHXeosLDQZfkjR47o9ddft9vXoEEDXXbZZZKkr776SvPnz3c4Lz09XWPHjnV53YyMDH322WeSpN69e5caqiSpdu3a6tu3ryTznlU5OTl2x7t3765WrVpJMocAfvDBB5KksLAwXXnllS6va61nVlaWxo0b57Q9nnvuOW3cuLHUOpZk3rx5ys7OVnZ2tsfez6pGsPJ19FgBAIAa5OjRo9qyZYtt++WXX/TNN9/oqaee0kUXXaQOHTrYPsSfc845+uSTT8q8yERZPPzwwzr77LMlSS+++KK6dOmiGTNmaPXq1frtt9+0fPlyvfLKK7r88svVtGlT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XZDcf99qul9//VVPPfWU6tWrp6effrrM59HunkOw8hFpaWm2xxERES7LFT9W/ByUX2Fhoa677jodOnRIYWFheuWVV+yO8564b+zYsUpJSdG0adNsQ6VKQ7tX3KlTp2yPH330UQUHB+vjjz9Wenq6Tp06pT179mjEiBGSpNdff13PP/+8rTzt7r5Jkybps88+U926dSVJWVlZtuFkubm5Sk9PV0pKit05tHvlcLddrY9LOrf4cd6T0mVlZWnEiBHKzMxU7dq19cQTTziU4feh4vLz83XTTTcpPz9fL730kuLi4sp8Lu3uOQQr1Fi33367Fi5cKEmaMWOGzjzzTC/XqHp57733tGjRIp111lm68847vV2dGsE6pMz6+I033tDw4cMVHBwsSWratKnmzZunTp06SZIee+wxp/OBUH6ZmZkaNWqUhgwZoqZNm2rJkiU6duyYjh07piVLlqhdu3aaO3euevTooc2bN3u7ukCVys/P19VXX60NGzYoODhY77//vho2bOjtalUrTzzxhH777TcNGTJEI0eO9HZ1aiyClY+Ijo62Pc7MzHRZrvix4uegfO6++25bD9Xzzz+vm266yaEM70nFHTlyRJMmTVJgYKDmzJmjoKCgMp9Lu1dc8XZo1aqVLr/8cocyAQEBuvvuuyVJJ06c0IYNGxzOpd3Lb/LkyZo/f77OOOMMrVq1ShdccIFq166t2rVr64ILLtAPP/yg1q1b6/jx47r11ltt59HulcPddrU+Lunc4sd5T1wrKCjQNddcoy+++EJBQUH64IMPdOGFFzoty+9Dxfz555965JFHFBUVpZkzZ5b7fNrdcwhWPqL4X24OHDjgslzxY/y1p2LuuecePfvss5KkZ555RpMmTXJajvek4u677z6dOHFCt9xyi9q0aaP09HS7zToPSJLDPtq94oqPjW/Tpo3Lcu3atbM93rNnjyTa3R1paWl67bXXJEm33nqr01W4wsPDNWHCBEnminNHjx6VRLtXlvK2a0xMjKKiohzOP3XqlG04Z0nn8544V1BQoGuvvVbz589XYGCg3nvvPQ0fPtxleXfft5rq1ltvVW5urh544AHFx8c7/J9rHZlgGIZtX15enu182t1zCFY+om3btgoIMN+O4quznM56rH79+kpISKiSulUnkydPtk3ofOqpp3TXXXe5LMt7UnG7du2SJM2aNUvR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rVu3rkzHW7VqpZCQENt+a6DbtWuXjh075vL8vLw821yq00Ngly5dJJnzxlwNVQQAVG8EKwCAV3Tp0kWNGzeWJL322mvKzs5263rvvPOOy2Pr1q2zLTgxcOBAu2PW7w3DcFhGvbhPPvlEKSkpTq8xdOhQSeb8L+vS7gCAmoVgBQDwioCAAN1///2SzOXDr7/+euXk5Lgsn5qaqldeecXl8a+++krz58932J+enq6xY8fantP62Oryyy9Xw4YNJUn/+9//9PvvvztcY9++fbr77rslmQtMnL60+7XXXmu799QDDzyglStXuqzn/v37XR4DAPgv5lgBALxm3Lhx+u677/T555/r448/1saNGzV27Fj16NFDsbGxSk1N1datW7VixQp99dVXCgsL04QJE5xeq1u3brr66qu1cuVKDR8+XDExMdq8ebOefPJJbdu2TZJ066236swzz7Q7LyQkRK+99pqGDh2q1NRU9erVS5MnT9aAAQMUGBion376SU888YRtFcNnnnlGtWvXtrtGWFiY5s6dqwsvvFCZmZkaOHCgrrvuOl1++eVq3LixcnJytHXrVn399df66quvSgyQAAD/ZDEMw/B2JQAANVdeXp5uv/12zZ49W6X9l5SUlGR3c9xp06Zp+vTpksxerwEDBmjXrl1Oz73yyis1b948BQU5/5viO++8o7Fjx7oMPYGBgXrkkUc0ZcoUl/X79ttvddVVV9kt5+7M6a+zX79+Wrlypfr27asVK1a4PK/46+W/bwDwLQwFBAB4VXBwsGbOnKlNmzZp4sSJ6tixo2JjYxUYGKjY2FidddZZ+te//qVPPvlEf/31l8vrJCUlacOGDbr//vvVtm1bRUREKDY2Vn369NF7772nTz75xGWokqQxY8Zo69atuv3229W2bVtFRkYqPDxcLVq00M0336xff/21xFAlSRdddJF27typxx57TOeee65q1aqlwMBAxcTEqEuXLpo0aZLWrl1b4bYCAPgueqwAAH6LHhwAgK+gxwoAAAAA3ESwAgAAAAA3EawAAAAAwE0EKwAAAABwE8EKAAAAANzEqoAAAAAA4CZ6rAAAAADATQQrAAAAAHATwQoAAAAA3ESwAgAAAAA3EawAAAAAwE0EKwAAAABwE8EKAAAAANxEsAIAAAAAN/0fU2pCHFm9/MsAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 1000x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA24AAAH3CAYAAADDpwzFAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjMsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvZiW1igAAAAlwSFlzAAAPYQAAD2EBqD+naQAAkmlJREFUeJzs3XdcU1f/B/DPZe8AojJEQAUVRets3bPWvRWrVqttHY8d2lb782nrap9O7XY8rXVbd21t3Tjq3gNXtSqggorKCHue3x/3SSAmgUACCfB5v173Rbj3nHNPTgjky1mSEEKAiIiIiIiILJaVuStARERERERERWPgRkREREREZOEYuBEREREREVk4Bm5EREREREQWjoEbERERERGRhWPgRkREREREZOEYuBEREREREVk4Bm5EREREREQWjoEbERERERGRhWPgRkRERFQMSZK0jhUrVpitPosXL9aoi4ODA+Li4rTSde7cWaveL7/8cvlXmMrV2bNntV737du3m7taZCQGblQlBQYG6vwjXNrDUv8IXrhwAXPmzNE6ylpubi58fHz0ttfu3bvLvA5EJIuOjjbq95s5gxPS7cmTJ/jggw80zo0bNw6+vr5mqpF5nDt3DjNmzECLFi1Qs2ZN2NnZoWbNmmjevDmmT5+Os2fPlsl94+Li8Msvv2Dq1Kno3r076tatC4VCARsbG7i6uqJ27dro3bs3Pv/8c8TGxhpUZmk/lyxdulRneS1atMALL7ygcW7q1KnIysoy+vmT+diYuwJEVHYuXLiAuXPnap0v6+Bt165dePDggd7rK1as0PqDQkREhvnPf/6DhIQE9fc2NjaYMWOGGWtUvpRKJaZMmYK1a9dCCKFxLT4+HvHx8Th//jwWLFiAUaNGYeHChXBzczPJvQcOHIjff/9d7/XU1FSkpqbi7t272LlzJ2bNmoXp06dj7ty5sLa2NkkdDPX+++9r/KP05s2bWLJkCd56661yrQeZDnvciMjkivsP/W+//Ybk5OTyqQwRUSUSGxuLRYsWaZwbNmwYgoKCzFSj8pWQkIBu3bphzZo1WkHb04QQWLNmDbp166YR6BojOjq6ROmzs7Pxn//8ByNHjjTJ/UuiQ4cOaNOmjca5Tz75BOnp6eVeFzIN9rhRldSkSRN4eXnpvBYXF4f79+9rnQ8JCYGrq6vOPFXlD6YhEhIS8McffxSZJjMzE+vXr8fEiRPLqVZE9LRq1aohMDCw2HT6fleSeXz77bdaw93GjBljptqUvwkTJuDMmTNa511dXREQEIA7d+5AqVRqXDtz5gwmTpyITZs2lUmdvL29Ua1aNdy9e1fr3iobN25E7969MXbsWIPKdHFxQf369YtNV7169SKvv/TSSzh+/Lj6+/j4eKxcuRKTJ082qB5kYQQRaZg9e7YAoHUcOHDA3FUrseXLl+t8LmXp+++/13nPp4/nnnuuTOtBRLKoqCid78GxY8eau2oViq42XL58ebnWISMjQ7i7u2vUoUaNGiInJ0dvnk6dOlWa137Hjh06X4dXXnlFpKWlCSGESE9PF6+++qrOdDt27DC6Dk2bNhUARMOGDcV3330nYmJiNK7v3btX1KtXT+f9W7VqpbfcgIAAjbSdOnUyuq5CCPHo0SNhY2OjUXaDBg1MUjaVPw6VJDKhxMREfPvttxg0aBCCgoLg5uYGe3t7+Pr6onPnzpg3b57OVb90+eeffzBr1ix07twZfn5+cHZ2hq2tLWrWrInQ0FB06dIFr7/+OlasWIFbt25p5FVNWh43bpzOsnVNcDbVvLeVK1dqnWvbtq3WuRMnTuDGjRslKvv+/fv48ssvMWDAANSpUwfu7u6ws7ODn58fmjdvjtGjR2Pp0qV4/PhxmZSjb5GHgwcP6ryPoau5rVixQme5AJCXl4eff/4Z3bt3h4+PD2xsbNTXAHkhmOPHj2PhwoV45ZVX0LZtW9SvXx81atSAnZ0dnJ2d4evriw4dOmDatGk4ceJEido8KSkJCxcuxPDhwxEcHAxPT0/Y2dnB29sbTZs2xdChQ/Hdd9/h3r176jxhYWFaz+Xjjz8u8j6TJk3SytO7d+8S1VWlqPYEgE2bNqFv377w8/NTvz+HDBlSokVz0tPTsXTpUowYMQLBwcHw8PBQL4zw3HPPYebMmfjnn3+KLaeoxUBOnTqFV155BXXr1oWTk5NFLRTy8ssva9W7c+fOAICMjAx8/fXXaNu2Lby8vODg4IC6deti0qRJuHbtmsH3iI6Oxty5c9G9e3f4+/vDyckJjo6O8PPzQ6dOnfDBBx/g+vXrJaq3qX6HPO3OnTuYMWMGQkND4eLiAjc3NzRr1gzz5s1DSkpKicoqym+//YakpCSNc8OGDYONjfEDqA4ePKjz51E1NHDz5s3o378/atWqBTs7O41r5eWHH37QOhcQEIBFixbByckJAODo6IiFCxeidu3aWmkXLlxodB3q1auHTZs24erVq3jjjTe07tO9e3fs2bMHDg4OWnnPnDmD7Oxso+tQEl5eXujRo4fGub///rvEfwvIQpg7ciSyNKXpccvLyxOffPKJcHZ2Lranyd7eXsyePVvk5eXpLW/WrFnC2traoJ4r1VFYSfKpjtmzZxvddpcvX9ZZ9pEjR0TdunW1zs+cOdOgctPS0sSUKVOEra2tUc/F2HL09Vzo+9kw9D/d+npG4+PjRevWrYt8vS9dulTi17pnz57i/v37RbZ5Tk6OmD17tnBycjKozMLPa+nSpVrXa9eurfdnPjs7W1SrVk0rz5YtW4qsoz762jMpKUk8//zzRT6PMWPGFNl7oXp+uur79GFtbS0mT54sMjMz9ZalK9/y5cvF7NmzhZWVlc5rJVUWPW5jx47VKq9Tp04iMjJS53tdddjZ2Ynvv/++yLJTU1PFa6+9ZtDvQEmSxMiRI0VSUlKRZZrid4i+12r58uXCxcVFb1nBwcHi7t27pW7rwgYNGqRV/tatW4vMY+jvoQMHDuis/9WrV0WfPn10XouKijLJ8zJEQkKCzvfEO++8ozP922+/rfM9mZCQUC71feGFF3S2mb7fvWXV4yaEEF999ZXB7UaWjXPciIyUl5eHIUOGFLnKVGFZWVmYO3cuLl++jI0bN8LKSrPje+XKlZg3b15ZVLXM6eoNqF27Ntq2bYvw8HB88sknGtdWr16Njz/+WKsNCnv8+DE6deqEq1evGlU3U5VTnnr37q1zLoexdu3ahZ49e+LYsWPq/1IXlpGRgV69euGvv/4qVfmjRo3CzJkz8ejRI/W5O3fuYMeOHejbt69W+r179+LJkyca52rUqIF+/fqV6v769OzZs9j/Mq9atQr5+flYvXq1zutvvPGGzv/665KXl4fFixfj4sWLiIiIgKOjo0H5Fi5cWCave1m7e/cuunXrpvG6Py07OxtvvPEGHB0d8corr2hdT0pKQseOHXHp0iWD7imEwC+//IJTp07hyJEjqFmzplaasnzvL1u2DIcPHy4yzT///IOxY8di3759Rt0rNzcXERERWuefffZZo8otzpgxYwz6efzxxx/x448/muSe/fr1w+zZszXOnT59Gvn5+VppW7RoobOMli1bap3Ly8vDmTNn8Pzzz5uknkXRtYqljY2NwXNGr169itatW+Off/5Bamoq3Nzc4OPjg9atW2PQoEHo06dPkX87C9P1M7Jjxw7Mnz/foPxkQcwdORJZmpL2uE2bNk3vf9sDAgJEgwYNhIODg840s2bN0iqvZcuWOtP6+PiIJk2aiPr16wsPDw+t64W1aNFCtGjRQgQGBuosS3W98PHf//7XqHbLzc0V3t7eWveaPn26EEKIyMhInXXZvXu33jLz8vLEc889p/c/2Q4ODqJhw4YiNDRUuLq66v1vuanKKe8et8JHYGCgRv1Unu5xc3NzEyEhIeKZZ54RYWFhokaNGnrL/OKLL3TWe/jw4Xrz2NjYiPr164uwsDDh6emp93nNmjVLK2/v3r113m/06NFaad99912daQ1RXHu6u7uLsLAwne8j1bF582atcr/99ludaSVJErVq1RKhoaF6e93HjBmjs67Fve4eHh4iLCxM+Pj4CMC0PW6GHPr+66+rx63w4evrKxo3bqz3d5+zs7OIjo7WKrdHjx562zg4OFg0aNBAZ68LANGmTRuRn5+vUZ6p3vvFvVZWVlaiQYMGws/PT2+aU6dOlfi1K+zcuXNaZfr7+xebz9get8KHn5+faNy4sfq9U7jHTd/fztIcuur3xRdf6Ex75MgRnc/70KFDOtN/+eWXhjZ5qeXn54ugoCCte7ds2VJvnqd73Io7QkNDxZkzZwyqT0ZGhlZvsyRJ5db7SKbDwI3oKSUJ3K5fv6416ReAGD9+vMZwCKVSKaZOnarzQ0NsbKxGmU8PTXNxcREnTpzQuvf9+/fFli1bxOTJk0WNGjV0PpfyXJzkzz//1Hmvs2fPqtOEhoZqXX/xxRf1lqmv/gqFQixbtkxjCFpeXp44fvy4eOmll8S8efPKpBxzBG6dO3cWN27c0Kjfnj171N//888/YuzYsWLr1q3i4cOHOutx+/Zt0bVrV62ydU1Q1/fhzd7eXsyfP1+kpKRopL948aJ4/fXXxYQJEzTOP3jwQNjb22uUYWVlpfVhPSMjQ+MDs+q4du2azudiiKLa84svvlAPhczNzRXffPONkCRJK12zZs00ynzy5IlQKBRa6fr27Stu3bqlTpeZmSk+++yzYt8LKvrq6eHhIbZs2aIxvPTmzZsaPwuGKs/Azc3NTezcuVOdLjk5WWdgDkBMnTpVo0x9C0+0aNFC/PPPP+p0d+7cEe3bt9eZdt26dRplmuq9L4T+16pp06Ya9fvkk090ptNVZknoei49e/YsNp8pArcmTZpo/fwePXpUKJVK9fdlHbjNmDFDZ9qrV6/qfN5XrlzRmf69994rts2MtWzZMp33Xrlypd48JQ3cAAhHR0dx+PBhg+rUoEEDrfwVcdG1qo6BG9FTShK4vffee1rp2rVrp7fs5s2ba6X/9NNPNdI8Hbg1aNBA67/IT8vNzdV5vjwDt2HDhmndJyQkRCPNvHnzdP7h0Tc/Rdd/ym1sbMTJkyeLrMvTc4pMVU55B27169cXGRkZRdbRULr+Ww9APH78WCPdiBEjdKYrbr6Zrnlcuj7c//vf/9ZIs2nTphK9hwyhrz319XqNHz9eZ/rCwePixYu1rgcGBors7GydZQ4ePFgr/cSJE7XS6ftAtm/fPqPaoLDyDNyWLVumlTYnJ0eEhIRopa1Zs6ZGuiFDhmilcXBw0Dk/7NGjRzoD6e7du2ukM9V7Xwjdr5WVlZXOYFrX8w0PDy/ynsX58MMPtcocNWpUsfmMDdy8vLxEfHx8sfcp68Bt4sSJOtMW/sdJYTdv3tSZXtf70JSOHj2qc85jhw4d9P6tFkI7cPPz81P3tuv651Lh99HT/1DTpW3btga9X8mycVVJIiPomm9w+/ZttGzZUuehawWup+c9PPPMMxrf//333+jUqRM+//xz/Pbbb7h27ZrWqlTW1tZGPxdjJCYmYtu2bVrnR4wYUeT3gDyfauPGjVrnk5OTcerUKa3zQ4YMQevWrYusj729vcnLMYd3331X58pkuly4cAEffPABunfvjsDAQLi5ucHa2lq9Mlzz5s115nt6ldO9e/dqpXn22WcxePDgIu+vq62mTZumde7nn39GTk6O+vt169ZppdE198kU9JWra6VPABp7H+l6ryuVSrRp00bne/3YsWNa6Q2d49SuXTt07drVoLTGqFatGlq0aFHkYcg+UiqOjo46Nxm2sbHB6NGjtc4/fPgQUVFR6u/379+vlaZnz56oVauW1nkvLy8MHDhQ6/yRI0fUP1/l8d7v3bs3goODtc43aNBA61xiYqJBZeqja6XLatWqGVWmISZOnFjsXmEAMGfOHAi5Q8DooySrpwo9m3DrO1+Wdu3ahRdeeAGpqaka54ODg7Fly5Yi/1Z7eXlh8uTJ+OOPP5CUlIR79+4hMjIScXFxSExMxIcffqjz5/Lhw4dYvHhxsXXT9bPy9NxisnxcnITICDExMVrn7t+/r3MDb0PLePvtt7U+9B0+fFhjAry1tTUaNmyIjh07YsSIEejQoUMJa25a69at09oQFgBefPFFje+Dg4PRvHlznDt3TuP8ihUr8Nprr2mcu3fvns6J6CX9QGuqcsyhS5cuxaZJSUnB+PHjsXnz5lLdo/DS4mlpaTr/kJe2rZo2bYouXbrgwIED6nMPHz7E1q1bMXz4cCiVSuzYsUMjj6urK4YPH16q+xWnSZMmOs+HhYXpPH/37l31Y13v9YSEBCQkJBh8/zt37hiUzpDX3RT69u1r0u0FQkJC9AY8RbVxUFAQUlNTdQY2TZs21Xs/XdcyMzPx6NEj+Pr6lst7v1mzZjrPu7i4aJ3T9TuyJHTld3V1NapMQ5TXz2NxFAqFzvP6ltfX197u7u6mqpKGpUuXYvLkycjNzdU4HxwcjAMHDhQb/J46dUrvYiMKhQLz5s1DgwYNMGrUKK3rf/75J6ZPn15k+boWS8nIyCgyD1ke9rgRGeHp/XRK4+kPykOGDMGSJUuK/IOcl5eHy5cvY9GiRejYsSP69u2L9PR0o+tSWro+/DVt2lTnf52fDuYA4NixY1p7XulrW09PzxLVzVTllIax+/Xo6ml42pAhQ0odtAHyz5JKWbSVrl63JUuWAJD3pMrMzNS4NmLECDg7O5f6fkXR957Sd77w/lumeK9nZ2cbtKeXIa+7JSrqd1ZxbZycnGyyMlWvVXm89/38/HSeN8W+ak/TFRQrlUqT3+dplvLzqG81Rn29RvrOG7qqY0nMmjULr732mlbQ1rx5cxw5ckTvz0lhhqwQOXLkSPj6+mqd//vvv4vNq+s9ZuhKt2Q52ONGZAR3d/cSb9T6tMIfnFUmTpyIF198Eb/++iv279+PCxcu4ObNm3r/O7Z9+3a89957+P77742qS2lcvXoVp0+f1jp/8eJFjU2Pi7NixQr85z//UX+v77+iJenhMGU5RSk89K+wwj02pVHccK2DBw/qHNo4cOBAzJw5E/Xr11f/l/r27duoW7dukeWVRVv17dsXwcHBGoH5gQMHcP369XIdJgkAqampOv9rry+YKhwYmOq/9Lre708z9xDd0np6eFhhxbWxvt6UogJdfddUr1V5vPf1vVYl+d1nKF1D3Uz5XPQx9OexrLcDeHoagYq+nmx9v3/1lVMaOTk5eO2117By5Uqta7169cLGjRt19r4aIyAgQGuIuyH/WNIVyJbHPzDJtNjjRmSEgIAArXOvv/56icby6/uF6+bmhpdffhmrVq1CZGQk0tPT8fDhQ+zfvx9DhgzRSr9mzRqdw4LKmqmGWq1evVqj/v7+/jr/A6lrHkxRTFUOANjZ2ek8r+sD6+PHj0s0ZLY0dM278vX1xebNm9G6dWuND8OGDNNzdnbW+d/o0rSViiRJePPNN7XOf/zxx1r1b9y4cZnuSRUZGanzvL49w/z9/dWPdb3X+/btW+K5O2U1TMsSXL9+Xe/wtOLa2MXFBR4eHlrXL168qPd+uq45ODioh6SZ8r1vCYKCgrTOWdIcpbi4OJw9e9YkR+G5jyotW7bUOUfs7NmzOuuj67y1tbXefd9KSqlUonfv3jqDtokTJ+KPP/4wedAG6B62bUgApivI1/UzRZaNgRuREbp166Z1bvPmzUVuQFvY/v37tYYvpKWl6U1fo0YNdOnSBUuXLtW6lpSUpNX7p+8/paYaVpmXl4c1a9aYpKy7d+9qfKByc3PT+SF+y5YtxW4GW3j4nanKAfT/B//y5cta5xYuXGhQ74ox4uPjtc55enrq/HCzaNEig8rUtTHtyZMni91g/um2KmzcuHFabbdmzRqtYUVl2dsGyJsl66Lvnw9t27ZVP9b1Xo+IiMCNGzcMuvfp06eN7oG1dBkZGVi/fr3W+dzcXJ2/J7y9vTU+OOqae7Zr1y7cu3dP6/yTJ0/w22+/aZ1v3749bG1tAZj2vW8JdM3RvHLlihlqYh4eHh7o2bOn1vktW7ZojXrIzs7Gli1btNL26tVL5z8IOnfurF7ISXXoW7QIkOdOt2/fXuufT5Ik4bPPPsOSJUtKtGjYxx9/bNAm57/88otWbxsANGrUqMh8GRkZuHXrltZ5U/Y+Uvlg4EZkhHHjxmn9cn7w4AG6d++O3bt3a61qlZaWhiNHjuD9999H/fr10a1bN60J+QMGDECvXr2wZMkSXL9+XevDf1ZWFn744Qed9Xm6R0jXHygA+OOPPwx6fsXZs2ePzl6lRo0aFbtanZOTk1a+pz9AT5w4UStNbm4uevTogVWrVmnMIRNC4MyZMxg/fjy+/PLLMinHyckJgYGBWmV9++23OH/+vPr7TZs24dNPP9VKZ2q6hpdduXJF4z/AaWlpmDZtGjZt2mRQmbraCpDnnn3zzTda/1i4du0a3n77bbz11lt6y3R2dtZafOZpdnZ2eOmllwyqY2mtXLkSX331lTpgzMvLw7fffovly5drpW3WrJnGiorDhw/XmtyfmZmJHj16YNOmTVpBaGZmJk6fPo2PP/4YzZs3R+vWrXV+cKps3nrrLY3hu0qlEuPHj9cZ4D4933X8+PFaaTIzMzFw4ECNtrt79y4GDRqkc87O02WY6r1vCZo0aaL1e/Pu3bt48OCBmWpU/qZMmaJ1LiYmBpMnT1ZPJcjIyMC//vUvnaMMdOUvqcjISDz33HNavcj29vZYv3493nvvvRKXGRERgVatWqFz585YsWKFVnCWnJyM2bNn63yPAMDQoUOLLP/cuXNav6MaNGig9zMCWbAy2GKAqEIryT5uQgjx1ltv6d1fxcnJSQQHB4vGjRsLPz8/nXuxREVFaZT39J47dnZ2IigoSDRt2lQ0aNBAODs767xX3bp1tep27949vXULDAwULVq0UB9ZWVklbqvhw4drlevu7m5QWRMmTNDZXsnJyeo0eXl5ok2bNnqfg6OjowgNDRWNGjXS2NNp9uzZGvcyVTlCCPGvf/1LZxnW1taiUaNGwsfHp8T7E5V2v70//vijyL19wsLChKOjY5H10fVzret1VR22traiQYMGIiwsTFSrVq3I51XYnTt3dG5WrzqGDx9e7PM1VFEbcAPy5tZNmjQRnp6eetNs3rxZq9yvv/5ab3p7e3tRp04d0aRJE1G7dm1hbW1tUFvrKmv58uUmawsh9O/jVq1aNY3fAfqOd955R6tMffu4qQ4/Pz/RuHFj4eDgoPO6s7Oz1mbsQgjRvXt3neklSRIhISGiQYMGwsrKSmeaZ599VmPDciFM+94vyWulq3307YlXEv369dMq9/fffy8yj7H7uD39N8rcdO33B0C4urqKxo0bC1dXV53Xhw4dqrdMQ9tICCGCg4N1lu/l5WXQ++nMmTMG3b9mzZqicePGwtfXt8h93Bo2bKh3P0mVBQsWaOWbNm1aidqdLAMDN6KnlDRwy8nJEf379y/yQ0xRR3GBm6GHvo00dW26qeso6UbPiYmJwt7e3uA/dk/bu3evznr89NNPGukePXokQkNDS9QWuj50maqc69ev6/0wWvhwc3MTfn5+BrVPaQO3vLw8nZu66zr0/YNB1891enp6iX8ODXndw8PD9ebfs2dPsfkNpa89+/bta9BzGT16tN6y9QXuhhyWFrgZegwYMECrTF2BSWhoqAgKCjKozKVLl+qs65MnT0r8PgUg6tSpI+7fv6+zTFO990vyWpVV4LZq1Sqtct98880i81S2wO3JkyeiRYsWJXo9W7RoIZ48eaK3zJIEbk9vlG2K3wOl/bvv6+sr/vnnn2LbrFevXlp5jx07ZmiTkwXhUEkiI9nY2GDr1q34/PPPS7Snjr29PQYPHqw1VEHfAhj6ODg4YMGCBRg3bpzO6wsXLtS7Ypsx9O3dFh4eblD+zp0761wI4+nhkl5eXjh9+jT+9a9/qeeulIapygkJCcHSpUuLXO67bt26OHjwIOrVq1fq+xjCysoKW7duLXKTZCsrK8ydOxdTp041uFxHR0dERERg9uzZOoe0lpa+OgQEBOicQ2ZqmzZtwrBhw4pMM2bMGJ1DJ1UWLlyI5cuXl2hJcWtra7zwwguVfiGA6tWrIyIiQu9+eQBga2uL77//Xu98Rk9PT5w8eRLjxo0zaHl0SZIwfPhwnDlzBt7e3jrTmOq9bwmGDBmiNWR3w4YNZT6f1pJ4enpi3759GDVqVLGrd0qShFGjRmH//v0WvYJi+/btS7yQyZAhQ3DmzJli/848fvxYa/Xh+vXro02bNiWuJ1kAc0eORJampD1uhSmVSrFkyRIRHh4ugoODhbu7u7C2thbOzs7C399fdOnSRbz11lti69atIikpSWcZubm54vjx42L+/Pli5MiRomXLlqJGjRrC3t5eWFlZCRcXF1GnTh3Rq1cv8eWXX4q4uLhi6xUdHS2mTp0qwsLChIuLi85hFyXtcXv22We1yvD09Cx2yEZhr732ms621vcfxLi4OPHFF1+Ifv36icDAQOHm5iZsbW2Fj4+PaNasmRg3bpz45ZdfivzPqqnKiYyMFC+99JLw9/cXdnZ2wtPTU7Rr1058++236rY09L+4pe1xU0lNTRVffPGFaNWqlXBxcREODg4iKChIjBkzRhw/flwIob/Xpbif68TERPH999+LoUOHinr16gl3d3dhY2MjatSoIcLCwsSIESPEzz//LGJjYw2qa+vWrbXqMGfOHIOfqyGKa8/ff/9d9O/fX/j6+go7Ozvh4+MjBg0aJHbt2mXwPTIzM8Xq1avFmDFjRMOGDYWnp6ewsbERTk5OwtfXV7Rv315MmjRJ/PLLLyI+Pl5vObrqWVF73FQ9SllZWeKHH34Q7du3F15eXsLe3l4EBQWJCRMmiKtXrxpc71u3bonZs2eLLl26CD8/P+Hg4CDs7e2Ft7e36NChg5g5c2aJyhPCuPd+SV6rsupxE0KIt99+W6vs3bt3601f2XrcCjt79qx45513xDPPPCOqV68ubG1thZeXl3jmmWfEO++8o3NYoi7m7nETQoi0tDSxfft28d5774kePXqIOnXqCFdXV/VnCD8/P/H888+LWbNmievXrxvcRgsXLtSqw8KFCw3OT5ZFEuKp1ROIiIjKQH5+PkJCQjQWmrCyskJUVBRq165tsvusWLFCZw80/9yZzssvv6y1DHqnTp1w8OBB81SoCrl37x7q1aunMeJh1KhRJlvhlyqXNm3a4MSJE+rvq1evjujoaJOOpqDyw6GSRERU5nJzc/HRRx9prazYp08fkwZtRJVdrVq1MHnyZI1zGzZs0Lm/F1Vthw4d0gjaAOD9999n0FaBMXAjIqIy8eeff6Jly5Zo2rQpatSogTlz5milmTFjRvlXjKiCe//99zXmR+fm5uLzzz83Y43IEn3yySca39etWxeTJk0yU23IFBi4ERFRmXj8+DHOnj2LyMhIrf0KAXkfr/bt25uhZkQVm5eXF/7zn/9onFu2bJnOfTWpajp79ix2796tce7bb7+Fvb29mWpEpqB/WTQiIqIy8txzz2HJkiXmrgZRhTV58mStIZNEKi1atOC83kqIPW5ERFQuXFxc8Oyzz+Kbb77BoUOHtJY1JyIiIv24qiQREREREZGF41DJcpafn4+4uDi4uroWu3EkERERERFVXkIIpKSkwNfXF1ZWRQ+GZOBWzuLi4uDv72/uahARERERkYW4e/cuatWqVWQaBm7lzNXVFYD84nB+BxERERFR1aVUKuHv76+OEYrCwK2cqYZHurm5MXAjIiIiIiKDplBxVUkiIiIiIiILx8CNiIiIiIjIwjFwIyIiIiIisnAM3IiIiIiIiCwcAzciIiIiIiILx8CNiIiIiIjIwjFwIyIiIiIisnAM3IiIiIiIiCwcAzciIiIiIiILx8CNiIiIiIjIwjFwIyIiIiIisnAM3IiIiIiIiCwcAzciIiIiIiILZ2PuChAREREREemUlQUcOQLs2QOkpwN9+gBduwJ2dprprl0D1q4F9u0DvL2BBg3ko359ICgIcHICHB0Bm4ob/lTcmhMRERERkWXKyAAiI4GYGMDFBXB3BxQK+aurK+DgANjaApIkp8/LAx4/Bu7fl48bN+Rg7eBBOWBT+eEHuYz+/YFBg4CoKGDNGuDcOcPqZWMj39vFBYiLK7h/BSAJIYS5K1GVKJVKKBQKJCcnw83NzdzVISIiIqKqKD8fuHgROHQIyMwEPDwKDnd3OZDKygKys+Wv6elAQoLmkZ8v92SpDltb4Pp1OYj6+2/5elGsrOQgyt4eUCrle+ri7Q306CH3mP32G/DwoXYaGxugZ09gyBAgJUW+//Xr8tfYWO30zs5AampJW83kShIbsMeNiIiIiMjS5ecDT57IvVFxcXKw5ews9xy5uMiPc3LkYCQ1FUhLK+ipsrKSD0kC7t4FDhyQe7ISEsq2zjVqACEhcj2Sk4GkJPlQBWj5+fI1VT0lSc7j4wPUqgV06AC88ALQpElBz9jChcCxY8CWLcCOHUD16sCoUcDw4YCXl+565OfLwWdGhnxkZsoBaQXDHrdyxh43IiIiokokO1seDvjkSUFgoAoO8vIAIeTAQQg5+LC1lednqQ4h5DJUPVtZWUB8vBycqYI01fDBnBzT1t3FRQ6OatQAEhPlQC4xUQ6ybGzknjA7O/mroyPg6VlweHjIaVSBV3q6/JyDgoBmzeTDx0d7KKIQBUFUZmbBoVDI9ajAc9BKgz1uRERERESGEkLuiTp7Vg40fHzk4Xne3nLQkpgI3LoF3L4tfy38+O5dOX95qV4d8PWVhyampRX0rqWmykGhqvfNxUUOtiRJDhxVh0IBdOokL/DRooWcpzxJkjw80sGhfO9bCTBwIyIiIiLL9uQJcOGCPCcrJkYOTFxdATc3+XBykgMs1WFnJwdbDx8WHElJcj6FQs6jUMjlnjwpH7rmTQFy2YUXx9CXpkYNOVBSrV7o4ABYWxcMUZQkOcDLydHsYbOyKujVUn2tXl0OHn19Nb/WrKm9miJVGQzciIiIiMh8Ll+WVwXcuFEOpFRBlUIhBz83bgD37pV9PWxsgLAwuQfqwQP5yM4uCNq8vYE6dYC6deWj8OMaNSrU6oRUMTFwIyIiIqKiJScDly7JQwNVPUSqIzNTHi54717B1+xsOZ2qx8nWtqAXydtb/hofL++7FRmpeS+lUnegVrcu8MwzQL168vyolBQ5rVIpB1eq+WGqlRAVCrmHqmZN+Z7u7gWLZCiV8ldHR6B1a+DZZ+U5WY6OBfcTomD1RF9fubeOyIwYuBERERFVZhkZ8jBBVbCiVMrBlqpny91dPnJyNAOwO3eAq1cL9uIqK7a2QO/e8sqATZrIAZmqnqmp8mIXTZrI9S1PkgRUqyYfRBaAgRsRERGROeXlyUGKs3Pp5y8lJMj7cf31l9wrFh9fcKSlmaae/v5A/fpyD5pqjlZ2thx4+fvLy7f7+wN+fvJzycuTj/x8OV18fMHqiA8eyIHRoEHA0KHyKoVEVCQGbkRERETlLTYW2L1bPiIiCvbTsrEpWBXQy0sOgnx95a/e3nLQlJMD5ObKx7178n5cFy8WvbKhlVXBQh4KhbwARkqK3BOXmFiwp1XNmgUBWK1acqDWpIk898vDo6xbhYiKwMCNiIiIqq7MTCA6Wp5zpVBoX09PB/75Rz4ePSrY5yohQc4bGChvMBwcLB9OTvIQQ9Vx966cNiWl4IiLA65d012f3NyCTYpjY+WAzFANGwKdO8vzwGrWlBfMqFFDnlvm6lr04hkZGXJwZ29v+P2IqFwxcCMiIqKq5/x54Oef5cUxkpLkcwoFULu2fGRlAdevy4FXWZAkeVGMF16Qj+bN5UBQtSdXSoocKMbGyoFebKy8XL0kyb1yqkOhANq3lwM2b+/S16fwohxEZJEYuBEREZFlEEKe/5STIwdPunqI8vOBv/+Wl5B3dCxYWMPDQw5kCs/tio+Xy7K1LThSUuRg7fz5gjIdHOSgSbVy4qVLmvesVk3uVfP2ludieXjIX21t5U2Y//lHXrJetRGzu3tBAOjvL+dX7Tnm6ipff+457UUvHBzka0REOjBwIyIiovKXnCxvenz6tByIXb8uf01Jka8rFEDTpvIS7WFhckB37Bhw/HhBD5kx7OyAgQOBV14BunWThwqqVlKMiZGDsvr15cPQVQUzMuRAsbxXPySiKkESoqiZrGRqSqUSCoUCycnJcOMvdiIiqshSU4GzZ4FTp+Rep6c/UtjZyQttqA57e7k369gx+auujyCqvb9ycvTf18lJDury8uT5ZomJcjCXlycv6FF4bpe9vVyW6gCArl2B0aO5zDsRmV1JYgP2uBEREZFu6elyYHb3bsGCGYmJ8tyrc+eAK1fkoYulVaeOPGSwcWOgQQO5d6tuXXmI5LVrwIUL8nHpkhyQtWsHtG0rr3Joa6tZlhByXaytS18fIiILxh63csYeNyIiKheZmfKCFqojLk4OvNLSCo7MTHmulre3vAqht7fcK3X8uNwrduGCvMphUWrVAp59Vh7OaGtb0IsmhLzEfFqa3DOnWnSjXj05+Grb1rjFNIiIKgH2uBEREVV0mZnyhsr378tDA52c5L29HBzkRTeio4GoKPnrvXtyYJSeLh9pafJ8K1Pw9ZV7wzw8NBcCadRIXhXR19c09yEioiIxcCMiIipvWVlyD5gQ8jww1ZGQAOzaBezYAezfb3zw5egob9ysOjw95eBPddjbA0+eAA8eyEvNP3ggzxNr3VruEWvTRv/qjkREVK4YuBEREZlKUhJw5oy8UEd6utxrlpEhHw8fyr1j0dEFQVtxfH3l+V+ZmXIvmqpHzctL3vg5MBAICpKXnHdzk4MxVc+cQiH3jjHoIiKqFBi4ERFR1ZadLfc6PX6sfUiSPHeraVMgIKAgCFLtN/b33/ICHadPyysrXr9u+H3t7eV9x7KzC1Y7tLaWF+Do1Us+mjRh4EVERAAYuBERUVXy+DGwcSOwebPc8/X4ccG+YcVRKORAKitLDtiUSt3p6tSRe8lcXeWhig4O8tdq1eTeMVVPWfXqmoGgKnizszPySRIRUWXEwI2IiCq+rCx5M+f9++Vl5L295eAoIED+evMmsGYNsHOn7lUSrazkwMrLSz5Uj7OygMhI4OpVecPow4c189StKy/c0aKFPC+sVSs5X0lJEgM2IiIqEgM3IiKyTELI88IuXZKPy5flXi4Xl4LFNWxs5GGKR48avpBH8+bAqFHy/mGqQM3dXQ7E9MnOlnvZLl2Shzg2bCgva29vb5KnSkREVBwGbkREVL5US9f7+8vBl0peHnDxInDwoHycOCFv9GyoGjWArl3lwOzRIyAmRj6io+VgLzxcDthCQ0teZzs7eZhkkyYlz0tERGQCDNyIiKjs5eQA27YBS5YAEREF5z085ACuWjXg/Hl5VcbCJEnu2WrSRF4kxMurYENn1V5lDRvKAVtoKBfyICKiSouBGxERGSctTV4C/9gxeTijq6vmfLEbN4ClS+U9wgA5uHJ2loOvxET5UHF1BTp2BDp3Bjp0kIM1JyezPC0iIiJLwsCNiIiKl5goL3X/4EHBcf8+cPYscOGCPMyxODVrAq+8Arz2mrxgSHIycPeufMTHA40aAc88I89bIyIiIg3860hERNoyM+UFP/btk4c2nj0L5OfrT+/nB7RpI88ve3pfNEdH4KWXgAEDAFvbgjwKhXw0blz2z4eIiKiCY+BGRFTZ5efLy+GfOycf0dFyYKU6EhLkHjMrK3kDaCsree6Yal8xFX9/wNdXXmrf21vuQQsNBdq2la8RERFRmWHgRkRkyYSQl7v/55+CPcPc3Quu5+TI+5adPw9cuSJvJp2VVXA8eiQPZdS3WXRRfHyA7t3lo1s3uVeNiIiIzIKBGxGRJbpxA1i7FvjlF7m3rLCaNeUALiVFXgwkO7v48hwcgKZN5Y2i69cv2GS6WjXA01MewpiXJ/fO5eXJy9/Xrs1VGomIiCwEAzciInN79EjuLVMdJ0/KQxpVnJyAZs3kIY6xsfKm1A8fFlx3c5MX9WjaVA7C7O0LDjc3+XzDhprzy4iIiKhCYeBGRFTehABOnQLWrwe2bJFXVXyatTXQo4e8YfSAAfIG0oA85PHGDeDvv+VetGbNgKAgeV4aERERVVoM3IiITC0/H7h6FYiMlIcdSlLBcfEisHGj3HumIkly8BUaKi+J37ixHLTVqKFdtpsb0LKlfBAREVGVwcCNiMgY6elAXBxw547ci3bkiLyMflJS0fmcneWetBEjgK5d5e+JiIiI9GDgRkSkT26uvDDIjRvy3DLVERdX8FhfgObsLO9p5ugoD40UQj5fvToweDDQu7c8d42IiIjIAAzciKhqunlTXrUxLk5zMQ8rK+DWLXm1xr//NmzFRicnean8pk2B9u3lo2lTwIa/YomIiMg0+KmCiKqOlBRg0yZg+XJ5SKMhnJzkpff9/eXgzM9P3oS68GOFgsvmExERUZli4EZElU92NnD2rNyrFhUF3L4tfz1zRp6TBsg9az16AG3ayOlVG1bn5AABAQWLhAQEcMVGIiIiMjsGbkRUOTx8COzYAWzfDuzZI/eu6VK/PvDyy8BLL8k9ZkREREQVAAM3IrJcQsibU7u7A3Z2mtfS0uThjvv3A/v2yT1shVWvLveY1akjL7UfFCRvQv3MMxzWSERERBUOAzcisizJyXIgtmuXfKg2p/bykueT+foCqanAyZPysMbCWrQA+vSRj5YtOcSRiIiIKg0GbkRkHkLIwxuvXCk4IiOB06flTauf9vixfERGFpyrXRvo1k3eB61bN8DHp/zqT0RERFSOGLgRUfkQQl5e/6+/5OPQIXkpfl0aNABeeAHo2RPo0AHIyJDT3r8vf5UkoGNHefgjhz0SERFRFcDAjYjKRn6+vBeaKkg7dAiIj9dMI0lA3bryXLRGjeSjTRsgMFAznbOzPFSySZNyqz4RERGRJWHgRkSmEx8P/PmnfPz1F5CQoHndwUEOzDp1ko/WreV90oiIiIioSAzciKj0hACuX5cDtd9+A44dk8+pODsD7drJQVrHjkCrVoC9vdmqS0RERFRRMXAjopKJi5NXfdy3D4iIAGJjNa+3aAEMGCBvbt28OWBra556EhEREVUiDNyISCYEkJsrr+io+pqeDly6JO+RpjqiozXz2dvLvWkDBgD9+wP+/mapPhEREVFlxsCNqKp7/BhYvFg+7t8vPr0kyb1q3bvLS/C3awc4OpZ9PYmIiIiqMAZuRFXV9evA118DK1cCmZn60wUHy4Fa8+YFX93dy62aRERERMTAjajqePgQOHpUXkDk6FHgxImCa82bA++8I++dZmsL2NgA1tYFX4mIiIjIrBi4EVVW2dny3mnbtgE7dwI3b2pelySgXz85YOvQgRtZExEREVkwBm5ElUlqasHS/Dt3AkplwTVJkje4bteuYIn+2rXNVlUiIiIiMhwDN6KKLj0d2LED2LAB2L4dyMgouFajhtyr1q+fHKhxbhoRERFRhcTAjagiiosDdu2Se9V27gTS0gqu1asHDBkiL8//7LOAlZX56klEREREJsHAjagiyMmRFxVRBWqRkZrXAwKA8HD5aNaM89WIiIiIKhkGbkSWSAggJgbYu1cO1CIigJSUguuSBLRsCfTqBfTuDbRuzWCNiIiIqBJj4EZkbtnZcmB26pS8t9r168CNG5rDHwGgenV5uf6ePYEePeTviYiIiKhKYOBGZA45OcC+fcDGjcDWrUBSknYaGxu5J61nT7lnrXlzzlcjIiIiqqIYuBGVl9xc4K+/5NUff/0VePKk4Jq3txyghYYC9evLR5068mbYRERERFTlMXAjKktCAEeOAOvXA5s3A/HxBdeqVweGDpUXFGnfHrC2Nl89iYiIiMiiMXAjKitHjgD/93/A0aMF5zw95aX6w8PlfdVs+BYkIiIiouLxUyORqUVGAv/+t7wZNgA4OAAjRsjBWrduHP5IRERERCXGwI3IVC5fBj79FFi3Th4iaW0NvPoq8OGHgJ+fuWtHRERERBUYAzciYx07Bnz2GfDHHwXnhg8HPvoICAkxX72IiIiIqNJg4EZUWn/9JfemHT4sfy9JwODB8jDJ5s3NWzciIiIiqlQYuBGVVGIiMH068PPP8ve2tsCYMfK5+vXNWzciIiIiqpQYuBEZSgh5Sf833gAePpTPTZgAzJrFOWxEREREVKYYuBEVJylJXtr/xx8L5rE1aAD89JO8/xoRERERURlj4Eb0tPx8YPduYM8eeR7bhQtybxsgD4ucOVOex2Zvb9ZqEhEREVHVwcCNSCU3F9iwAfjkE+DqVc1rwcFA587AW28BjRqZpXpEREREVHUxcCPKygJWrZKX9L99Wz7n5ga8+KIcrHXsCPj6mrWKRERERFS1MXCjquvaNXllyFWrgEeP5HNeXsC0acCUKYBCYd76ERERERH9DwM3qlqysoA1a+SA7fjxgvN+fsC77wKvvQY4O5uvfkREREREOjBwo6rjyROgf3/g2DH5e2troG9f4JVXgF69ABu+HYiIiIjIMvGTKlUNUVFycHb9OuDuLq8MOWYM4O1t7poRERERERXLytwVMFZKSgrmzJmDsLAwuLi4QKFQoFWrVliwYAGys7ONLv/Bgwf48MMP0aJFC3h6esLR0REBAQHo2bMnPvvsM+Tk5JjgWVCZOncOaNNGDtr8/eU92WbMYNBGRERERBWGJIRqg6qKJyYmBp07d0Z0dDQAwMnJCXl5ecjKygIANGvWDPv27YOHh0epyt+wYQMmTJgApVIJAHBwcICdnZ36ewBITEyEu7u7wWUqlUooFAokJyfDzc2tVPWiEtizBxgyBEhNBZo0AXbskOezERERERGZWUligwrb45abm4t+/fohOjoaPj4+2Lt3L9LS0pCeno7169fD1dUV58+fx+jRo0tV/qZNmzBy5EgolUpMmDABV65cQUZGBpKTk6FUKnHo0CFMmzYNtra2Jn5mZBJCAIsXA336yEFb167AoUMM2oiIiIioQqqwPW4///wzXn31VQDAsWPH0KZNG43r69atw8iRIwEAERER6Natm8Fl379/H40aNUJiYiIWLFiAt99+22T1Zo9bOcjKAl5/HVi6VP5+1Chg2TLAzs689SIiIiIiKqRK9LitXLkSANClSxetoA0ARowYgaCgIADAqlWrSlT2d999h8TERDRr1gzTpk0zvrJUfu7fB7p0kYM2SQI+/xxYvZpBGxERERFVaEYFbvPnz0d8fLyp6mKw9PR0HD16FADQq1cvnWkkSULPnj0BAHv27ClR+apAb/To0ZAkyYiaUrk6eRJo2VLen83dXZ7PNmOGHMAREREREVVgRgVuM2bMgL+/PwYNGoQ//vgD+fn5pqpXka5du6a+V+PGjfWmU1178OABEhISDCo7KioKcXFxAIAWLVrg0qVLGDlyJHx8fGBvb49atWohPDxcHTiSBRACWLIE6NgRiIsDQkOBU6eA/wXuREREREQVndFDJXNycrBt2zYMHDgQfn5+eO+99/D333+bom56qQIrAPArYrGJwtcK5ynKjRs31I+PHj2Kli1bYt26dUhOToaDgwNiY2OxceNGdOjQAR999FGx5WVlZUGpVGocZELp6cC4ccDkyUB2NjBwIHDiBBAcbO6aERERERGZjFGB26VLlzB16lR4eXlBCIGHDx9i/vz5aNSoEdq2bYuff/4ZqamppqqrWkpKivqxk5OT3nSFrxXOU5TExET14w8//BC+vr7Yu3cvUlNTkZycjCtXrqBz584QQmDWrFn49ddfiyzv008/hUKhUB/+/v4G1YMMcOsW0LYtsHIlYGUlz2f79VfA1dXcNSMiIiIiMimjArdGjRrhq6++QmxsLH799Vf069cP1tbWEELg5MmTmDBhAnx8fDBu3DgcOnTIVHUuU4WHewohsGXLFnTv3h1WVnJThYaG4o8//oD3/zZvnjt3bpHlzZw5E8nJyerj7t27ZVf5qmTPHqBFC+DiRaBGDSAigvPZiIiIiKjSMsmqkjY2Nhg4cCB+//133Lt3D1988QUaNmwIIQTS0tKwatUqdOnSBSEhIfj0008NHraoj2uhHpX09HS96QpfczWwF6Zwum7duqF58+ZaaVxcXDBlyhQAQGRkJB4+fKi3PHt7e7i5uWkcZKTdu4F+/YDkZKBNG+DcOXklSSIiIiKiSsrk2wHUqFED7777Li5fvowTJ05gwoQJcHNzgxACN2/exAcffICAgAD07t0bW7ZsQU5OTonv4evrq34cGxurN13ha4XzFKXwvLiGDRvqTRcaGqp+HBMTY1DZZAL79snz2LKzgUGDgIMHuak2EREREVV6ZbqPW+vWrbFkyRLcv38fq1atgre3N4QQyMvLw+7duzF8+HD4+fnh//7v//DgwQODy23YsKF66OLly5f1plNd8/b2hqenp0Flh4aGwtrauth0hfct55YB5eTgQbmnLTNT/rp+PfdnIyIiIqIqocw34I6JicHnn3+OWbNm4eHDh+ogRwgBIQQeP36ML7/8EnXr1sXXX39tUJlOTk5o164dAGDXrl060wghsHv3bgBAjx49DK6vg4MDOnbsCEDedkCfq1evApCDtsDAQIPLp1I6fBjo2xfIyAB69wY2bWLQRkRERERVRpkEbpmZmVizZg26deuGunXrYt68eYiOjoYQAsHBwfj8888RFxeHPXv2IDw8HNbW1sjIyMC7776LNWvWGHSPsWPHAgAOHDiAkydPal3ftGkTbt++DQAYM2ZMieo/btw4AMC+fftw7tw5reupqalYtGgRAODZZ59F9erVS1Q+ldCZM3KwlpYG9OgBbNkC2Nubu1ZEREREROVHmNCxY8fEa6+9JhQKhbCyshJWVlZCkiTh5OQkxowZIw4dOqQz382bN8UzzzwjJEkSzZs3N+heOTk5IiwsTAAQfn5+IiIiQgghRF5enti4caNwc3MTAESvXr208s6ePVsAEABEVFSU1vW8vDzRunVrAUAEBgaKiIgIkZeXJ4QQ4urVq6JLly4CgLCyshL79u0zsHVkycnJAoBITk4uUb4qKzpaCG9vIQAhunYVIj3d3DUiIiIiIjKJksQGNsYGfqr5aytWrFBvXi3+N/+rWbNmePXVVzFq1KgiV1OsW7cuPv/8c/Ts2VNjA+yi2NjYYNu2bejSpQuio6PRvXt3ODk5IT8/H5mZmer7r127tsTPycrKCr///ju6deuGq1evqsu2tbVFcnIyAMDW1hYLFy5E165dS1w+GSg5WR4e+eABEBYGbN0KODqau1ZEREREROXOqMCtd+/e2Lt3L/Lz89XBmkKhwMiRI/Hqq6+iWbNmBpdVp04dAEUv7/+0wMBAREZGYv78+fj1118RFRUFW1tbNGrUCC+++CLeeOMN2JVyHpS3tzfOnTuHH374ARs2bMCNGzeQkZGBwMBAdO3aFdOmTUPjxo1LVTYZICcHGD4cuHwZ8PEBtm8HuJUCEREREVVRkhCFlkcsIdXKjgDQoUMHvPrqqxg2bBgcHBxKXFZcXBxGjhwJSZJw4MCB0lbJ4imVSigUCiQnJ3NPN32EACZPBv77X8DJCTh0SN5sm4iIiIioEilJbGBUj1uNGjUwduxYvPrqqwgODjamKPj6+uLgwYNGlUGVxFdfyUGbJAG//MKgjYiIiIiqPKMCt3v37sHGxuhpckQFzp4FZsyQHy9YAAwYYN76EBERERFZAKO2A2DQRiaVlwdMmgTk5wPh4cDUqeauERERERGRRTAq8srNzcWxY8cAAE2bNoVCoSgyfVJSEiIjIwHIc+JUm3ETAQCWLJH3bFMogG++kYdKEhERERGRcT1uv//+Ozp37owhQ4bA1ta22PR2dnYYPHgwunTpgu3btxtza6ps7t8H/v1v+fEnnwDe3uatDxERERGRBTEqcNu6dSsAYNiwYXBycio2vZOTE8LDwyGEwJYtW4y5NVU277wDKJVAy5bAxInmrg0RERERkUUxKnA7ffo0JEkq0SbUqrQnTpww5tZUmezdC6xbB1hZycMlra3NXSMiIiIiIotiVOB29+5dAEBQUJDBeQIDAzXyUhWXmQlMmSI/njKFS/8TEREREelgVOCmUpI9vFVpc3NzTXFrqui++AL45x/Axwf46CNz14aIiIiIyCIZFbhVr14dAPD3338bnEeV1svLy5hbU2UQHy8HboC86XYxq5ISEREREVVVRgVurVq1ghACq1atMjjPihUrIEkSmjdvbsytqTL47DMgLU1ekCQ83Ny1ISIiIiKyWEYFbkOHDgUA7Nu3DwsWLCg2/YIFC7B//34A8kqUVIXFxgKLFsmPP/6Ye7YRERERERXBqMAtPDwcTZs2hRACM2bMwNChQ3HkyBGN+Wu5ubk4fPgwhgwZghkzZkCSJDRu3BijR482uvJUgX38MZCVBXToAPToYe7aEBERERFZNEmUZGURHaKjo9GuXTvcv38f0v96TWxtbeHp6QkASEhIQE5ODgB5YRJfX18cOXJEvbpkVaNUKqFQKJCcnAw3NzdzV8c8oqKAkBAgNxf46y+gY0dz14iIiIiIqNyVJDYwelXJwMBAnD9/HgMHDgQgB2fZ2dl48OABHjx4gOzsbPVKkoMHD8a5c+eqbNBG/zN3rhy09ejBoI2IiIiIyABG97gVduPGDWzfvh3nz5/H48ePAcirRzZv3hx9+vRBcHCwqW5VYVX5Hre//wYaNQLy84GTJ4HWrc1dIyIiIiIisyhJbGBjyhuHhIQgJCTElEVSZTN7thy09e/PoI2IiIiIyEAm2YCbyCAXLwIbN8qPudk2EREREZHBGLhR+Vm6VP46bBjQpIl560JEREREVIGYdKgkIK8y+fjxY2RkZKC46XMduTBF1SEE8Mcf8uOXXjJvXYiIiIiIKhiTBG7Xr1/HJ598gm3btkGpVBqUR5Ikjf3eqJK7dAmIiQEcHIBu3cxdGyIiIiKiCsXowO23337DqFGjkJmZWWwPG1Vhqt62558HnJzMWxciIiIiogrGqMDt7t27GD16NDIyMuDn54fp06fDyckJEyZMgCRJiIiIQEJCAs6cOYPVq1cjLi4O7du3x5w5c2BtbW2q50AVwbZt8td+/cxbDyIiIiKiCsiofdymT5+OBQsWwNXVFdeuXYOvry+uXLmCsLAwSJKEvLw8ddqMjAy88sor2LBhA0aMGIG1a9ea5AlUNFVyH7cHDwAfH/lxXFzBYyIiIiKiKqwksYFRq0pGRERAkiT861//gq+vb5FpHR0dsWbNGjRr1gzr16/Hli1bjLk1VSTbt8tfW7Vi0EZEREREVApGBW7R0dEAgLZt26rPSZKkfvz04iNWVlZ48803IYTAsmXLjLk1VSQcJklEREREZBSjAre0tDQAgL+/v/qcU6GFJ5KTk7XyNGrUCABw8eJFY25NFUVGBrB3r/y4f3/z1oWIiIiIqIIyKnBTKBQAgMzMTPW5atWqqR/funVLK48qmHv8+LExt6aKYt8+OXjz9+em20REREREpWRU4Fa/fn0AwO3bt9XnXF1dERAQAADYs2ePVp69/+t9cXd3N+bWVFGotgHo1w8oNIyWiIiIiIgMZ1Tg1qZNGwDAiRMnNM737dsXQgh8+eWXOHDggPr8xo0b8e2330KSJLRr186YW1NFkJ9fELhxmCQRERERUakZtR3AgQMH0K1bN/j6+iImJka9N9udO3cQGhqKjIwMAICnpycyMzORnp4OIQSsra1x+PBhPPfcc6Z5FhVIldoO4MwZeSVJFxfg8WPA3t7cNSIiIiIishjlth1A586dMXv2bIwbNw6xsbHq87Vr18amTZugUCgghMCTJ0+QlpYGIQTs7e3x008/VcmgrcpR9bb16MGgjYiIiIjICEb1uBXnyZMn2Lx5M65cuYLc3FwEBwdj+PDh8PPzK6tbWrwq1ePWrBlw4QKwYgUwdqy5a0NEREREZFFKEhuUaeBG2qpM4HbvnrySpCQBDx8C1aubu0ZERERERBalJLGBjTE3Gj9+PACgV69eGDZsmDFFUWWjWlG0dWsGbURERERERjIqcFu5ciUAIDw83CSVoUpEFbj16GHeehARERERVQJGLU5S/X89KTVr1jRJZaiSyM+XN94GgOefN29diIiIiIgqAaMCt9DQUABATEyMSSpDlcSFC/Ly/y4uAFcPJSIiIiIymlGB2+jRoyGEUA+ZJAIA7N0rf+3SBbC1NW9diIiIiIgqAaMCt3HjxqFbt274/fffMWfOHHCBSgJQELhxmCQRERERkUkYtR3AoUOHkJGRgffeew+XLl1CSEgIwsPD0aRJE3h4eMDa2rrI/B07diztrSusSr8dQHo64OkJZGUB164BDRqYu0ZERERERBap3PZxs7KygiRJpcorSRJyc3NLe+sKq9IHbrt3Az17ynu4xcTI+7gREREREZGWctvHDQCHR5KmwsMkGbQREREREZmEUYHbgQMHTFUPqiw4v42IiIiIyOSMCtw6depkqnpQZfDwIRAZKT/u1s28dSEiIiIiqkSMWlWSSENEhPy1eXPgf5uzExERERGR8Ri4kens2SN/5TBJIiIiIiKTYuBGpiEE57cREREREZURo+a4de3atdR5JUnCvn37jLk9WZKrV4H79wFHR6BdO3PXhoiIiIioUjEqcDt48CAkSSpyS4Cn93lTpS3t/m9koVS9bR07Ag4O5q0LEREREVElY1Tg1rFjx2IDsLS0NNy8eRNJSUmQJAkhISHw8fEx5rZkiThMkoiIiIiozBjd42aoHTt24M0330RCQgJ+/vlntONwusrlxAn5a5cu5q0HEREREVElVG6Lk/Tu3RtHjhyBjY0NBg0ahNjY2PK6NZW1x4+BhAT5cYMG5q0LEREREVElVK6rSnp7e2PatGl4/Pgxvvjii/K8NZWlGzfkr7VrA05O5q0LEREREVElVO7bAbRv3x4AsH379vK+NZWV69flryEh5q0HEREREVElVe6Bm52dHQAgLi6uvG9NZUUVuNWvb956EBERERFVUuUeuB05cgQA4MQhdZWHaqgke9yIiIiIiMpEuQZux48fx7x58yBJElq3bl2et6ayxB43IiIiIqIyZdR2APPmzSs2TX5+PhITE3HmzBmcPHkS+fn5kCQJ06ZNM+bWZCny8oCbN+XHDNyIiIiIiMqEUYHbnDlzit2AuzAhBGxsbPDFF1/g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",
      "text/plain": [
       "<Figure size 1000x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA24AAAJyCAYAAAC8MpMzAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjMsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvZiW1igAAAAlwSFlzAAAPYQAAD2EBqD+naQAAYDBJREFUeJzt3Xd8VFX+//H3TU9IMiSAdEJQUJoaEBQRAcNSFBTbgoCgKIrLYgP2u+gqcV3LCqwVcLGwIAjSXAHpbEAMgjSlrgUSSmjS0nvu74/szC8hmZBkkswd8no+HvPwZs65n3OGaxze3nvPNUzTNAUAAAAAsCwvd08AAAAAAFA6ghsAAAAAWBzBDQAAAAAsjuAGAAAAABZHcAMAAAAAiyO4AQAAAIDFEdwAAAAAwOIIbgAAAABgcT7unkBNk5+frxMnTigkJESGYbh7OgAAAADcxDRNpaSkqFGjRvLyKv2cGsGtmp04cUJNmzZ19zQAAAAAWMSxY8fUpEmTUvsQ3KpZSEiIpIKDExoa6ubZAAAAAHCX5ORkNW3a1JERSkNwq2b2yyNDQ0MJbgAAAADKdAsVi5MAAAAAgMUR3AAAAADA4ghuAAAAAGBxBDcAAAAAsDiCGwAAAABYHMENAAAAACyO4AYAAAAAFkdwAwAAAACLI7gBAAAAgMUR3AAAAADA4nzcPQEAAICaLj8/X7m5ucrPz3f3VACUkZeXl3x9fWUYRrWMR3ADAABwk6SkJCUnJys9PZ3QBnggX19fhYSEqG7duvL29q7SsQhuAAAA1cw0TZ0+fVoXLlxQUFCQ6tatq4CAAHl5eVXb/70HUHGmaSovL0+pqam6ePGiMjIy1LRp0yoNbwQ3AACAanbhwgVduHBBDRo0UFhYmLunA6CCgoODZbPZdPToUZ09e1b169evsrFYnAQAAKAamaapixcvKiQkhNAGXAECAwMVGhqqlJQUmaZZZeMQ3AAAAKpRbm6usrKyZLPZ3D0VAJUkJCREOTk5ysnJqbIxCG4AAADVKC8vT5Lk48MdK8CVwn5vW1UuMkRwAwAAcAMWIQGuHNXx+0xwAwAAAACLI7gBAAAAgMUR3AAAAADA4ghuAAAAAGBxBDcAAADgChQTEyPDMFgI5wpBcAMAAMAVbePGjY4AU/jl4+Oj8PBwRUZG6vbbb9dzzz2nJUuWKDs7+7I1mzdvXmLNkl49evSo+g9ZSXr27OmYd+/evd09nTL717/+VeTP/Oqrry7TfseOHZO3t3eRfRMSEqp2shVEcAMAAECNlJeXpwsXLighIUGbN2/WO++8owceeEBNmjTR3/72N+Xm5rp7itXqyJEj2rRpk+PnDRs26MSJE26cUcUdPnxYW7ZsuWy/efPmVemz1yoTT34EAABAjfHUU0/pD3/4g+Pn1NRUXbhwQXv27NGGDRu0fv16/fbbb3rppZe0fPlyrVixQvXq1XNar1GjRlqzZk2pY9aqVavS5l+VPvvsM5mmKX9/f+Xl5Sk3N1dz587Vn/70J3dPrVwCAgKUmZmpzz77TLfeemupfT/77LMi+1gZZ9wAAABQY1x11VVq166d43XLLbeoX79++r//+z+tXbtW+/btU1RUlCTp+++/17333lvqpZO+vr5F6pX0ioyMrK6P5xJ7iOnfv7/jMkn7e57k7rvvliQtXLiw1GO3a9cuHThwQJJ0zz33VMvcXEFwAwAAAP6nTZs2iouLc4S3uLg4TZs2zc2zqnpbt27Vzz//LEkaOnSohg0bJknat2+fdu3a5c6pldugQYPk5+en8+fP6+uvv3bazx5KO3XqpOuuu666pldhBDcAAACgkMDAQH322WeO1RinTJminJycSh/n3//+tx588EE1a9ZMAQEBql27tm666Sa98sorunDhwmX3P378uMaMGaMWLVooICBAjRo10t13363169eXey5z5syRJIWFhemuu+7SwIEDFRISUqStsCNHjsjLy0uGYejFF1+8bP358+c7Fv9YuXJlsfbc3Fy999576ty5s0JDQx1/Fm+//bays7OVkJDg2P9f//pXqWOFh4frrrvukuT8jGFubq7mz58vSXr44YcvO38rILgBAABAysuTNm6U5s8v+Gdenrtn5FZt27bV7373O0nSiRMntH379kqrfeHCBUVHR+vee+/V4sWLdezYMWVlZSkpKUk7d+5UTEyMrrvuOm3dutVpjc2bN6tt27aaPn264uPjlZWVpZMnT2r58uX63e9+p1deeaXM88nOztYXX3whSXrwwQfl5+enwMBA3XfffZIKQtelC7VERESoa9eujvbLmTdvniSpXr16xVarTE5OVrdu3fTMM89o+/btSklJcfxZPP/88+rWrZsuXrxY5s8j/f8w9vXXX+v8+fPF2teuXavTp0/Lx8dHgwcPLldtdyG4AQAA1HRLl0rNm0s9e0pDhhT8s3nzgvdrsF69ejm2N2/eXCk1s7Ky1KtXL/3nP/+Rt7e3Hn74Yc2fP19bt27V5s2b9dprr6lOnTo6c+aM7rzzTh05cqRYjaNHj6p///5KTk6Wl5eXRo8erfXr12v79u365JNP1LJlS8XExJR6mWBhK1ascIQb+yWShbfPnDmj1atXF9tv6NChkqT4+PhSV3A8d+6c1q5dK0n6/e9/Lx+fousjDh482BFSu3btqgULFmjHjh1atWqVhg4dqu+//16jR48u02exu+uuuxQeHq7s7GwtXLiwWLv9TFzfvn1LXXzGSlhVEgAAoCZbulR64AHJNIu+n5hY8P7ixdL/zrzUNB06dHBs2+//ulROTo727dvntIafn59atWrl+Pmvf/2rdu3apdq1a2v9+vXq2LFjkf633Xabhg4dqi5duujkyZN64YUXHGer7MaNG6fk5GRJ0ty5c/XQQw852m666SY9+OCD6tatm3bs2FGmz2m/FLJ58+a67bbbHO/fcccdatSokU6cOKE5c+aof//+RfZ78MEH9fTTTysnJ0eff/650xUcFy1a5LjU1B727L766iutWrVKknTfffdp0aJF8vL6/+eW+vbtq6ioKI0fP75Mn8XOz89PgwYN0owZM/TZZ58VCX4pKSn66quvJEnDhw8vV1134owbAACAVZmmlJZWda/kZOnpp4uHNvvYkvTMMwX9qnIeJY1vAXXq1HFsO7vn7MSJE2rfvr3TV+HLAlNTUx0Lnbz66qvFQptdRESEXnrpJUkFoSctLc3RdurUKX355ZeSClZ/LBza7EJCQjRz5swyfcZz58457jkbMmSI474+SfLy8tKQIUMkScuXLy92uWKdOnXUt29fSQUrODp77p09eLZo0UJdunQp0vbhhx9KKriv8MMPPywS2uyef/75IiG6rOyXS27ZskWHDx92vL948WJlZGTIZrNpwIAB5a7rLgQ3AAAAq0pPl4KDq+5lsxWcWXPGNKXjxwv6VeU80tOr78+0HIKDgx3bKSkpLtfbtGmTkpKSJEkPPPBAqX1vv/12SQVn9Hbu3Ol4PzY2Vnn/u//w0Ucfdbp/586d1bZt28vOaf78+Y6zYYUvk7Szv5eZmalFixYVa7efQfvtt9+0bt26Yu1Hjx5VXFycJDlCoF1ubq7jgd+lXbJoGEaFFhDp0qWLrrnmGkkFZybt7JdJPvjggwoICCh3XXchuAEAAAAlKBzWQkNDS+wTEREh0zSdvhISEhx9C1+62LBhQ8cqiSW92rVr5+h76tQpx/bevXsd2506dSp1/p07d77sZ5w9e7akgstCW7duXaz9hhtucMylpNUl7777bsfqk5de0ikVBEPzf2dUL71M8tChQ8rIyJAkp2cf7W666abLfZQS2QOfPbgdO3ZMGzdulORZl0lKBDcAAADrCgqSUlOr7lXCsuwlWrmyaucRFFS1f44VdPbsWcd2eHi4y/XOnDlTof3SC52RLLxC4lVXXVXqfvXr1y+1/eDBg44wWdLZNjt7+ImLi1N8fHyRtsDAQN17772SCh5vkH7J2VN7mOvQoUOxZ6UVvvz0cguEVHQBEfvn+uWXX7R161bNnTtXpmkWu5/PE7A4CQAAgFUZhlSrVtXV791batKk4HLJku4zM4yC9t69JW/vqpuHRe3evduxfe2117pcL6/QIxZ27dolX1/fMu3XpEmTEt8vfD9aRRQ+g/b888/r+eefL7W/aZqaM2eOJk2aVOT9oUOHas6cOUpLS9NXX33luO9u//79jjOEl55tqy4tWrRQ165dFRcXp88++0yxsbGSCgKdq39+1c1jz7ilp6dr1apV+tvf/qb77rtPERERjlPLMTExlTLG6dOnNW7cOF177bUKDAxUeHi4unXrpo8//thxyhcAAMBjeXtL775bsH3pX2LtP7/zTo0MbZKK3LNVGWdnCi92Uq9ePbVr165Mr9q1azv2CwsLc2yfPn261PFKa8/Pzy/x0sbLKemB1tHR0Y6ze4Vr2re9vLxKfFZa4c/y22+/lTru5dpLY78k8tNPP9XBgwclec5Dtwvz2DNu33//ve68884qq79z50716dNH586dk1Rwc2pKSoq+/fZbffvtt1q8eLGWLVsmPz+/KpsDAABAlbvvvoIl/595pmAhErsmTQpCWw19FMC+ffu0YcMGSVLTpk0rfI9VYVFRUY7tuLg4DRo0qNw12rdv79jevn27mjZt6rRvaQ8Nj42N1bFjxyRJY8eOdbqUv922bdv0zjvv6NChQ4qLi3M8fFuSvL29NXjwYL377rtau3atzp07p/DwcMeDuXv27KlGjRoVq3n11VcrICBAmZmZRRZgKUlZH21Qkt///vd6+umnlZmZKUm6+eabizyiwVN47Bk3qSClR0dHa8KECZo/f74aNGhQKXWTkpLUv39/nTt3Ttddd53jCe5paWn64IMP5OvrqzVr1ujZZ5+tlPEAAADc6r77pIQEKTZW+vzzgn/Gx9fY0JaRkaHhw4c7rrAaP358sYdGV0SvXr0U9L/7+d57770KXcHVs2dPef/vDKh9YZGSbN++vdTny9kvk/T29tZf/vIXDR48uNTXiy++6PgzKGmREvulkDk5OVq4cKG2bNniWJjF2WWSPj4+jtUzV69e7fSsmmmaJZ7pK6vatWtr4MCB8vf3l7+/v0aMGFHhWu7kscGtW7duOn/+vNavX6+33npLgwcPlr+/f6XUnjJlik6dOqXAwECtXLnS8X9Y/Pz8NGbMGL3yyiuSpJkzZzp9GCMAAIBH8faWevSQHnqo4J819PLIAwcO6LbbbnPc39a9e3c99dRTlVK7du3a+uMf/yip4Nlizz33nPLz8532P336tD7++OMi7zVs2FD33HOPJGnZsmVauHBhsf1SU1P15JNPOq2blpampUuXSir4O/XlFjmRpLp166p79+6SCp7ZlpWVVaS9U6dOatmypaSCSyQ///xzSVJAQIDuv/9+p3Xt88zIyNDo0aNL/PP4xz/+oV27dl12jqVZsGCBMjMzlZmZWWnHs7p5bHDzrsL/mNj/L8LgwYMVGRlZrH3s2LEKDg5WXl5eha4NBgAAgHucOXNG+/btc7y2bdum1atX66233lKfPn3Url07R0i45ZZbtHjx4jIvIlIWf/3rX3XzzTdLkt5991116NBB06ZNU1xcnH744QfFxsbqgw8+0MCBA9WsWTPHA6oLmzp1qmMJ/iFDhmjMmDGKjY3Vzp07NWvWLHXs2FG7d+92ennn0qVLlZqaKkmlhqpL2ftevHhRy5YtK9ZuP7O2ZcsWx9+R+/fv7/RRCpJ03333OR5SvnTpUt1+++1auHChdu3apTVr1ujhhx/W+PHjizzawNMWFak05hUkIiLClGROmjSpwjX++9//mpJMSebChQud9uvXr58pybzlllvKVT8pKcmUZCYlJVV4jgAAwHNlZGSYBw4cMDMyMtw9lRojNjbW8fe7srzq1atnvvbaa2ZOTo7Tmva/d0ZERJR7PsnJyeZ9991Xprn07NnT6WcKCQlxut/LL79sTpo0yfFzYb169TIlmYZhmImJiWWe96lTp0wvLy9Tktm/f/9i7b/88kuxeXz55ZeXrXvhwgWzc+fOTj9LVFSUuWPHDsfPCxYsKFZj1qxZjvbY2Ngyfya7wn9W8fHx5d6/or/X5ckGHnvGraoUvha48IMPL2VvO3DgQJXPCQAAAJXPy8tLNptNzZo1U7du3fTss89qyZIlOn78uF544YVKua+tJCEhIVqyZIk2b96sxx9/XNdee61CQkLk4+Oj8PBwderUSWPGjNHKlSuLrGxZWI8ePbR//3499dRTioiIkJ+fn+rXr6+77rpLq1evdtzac6nExET95z//kSR16dKlxEVDnKlfv75jUZKS7km75ppripwZCwsLK9NigrVr19a3336rt99+Wx07dlRwcLBCQkJ044036o033tCWLVuKXG1ns9nKPOcriWGaV8669s2bN9eRI0c0adKkCj8S4P3339fTTz8tqWCREmendt99913H4iQpKSkKDg4uU/3k5GTZbLZSawMAgCtXZmam4uPjFRkZqYCAAHdPB/AIc+fOdSzh/+uvv+rqq69284yKqujvdXmygcc+DqCqpKSkOLbtq/6UpHBbacEtKyuryM2bycnJlTBLAAAAoOawP1qgXr16atGihZtn4x5cKlnF3njjDdlsNsertGdtAAAAADVNYmKiMjIynLZ//PHHWrlypaSCh2nX1MVJCG6XsK/QI0np6elO+xVuK7zPpSZOnKikpCTHy/6gQwAAAADSunXrFBERoaefflpLly7Vzp07tX37di1YsED33nuvRo0aJangHruJEye6ebbuw6WSlyh8g2ZiYqLTa00TExMlSaGhoaXe32Z/0B8AAACAkv322296//339f7775fY3rBhQ3399deqU6dONc/MOjjjdonCK0mW9rR5e1ubNm2qfE4AAADAlap///6aMWOGBg4cqFatWiksLEw+Pj6qW7euunXrprfeeks//fSToqKi3D1Vt+KM2yVatWqlZs2a6ejRo1q9erUefPDBYn3S0tK0efNmSXI8MBAAAABA+dWtW1ejR4/W6NGj3T0VS+OM2yUMw9Dw4cMlSQsWLFBCQkKxPtOmTVNqaqq8vb0dT4gHAAAAgKri0cHtwoULOnv2rOOVn58vqWDhkMLvp6amFtkvJiZGhmHIMIwSg9n48ePVoEEDpaen66677tLOnTslSdnZ2ZoxY4Zeeukl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VFpamsufAwAAAABK41Jwi46Olmma+vrrr4u8P3r0aEkFge7666/XhAkT9Ic//EHt27fXzz//LEkaPny4K0MrNzdXAwYMUEJCgho2bKh169YpLS1N6enpWrBggUJCQrR7926nC6dczqJFizRkyBAlJyfriSee0P79+5WRkaGkpCQlJyfrm2++0XPPPSdfX1+XPgcAAAAAXI5hXrr0YzlcvHhRN954o0zT1H/+8x9dffXVjrbHH39cn376acEg/7ss0j5Unz599PXXX8vLq+K58ZNPPtHjjz8uSdqyZYu6dOlSpH3+/PkaMmSIJGn9+vWORVHK4uTJk2rbtq0uXLigqVOn6vnnn6/wPC+VnJwsm82mpKSkIvcDAgAAAKhZypMNXDrjVrt2bSUkJOjIkSNFQpskffzxx/roo4908803q1atWvL391f79u01efJkLV++3KXQJhU83FuSevbsWSy0SdLgwYMdq13OmTOnXLXfe+89XbhwQVFRUXruuedcmicAAAAAuMqnKos/9thjeuyxxyq9bnp6uuLi4iRJ/fr1K7GPYRjq27evZsyYobVr15arvj3oDRs2rNIWUQEAAACAinLttJebHDx4UPn5+ZKkdu3aOe1nbzt16pTjmXOXEx8frxMnTkiSOnbsqL1792rIkCFq2LCh/P391aRJEw0aNMgRHAEAAACgqnlkcLMHK0lq3Lix036F2wrvUxr74imSFBcXp5tuuknz589XUlKSAgIClJiYqIULF6pbt2569dVXKzB7AAAAACgfjwxuKSkpju2goCCn/Qq3Fd6nNIUfH/DSSy+pUaNGWrdunVJTU5WUlKT9+/erR48eMk1TL7/8spYuXVpqvaysLCUnJxd5AQAAAEB5eGRwq0r2SzClglUwlyxZol69ejkWU2nTpo2WL1+uBg0aSJJeeeWVUuu98cYbstlsjlfTpk2rbvIAAAAArkgeGdxCQkIc2+np6U77FW4rvE9Za0dHRzseMl5YcHCwxowZI0nas2ePTp8+7bTexIkTlZSU5HgdO3asTPMAAAAAADuPDG6NGjVybCcmJjrtV7it8D6lKXxfXOvWrZ32a9OmjWP7yJEjTvv5+/srNDS0yAsAAAAAysMjg1vr1q0dly7u27fPaT97W4MGDRQeHl6m2m3atJG3t/dl+xV+bjmPDAAAAABQlTwyuAUFBalr166S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+1+tXLlSy5YtKzWgAgA8k2GapunuSQAAUFVycnL0zDPP6MMPP9TlvvIiIyOLPHw6JiZGr7zyiqSCs3bR0dGKj48vcd/7779fCxYskI9Pyf9PdPbs2XryySedhipvb2+9+uqrmjhxotP5rVmzRg899FCRxw2U5NLP2aNHD23atEndu3fXxo0bne5X+PPy1wMAsBYulQQAXNF8fX01ffp0/fjjjxo7dqzat28vm80mb29v2Ww23XjjjXrssce0ePFiHTx40GmdyMhI7dy5Uy+88IJat26toKAg2Ww23X777Zo7d64WL17sNLRJ0ogRI/Tf//5XzzzzjFq3bq1atWopMDBQV199tUaNGqXdu3eXGtokqU+fPjp8+LBef/113XrrrapTp468vb0VGhqqDh066Nlnn9X3339f4T8rAIB1ccYNAAAnOAMFALAKzrgBAAAAgMUR3AAAAADA4ghuAAAAAGBxBDcAAAAAsDiCGwAAAABYHKtKAgAAAIDFccYNAAAAACyO4AYAAAAAFkdwAwAAAACLI7gBAAAAgMUR3AAAAADA4ghuAAAAAGBxBDcAAAAAsDiCGwAAAABYHMENAAAAACzu/wHykfei7DJ7vAAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 1000x700 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "r_d_fedavg_m = {}\n",
    "\n",
    "r_d_fedavg_m['test_loss'] = []\n",
    "r_d_fedavg_m['test_acc'] = []\n",
    "r_d_fedavg_m['cl_acc'] = []\n",
    "for i in range(len(learning_rates)):\n",
    "    r_d_fedavg_m['test_loss'].append(d_fedavg_m[i][0])\n",
    "    r_d_fedavg_m['test_acc'].append(d_fedavg_m[i][1])\n",
    "    r_d_fedavg_m['cl_acc'].append(d_fedavg_m[i][2])\n",
    "\n",
    "os.makedirs('graphs', exist_ok=True)\n",
    "\n",
    "avg_test_loss = np.mean([loss[-1] for loss in r_d_fedavg_m['test_loss']])\n",
    "avg_test_acc = np.mean([acc[-1] for acc in r_d_fedavg_m['test_acc']])\n",
    "avg_cl_acc = np.mean([cl_acc[-1] for cl_acc in r_d_fedavg_m['cl_acc']])\n",
    "std_test_acc = np.std([acc[-1] for acc in r_d_fedavg_m['test_acc']])\n",
    "\n",
    "print(f\"Average Test Loss (Last Epoch): {avg_test_loss:.4f}\")\n",
    "print(f\"Average Test Accuracy (Last Epoch): {avg_test_acc:.4f}\")\n",
    "print(f\"Average Cluster Accuracy (Last Epoch): {avg_cl_acc:.4f}\")\n",
    "print(f\"Average Standard Deviation (Last Epoch): {std_test_acc:.4f}\")\n",
    "\n",
    "for l in range(len(learning_rates)):\n",
    "\n",
    "    plt.figure(figsize=(10,5))\n",
    "    plt.plot(r_d_fedavg_m['test_loss'][l], label='DFedAvgM', color='red')\n",
    "    plt.xlabel('epoch', fontsize=20)\n",
    "    plt.ylabel('loss', fontsize=20)\n",
    "    plt.title(f'Test Loss per Epoch (lr={learning_rates[l]})', fontsize=22, fontweight='bold')\n",
    "    plt.tick_params(axis='both', which='major', labelsize=18)\n",
    "    plt.legend(fontsize=20)\n",
    "    plt.savefig(os.path.join('graphs', 'train_loss.png'))\n",
    "\n",
    "    plt.figure(figsize=(10,5))\n",
    "    plt.plot(r_d_fedavg_m['test_acc'][l], label='DFedAvgM', color='red')\n",
    "    plt.xlabel('epoch', fontsize=20)\n",
    "    plt.ylabel('test accuracy', fontsize=20)\n",
    "    plt.title(f'Test Accuracy per Epoch (lr={learning_rates[l]})', fontsize=22, fontweight='bold')\n",
    "    plt.tick_params(axis='both', which='major', labelsize=18)\n",
    "    plt.legend(fontsize=20)\n",
    "    plt.savefig(os.path.join('graphs', 'test_acc.png'))\n",
    "\n",
    "    plt.figure(figsize=(10,7))\n",
    "    plt.ylim([0, 1.1])\n",
    "    plt.plot(r_d_fedavg_m['cl_acc'][l][:31], label='DFedAvgM', color='red', marker='o')\n",
    "    plt.xlabel('epoch', fontsize=20)\n",
    "    plt.ylabel('cluster acc', fontsize=20)\n",
    "    plt.legend(fontsize=20)\n",
    "    plt.tick_params(axis='both', which='major', labelsize=18)\n",
    "    plt.savefig(os.path.join('graphs', 'cluster_acc.png'))"
   ]
  }
 ],
 "metadata": {
  "accelerator": "GPU",
  "colab": {
   "gpuType": "T4",
   "provenance": []
  },
  "kernelspec": {
   "display_name": "Python 3",
   "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.11.11"
  },
  "widgets": {
   "application/vnd.jupyter.widget-state+json": {
    "state": {
     "0a3c30b3d8404bf1bb9f5dc6cdabbe87": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {
       "_model_module": "@jupyter-widgets/base",
       "_model_module_version": "2.0.0",
       "_model_name": "LayoutModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "2.0.0",
       "_view_name": "LayoutView",
       "align_content": null,
       "align_items": null,
       "align_self": null,
       "border_bottom": null,
       "border_left": null,
       "border_right": null,
       "border_top": null,
       "bottom": null,
       "display": null,
       "flex": null,
       "flex_flow": null,
       "grid_area": null,
       "grid_auto_columns": null,
       "grid_auto_flow": null,
       "grid_auto_rows": null,
       "grid_column": null,
       "grid_gap": null,
       "grid_row": null,
       "grid_template_areas": null,
       "grid_template_columns": null,
       "grid_template_rows": null,
       "height": null,
       "justify_content": null,
       "justify_items": null,
       "left": null,
       "margin": null,
       "max_height": null,
       "max_width": null,
       "min_height": null,
       "min_width": null,
       "object_fit": null,
       "object_position": null,
       "order": null,
       "overflow": null,
       "padding": null,
       "right": null,
       "top": null,
       "visibility": null,
       "width": null
      }
     },
     "1a0b07184cfe426f99c99c0017acb51e": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLStyleModel",
      "state": {
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "2.0.0",
       "_model_name": "HTMLStyleModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "2.0.0",
       "_view_name": "StyleView",
       "background": null,
       "description_width": "",
       "font_size": null,
       "text_color": null
      }
     },
     "1f42fe2d8ae74beda955fbb202075795": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {
       "_model_module": "@jupyter-widgets/base",
       "_model_module_version": "2.0.0",
       "_model_name": "LayoutModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "2.0.0",
       "_view_name": "LayoutView",
       "align_content": null,
       "align_items": null,
       "align_self": null,
       "border_bottom": null,
       "border_left": null,
       "border_right": null,
       "border_top": null,
       "bottom": null,
       "display": null,
       "flex": null,
       "flex_flow": null,
       "grid_area": null,
       "grid_auto_columns": null,
       "grid_auto_flow": null,
       "grid_auto_rows": null,
       "grid_column": null,
       "grid_gap": null,
       "grid_row": null,
       "grid_template_areas": null,
       "grid_template_columns": null,
       "grid_template_rows": null,
       "height": null,
       "justify_content": null,
       "justify_items": null,
       "left": null,
       "margin": null,
       "max_height": null,
       "max_width": null,
       "min_height": null,
       "min_width": null,
       "object_fit": null,
       "object_position": null,
       "order": null,
       "overflow": null,
       "padding": null,
       "right": null,
       "top": null,
       "visibility": null,
       "width": null
      }
     },
     "2399aea95518487eb735b60b0e73b663": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLModel",
      "state": {
       "_dom_classes": [],
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "2.0.0",
       "_model_name": "HTMLModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/controls",
       "_view_module_version": "2.0.0",
       "_view_name": "HTMLView",
       "description": "",
       "description_allow_html": false,
       "layout": "IPY_MODEL_4256ef12093e4a24bf1c79a48dfbb9e6",
       "placeholder": "​",
       "style": "IPY_MODEL_1a0b07184cfe426f99c99c0017acb51e",
       "tabbable": null,
       "tooltip": null,
       "value": " 3/3 [4:42:41&lt;00:00, 2065.89s/tasks]"
      }
     },
     "2c0f94a47f3b436fb5c7396ebca0c715": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "FloatProgressModel",
      "state": {
       "_dom_classes": [],
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "2.0.0",
       "_model_name": "FloatProgressModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/controls",
       "_view_module_version": "2.0.0",
       "_view_name": "ProgressView",
       "bar_style": "success",
       "description": "",
       "description_allow_html": false,
       "layout": "IPY_MODEL_1f42fe2d8ae74beda955fbb202075795",
       "max": 3,
       "min": 0,
       "orientation": "horizontal",
       "style": "IPY_MODEL_fcac53cc894248edacd37bb9e727a6f3",
       "tabbable": null,
       "tooltip": null,
       "value": 3
      }
     },
     "337e384cd1e04f21b2bdaf2671114662": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {
       "_model_module": "@jupyter-widgets/base",
       "_model_module_version": "2.0.0",
       "_model_name": "LayoutModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "2.0.0",
       "_view_name": "LayoutView",
       "align_content": null,
       "align_items": null,
       "align_self": null,
       "border_bottom": null,
       "border_left": null,
       "border_right": null,
       "border_top": null,
       "bottom": null,
       "display": null,
       "flex": null,
       "flex_flow": null,
       "grid_area": null,
       "grid_auto_columns": null,
       "grid_auto_flow": null,
       "grid_auto_rows": null,
       "grid_column": null,
       "grid_gap": null,
       "grid_row": null,
       "grid_template_areas": null,
       "grid_template_columns": null,
       "grid_template_rows": null,
       "height": null,
       "justify_content": null,
       "justify_items": null,
       "left": null,
       "margin": null,
       "max_height": null,
       "max_width": null,
       "min_height": null,
       "min_width": null,
       "object_fit": null,
       "object_position": null,
       "order": null,
       "overflow": null,
       "padding": null,
       "right": null,
       "top": null,
       "visibility": null,
       "width": null
      }
     },
     "4256ef12093e4a24bf1c79a48dfbb9e6": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {
       "_model_module": "@jupyter-widgets/base",
       "_model_module_version": "2.0.0",
       "_model_name": "LayoutModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "2.0.0",
       "_view_name": "LayoutView",
       "align_content": null,
       "align_items": null,
       "align_self": null,
       "border_bottom": null,
       "border_left": null,
       "border_right": null,
       "border_top": null,
       "bottom": null,
       "display": null,
       "flex": null,
       "flex_flow": null,
       "grid_area": null,
       "grid_auto_columns": null,
       "grid_auto_flow": null,
       "grid_auto_rows": null,
       "grid_column": null,
       "grid_gap": null,
       "grid_row": null,
       "grid_template_areas": null,
       "grid_template_columns": null,
       "grid_template_rows": null,
       "height": null,
       "justify_content": null,
       "justify_items": null,
       "left": null,
       "margin": null,
       "max_height": null,
       "max_width": null,
       "min_height": null,
       "min_width": null,
       "object_fit": null,
       "object_position": null,
       "order": null,
       "overflow": null,
       "padding": null,
       "right": null,
       "top": null,
       "visibility": null,
       "width": null
      }
     },
     "449d46dc356a40d6ad3bd0c8fd03e4ef": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HBoxModel",
      "state": {
       "_dom_classes": [],
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "2.0.0",
       "_model_name": "HBoxModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/controls",
       "_view_module_version": "2.0.0",
       "_view_name": "HBoxView",
       "box_style": "",
       "children": [
        "IPY_MODEL_f95aa764f6004f378bed561ca11e4d55",
        "IPY_MODEL_7c403a12612f4870a5fea409cc10061a",
        "IPY_MODEL_d414853e3519414e998086cb00a4bee3"
       ],
       "layout": "IPY_MODEL_6a531147c8b34e6ab1e2aaf7f0650be5",
       "tabbable": null,
       "tooltip": null
      }
     },
     "51e5577e0adb4caebccfb7a5d15ed679": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLStyleModel",
      "state": {
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "2.0.0",
       "_model_name": "HTMLStyleModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "2.0.0",
       "_view_name": "StyleView",
       "background": null,
       "description_width": "",
       "font_size": null,
       "text_color": null
      }
     },
     "6a531147c8b34e6ab1e2aaf7f0650be5": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {
       "_model_module": "@jupyter-widgets/base",
       "_model_module_version": "2.0.0",
       "_model_name": "LayoutModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "2.0.0",
       "_view_name": "LayoutView",
       "align_content": null,
       "align_items": null,
       "align_self": null,
       "border_bottom": null,
       "border_left": null,
       "border_right": null,
       "border_top": null,
       "bottom": null,
       "display": null,
       "flex": null,
       "flex_flow": null,
       "grid_area": null,
       "grid_auto_columns": null,
       "grid_auto_flow": null,
       "grid_auto_rows": null,
       "grid_column": null,
       "grid_gap": null,
       "grid_row": null,
       "grid_template_areas": null,
       "grid_template_columns": null,
       "grid_template_rows": null,
       "height": null,
       "justify_content": null,
       "justify_items": null,
       "left": null,
       "margin": null,
       "max_height": null,
       "max_width": null,
       "min_height": null,
       "min_width": null,
       "object_fit": null,
       "object_position": null,
       "order": null,
       "overflow": null,
       "padding": null,
       "right": null,
       "top": null,
       "visibility": null,
       "width": null
      }
     },
     "7c403a12612f4870a5fea409cc10061a": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "FloatProgressModel",
      "state": {
       "_dom_classes": [],
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "2.0.0",
       "_model_name": "FloatProgressModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/controls",
       "_view_module_version": "2.0.0",
       "_view_name": "ProgressView",
       "bar_style": "success",
       "description": "",
       "description_allow_html": false,
       "layout": "IPY_MODEL_7ef1404e2d4e4840b8612724952752fb",
       "max": 3,
       "min": 0,
       "orientation": "horizontal",
       "style": "IPY_MODEL_cf97ab3bed9b4c7f8c85e75977fdfb2d",
       "tabbable": null,
       "tooltip": null,
       "value": 3
      }
     },
     "7ef1404e2d4e4840b8612724952752fb": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {
       "_model_module": "@jupyter-widgets/base",
       "_model_module_version": "2.0.0",
       "_model_name": "LayoutModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "2.0.0",
       "_view_name": "LayoutView",
       "align_content": null,
       "align_items": null,
       "align_self": null,
       "border_bottom": null,
       "border_left": null,
       "border_right": null,
       "border_top": null,
       "bottom": null,
       "display": null,
       "flex": null,
       "flex_flow": null,
       "grid_area": null,
       "grid_auto_columns": null,
       "grid_auto_flow": null,
       "grid_auto_rows": null,
       "grid_column": null,
       "grid_gap": null,
       "grid_row": null,
       "grid_template_areas": null,
       "grid_template_columns": null,
       "grid_template_rows": null,
       "height": null,
       "justify_content": null,
       "justify_items": null,
       "left": null,
       "margin": null,
       "max_height": null,
       "max_width": null,
       "min_height": null,
       "min_width": null,
       "object_fit": null,
       "object_position": null,
       "order": null,
       "overflow": null,
       "padding": null,
       "right": null,
       "top": null,
       "visibility": null,
       "width": null
      }
     },
     "81911ddd6bf3483aa58b720cf8ac5608": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HBoxModel",
      "state": {
       "_dom_classes": [],
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "2.0.0",
       "_model_name": "HBoxModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/controls",
       "_view_module_version": "2.0.0",
       "_view_name": "HBoxView",
       "box_style": "",
       "children": [
        "IPY_MODEL_f0fe7929373b42f9bb4bdb6fe8559604",
        "IPY_MODEL_2c0f94a47f3b436fb5c7396ebca0c715",
        "IPY_MODEL_2399aea95518487eb735b60b0e73b663"
       ],
       "layout": "IPY_MODEL_cd90a682b5ca4cbabbd99dedf018cca9",
       "tabbable": null,
       "tooltip": null
      }
     },
     "cd90a682b5ca4cbabbd99dedf018cca9": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {
       "_model_module": "@jupyter-widgets/base",
       "_model_module_version": "2.0.0",
       "_model_name": "LayoutModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "2.0.0",
       "_view_name": "LayoutView",
       "align_content": null,
       "align_items": null,
       "align_self": null,
       "border_bottom": null,
       "border_left": null,
       "border_right": null,
       "border_top": null,
       "bottom": null,
       "display": null,
       "flex": null,
       "flex_flow": null,
       "grid_area": null,
       "grid_auto_columns": null,
       "grid_auto_flow": null,
       "grid_auto_rows": null,
       "grid_column": null,
       "grid_gap": null,
       "grid_row": null,
       "grid_template_areas": null,
       "grid_template_columns": null,
       "grid_template_rows": null,
       "height": null,
       "justify_content": null,
       "justify_items": null,
       "left": null,
       "margin": null,
       "max_height": null,
       "max_width": null,
       "min_height": null,
       "min_width": null,
       "object_fit": null,
       "object_position": null,
       "order": null,
       "overflow": null,
       "padding": null,
       "right": null,
       "top": null,
       "visibility": null,
       "width": null
      }
     },
     "cf97ab3bed9b4c7f8c85e75977fdfb2d": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "ProgressStyleModel",
      "state": {
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "2.0.0",
       "_model_name": "ProgressStyleModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "2.0.0",
       "_view_name": "StyleView",
       "bar_color": null,
       "description_width": ""
      }
     },
     "d414853e3519414e998086cb00a4bee3": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLModel",
      "state": {
       "_dom_classes": [],
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "2.0.0",
       "_model_name": "HTMLModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/controls",
       "_view_module_version": "2.0.0",
       "_view_name": "HTMLView",
       "description": "",
       "description_allow_html": false,
       "layout": "IPY_MODEL_337e384cd1e04f21b2bdaf2671114662",
       "placeholder": "​",
       "style": "IPY_MODEL_51e5577e0adb4caebccfb7a5d15ed679",
       "tabbable": null,
       "tooltip": null,
       "value": " 3/3 [00:05&lt;00:00,  5.48s/engine]"
      }
     },
     "f09390fd4e844b878333ab7232c8ad25": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {
       "_model_module": "@jupyter-widgets/base",
       "_model_module_version": "2.0.0",
       "_model_name": "LayoutModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "2.0.0",
       "_view_name": "LayoutView",
       "align_content": null,
       "align_items": null,
       "align_self": null,
       "border_bottom": null,
       "border_left": null,
       "border_right": null,
       "border_top": null,
       "bottom": null,
       "display": null,
       "flex": null,
       "flex_flow": null,
       "grid_area": null,
       "grid_auto_columns": null,
       "grid_auto_flow": null,
       "grid_auto_rows": null,
       "grid_column": null,
       "grid_gap": null,
       "grid_row": null,
       "grid_template_areas": null,
       "grid_template_columns": null,
       "grid_template_rows": null,
       "height": null,
       "justify_content": null,
       "justify_items": null,
       "left": null,
       "margin": null,
       "max_height": null,
       "max_width": null,
       "min_height": null,
       "min_width": null,
       "object_fit": null,
       "object_position": null,
       "order": null,
       "overflow": null,
       "padding": null,
       "right": null,
       "top": null,
       "visibility": null,
       "width": null
      }
     },
     "f0fe7929373b42f9bb4bdb6fe8559604": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLModel",
      "state": {
       "_dom_classes": [],
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "2.0.0",
       "_model_name": "HTMLModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/controls",
       "_view_module_version": "2.0.0",
       "_view_name": "HTMLView",
       "description": "",
       "description_allow_html": false,
       "layout": "IPY_MODEL_0a3c30b3d8404bf1bb9f5dc6cdabbe87",
       "placeholder": "​",
       "style": "IPY_MODEL_fa03744c1bc045a981f6d06895cd71ff",
       "tabbable": null,
       "tooltip": null,
       "value": "unknown: 100%"
      }
     },
     "f39d3a65294343b784594b2883a36c8f": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLStyleModel",
      "state": {
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "2.0.0",
       "_model_name": "HTMLStyleModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "2.0.0",
       "_view_name": "StyleView",
       "background": null,
       "description_width": "",
       "font_size": null,
       "text_color": null
      }
     },
     "f95aa764f6004f378bed561ca11e4d55": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLModel",
      "state": {
       "_dom_classes": [],
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "2.0.0",
       "_model_name": "HTMLModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/controls",
       "_view_module_version": "2.0.0",
       "_view_name": "HTMLView",
       "description": "",
       "description_allow_html": false,
       "layout": "IPY_MODEL_f09390fd4e844b878333ab7232c8ad25",
       "placeholder": "​",
       "style": "IPY_MODEL_f39d3a65294343b784594b2883a36c8f",
       "tabbable": null,
       "tooltip": null,
       "value": "100%"
      }
     },
     "fa03744c1bc045a981f6d06895cd71ff": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLStyleModel",
      "state": {
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "2.0.0",
       "_model_name": "HTMLStyleModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "2.0.0",
       "_view_name": "StyleView",
       "background": null,
       "description_width": "",
       "font_size": null,
       "text_color": null
      }
     },
     "fcac53cc894248edacd37bb9e727a6f3": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "ProgressStyleModel",
      "state": {
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "2.0.0",
       "_model_name": "ProgressStyleModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "2.0.0",
       "_view_name": "StyleView",
       "bar_color": null,
       "description_width": ""
      }
     }
    },
    "version_major": 2,
    "version_minor": 0
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
