{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-08-05T18:17:08.457037Z",
     "iopub.status.busy": "2025-08-05T18:17:08.456595Z",
     "iopub.status.idle": "2025-08-05T18:17:14.119634Z",
     "shell.execute_reply": "2025-08-05T18:17:14.118279Z"
    },
    "id": "OHJWesKs-tqd"
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-08-05 20:17:11.758858: 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:1754417831.780141  926711 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:1754417831.786217  926711 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:1754417831.802409  926711 computation_placer.cc:177] computation placer already registered. Please check linkage and avoid linking the same target more than once.\n",
      "W0000 00:00:1754417831.802426  926711 computation_placer.cc:177] computation placer already registered. Please check linkage and avoid linking the same target more than once.\n",
      "W0000 00:00:1754417831.802428  926711 computation_placer.cc:177] computation placer already registered. Please check linkage and avoid linking the same target more than once.\n",
      "W0000 00:00:1754417831.802430  926711 computation_placer.cc:177] computation placer already registered. Please check linkage and avoid linking the same target more than once.\n",
      "2025-08-05 20:17:11.807511: 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 dfca as DFCA\n",
    "\n",
    "import numpy as np\n",
    "\n",
    "from util import *"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-08-05T18:17:14.131901Z",
     "iopub.status.busy": "2025-08-05T18:17:14.131670Z",
     "iopub.status.idle": "2025-08-05T18:17:14.136672Z",
     "shell.execute_reply": "2025-08-05T18:17:14.135721Z"
    }
   },
   "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",
    "dfca = []"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "7ADsUSUi-tqf"
   },
   "source": [
    "Running the dfca experiment"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 1000
    },
    "execution": {
     "iopub.execute_input": "2025-08-05T18:17:14.139634Z",
     "iopub.status.busy": "2025-08-05T18:17:14.139434Z",
     "iopub.status.idle": "2025-08-07T11:56:28.542143Z",
     "shell.execute_reply": "2025-08-07T11:56:28.541038Z"
    },
    "id": "T_XDv25r-tqf",
    "outputId": "9c8f4300-c792-4e49-be40-c694fa066e6f"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "---------------------------------DFCA, lr: 0.25, seed: 1824---------------------------------\n",
      "config: {'m': 100, 'm_test': 20, 'p': 2, 'n': 1000, 'participation_rate': 1, '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:1754417838.897493  926711 gpu_device.cc:2019] Created device /job:localhost/replica:0/task:0/device:GPU:0 with 18963 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:1754417838.945974  926711 mlir_graph_optimization_pass.cc:425] MLIR V1 optimization pass is not enabled\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "finding good initializer from train data\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-08-05 20:17:19.278387: W tensorflow/c/c_api.cc:305] Operation '{name:'softmax_linear/biases/Assign' id:221 op device:{requested: '/device:CPU:0', assigned: ''} def:{{{node softmax_linear/biases/Assign}} = Assign[T=DT_FLOAT, _class=[\"loc:@softmax_linear/biases\"], _has_manual_control_dependencies=true, use_locking=true, validate_shape=true, _device=\"/device:CPU:0\"](softmax_linear/biases, softmax_linear/biases/Initializer/Const)}}' was changed by setting attribute after it was run by a session. This mutation will have no effect, and will trigger an error in the future. Either don't modify nodes after running them or create a new session.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "I0000 00:00:1754417840.355698  927401 cuda_dnn.cc:529] Loaded cuDNN version 90501\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch -1 tr: l 4.676 a 0.099  clct[np.int64(100), np.int64(0)] ans[np.int64(50), np.int64(50)] cl_acc 0.500 13.899sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-08-05 20:17:33.289429: W tensorflow/c/c_api.cc:305] Operation '{name:'softmax_linear/biases/Assign' id:221 op device:{requested: '/device:CPU:0', assigned: ''} def:{{{node softmax_linear/biases/Assign}} = Assign[T=DT_FLOAT, _class=[\"loc:@softmax_linear/biases\"], _has_manual_control_dependencies=true, use_locking=true, validate_shape=true, _device=\"/device:CPU:0\"](softmax_linear/biases, softmax_linear/biases/Initializer/Const)}}' was changed by setting attribute after it was run by a session. This mutation will have no effect, and will trigger an error in the future. Either don't modify nodes after running them or create a new session.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch -1 tr: l 4.673 a 0.096  clct[np.int64(100), np.int64(0)] ans[np.int64(50), np.int64(50)] cl_acc 0.500 9.839sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-08-05 20:17:43.262781: W tensorflow/c/c_api.cc:305] Operation '{name:'softmax_linear/biases/Assign' id:221 op device:{requested: '/device:CPU:0', assigned: ''} def:{{{node softmax_linear/biases/Assign}} = Assign[T=DT_FLOAT, _class=[\"loc:@softmax_linear/biases\"], _has_manual_control_dependencies=true, use_locking=true, validate_shape=true, _device=\"/device:CPU:0\"](softmax_linear/biases, softmax_linear/biases/Initializer/Const)}}' was changed by setting attribute after it was run by a session. This mutation will have no effect, and will trigger an error in the future. Either don't modify nodes after running them or create a new session.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch -1 tr: l 4.673 a 0.101  clct[np.int64(70), np.int64(30)] ans[np.int64(50), np.int64(50)] cl_acc 0.560 10.533sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-08-05 20:17:54.006565: W tensorflow/c/c_api.cc:305] Operation '{name:'softmax_linear/biases/Assign' id:221 op device:{requested: '/device:CPU:0', assigned: ''} def:{{{node softmax_linear/biases/Assign}} = Assign[T=DT_FLOAT, _class=[\"loc:@softmax_linear/biases\"], _has_manual_control_dependencies=true, use_locking=true, validate_shape=true, _device=\"/device:CPU:0\"](softmax_linear/biases, softmax_linear/biases/Initializer/Const)}}' was changed by setting attribute after it was run by a session. This mutation will have no effect, and will trigger an error in the future. Either don't modify nodes after running them or create a new session.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch -1 tr: l 4.673 a 0.099  clct[np.int64(94), np.int64(6)] ans[np.int64(50), np.int64(50)] cl_acc 0.500 11.905sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-08-05 20:18:06.033140: W tensorflow/c/c_api.cc:305] Operation '{name:'softmax_linear/biases/Assign' id:221 op device:{requested: '/device:CPU:0', assigned: ''} def:{{{node softmax_linear/biases/Assign}} = Assign[T=DT_FLOAT, _class=[\"loc:@softmax_linear/biases\"], _has_manual_control_dependencies=true, use_locking=true, validate_shape=true, _device=\"/device:CPU:0\"](softmax_linear/biases, softmax_linear/biases/Initializer/Const)}}' was changed by setting attribute after it was run by a session. This mutation will have no effect, and will trigger an error in the future. Either don't modify nodes after running them or create a new session.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch -1 tr: l 4.677 a 0.103  clct[np.int64(48), np.int64(52)] ans[np.int64(50), np.int64(50)] cl_acc 0.620 12.002sec\n",
      "found good initializer\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch -1 tr: l 4.677 a 0.104  clct[np.int64(48), np.int64(52)] ans[np.int64(50), np.int64(50)] cl_acc 0.620 12.353sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch -1 tst: l 4.677 a 0.102  clct[np.int64(8), np.int64(12)] ans[np.int64(10), np.int64(10)] cl_acc 0.700 2.432sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0 tr: l 3.789 a 0.232  clct[np.int64(53), np.int64(47)] ans[np.int64(50), np.int64(50)] lr 0.250000 cl_acc 0.690 393.352sec(train) 13.193sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0 tst: l 3.775 a 0.247  clct[np.int64(9), np.int64(11)] ans[np.int64(10), np.int64(10)] cl_acc 0.750 2.308sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1 tr: l 3.118 a 0.302  clct[np.int64(62), np.int64(38)] ans[np.int64(50), np.int64(50)] lr 0.247500 cl_acc 0.820 400.666sec(train) 12.012sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1 tst: l 3.093 a 0.335  clct[np.int64(12), np.int64(8)] ans[np.int64(10), np.int64(10)] cl_acc 0.900 2.093sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2 tr: l 2.572 a 0.371  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.245025 cl_acc 1.000 391.777sec(train) 12.943sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2 tst: l 2.504 a 0.423  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 2.301sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3 tr: l 2.173 a 0.427  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.242575 cl_acc 1.000 389.392sec(train) 12.737sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3 tst: l 2.098 a 0.466  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 2.301sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4 tr: l 1.896 a 0.475  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.240149 cl_acc 1.000 393.320sec(train) 9.996sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4 tst: l 1.834 a 0.502  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.883sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5 tr: l 1.721 a 0.505  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.237748 cl_acc 1.000 172.348sec(train) 5.957sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5 tst: l 1.604 a 0.551  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.169sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6 tr: l 1.577 a 0.540  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.235370 cl_acc 1.000 142.436sec(train) 6.014sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6 tst: l 1.484 a 0.577  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.293sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7 tr: l 1.493 a 0.559  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.233016 cl_acc 1.000 139.339sec(train) 5.743sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7 tst: l 1.374 a 0.606  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.107sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8 tr: l 1.408 a 0.582  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.230686 cl_acc 1.000 145.634sec(train) 6.068sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8 tst: l 1.292 a 0.627  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.785sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9 tr: l 1.347 a 0.601  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.228379 cl_acc 1.000 146.002sec(train) 6.021sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9 tst: l 1.243 a 0.642  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.188sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10 tr: l 1.279 a 0.624  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.226096 cl_acc 1.000 139.763sec(train) 6.139sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10 tst: l 1.204 a 0.647  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.197sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11 tr: l 1.281 a 0.620  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.223835 cl_acc 1.000 154.618sec(train) 6.003sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11 tst: l 1.161 a 0.665  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.148sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12 tr: l 1.260 a 0.631  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.221596 cl_acc 1.000 144.438sec(train) 5.748sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12 tst: l 1.157 a 0.668  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.232sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13 tr: l 1.241 a 0.636  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.219380 cl_acc 1.000 143.793sec(train) 5.626sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13 tst: l 1.120 a 0.681  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.142sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14 tr: l 1.214 a 0.646  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.217186 cl_acc 1.000 143.045sec(train) 5.832sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14 tst: l 1.108 a 0.684  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.267sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15 tr: l 1.210 a 0.650  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.215015 cl_acc 1.000 153.922sec(train) 6.730sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15 tst: l 1.131 a 0.682  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.460sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16 tr: l 1.156 a 0.670  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.212864 cl_acc 1.000 145.052sec(train) 5.945sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16 tst: l 1.066 a 0.701  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.269sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17 tr: l 1.159 a 0.669  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.210736 cl_acc 1.000 141.925sec(train) 5.781sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17 tst: l 1.080 a 0.697  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.111sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18 tr: l 1.143 a 0.675  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.208628 cl_acc 1.000 139.882sec(train) 5.976sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18 tst: l 1.062 a 0.706  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.355sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19 tr: l 1.131 a 0.680  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.206542 cl_acc 1.000 150.246sec(train) 6.436sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19 tst: l 1.089 a 0.699  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.359sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20 tr: l 1.124 a 0.684  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.204477 cl_acc 1.000 147.467sec(train) 5.963sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20 tst: l 1.065 a 0.706  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.431sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21 tr: l 1.102 a 0.692  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.202432 cl_acc 1.000 143.404sec(train) 6.433sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21 tst: l 1.046 a 0.714  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.201sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22 tr: l 1.092 a 0.697  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.200408 cl_acc 1.000 141.396sec(train) 6.589sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22 tst: l 1.026 a 0.722  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.125sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23 tr: l 1.087 a 0.700  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.198404 cl_acc 1.000 140.281sec(train) 6.267sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23 tst: l 1.030 a 0.721  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.449sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24 tr: l 1.095 a 0.698  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.196420 cl_acc 1.000 138.976sec(train) 5.834sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24 tst: l 1.015 a 0.728  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.170sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25 tr: l 1.092 a 0.699  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.194455 cl_acc 1.000 155.915sec(train) 9.174sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25 tst: l 1.020 a 0.725  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.862sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 26 tr: l 1.060 a 0.709  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.192511 cl_acc 1.000 167.165sec(train) 8.855sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 26 tst: l 1.005 a 0.730  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.541sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 27 tr: l 1.082 a 0.703  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.190586 cl_acc 1.000 147.181sec(train) 8.949sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 27 tst: l 1.035 a 0.724  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.788sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 28 tr: l 1.074 a 0.706  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.188680 cl_acc 1.000 174.076sec(train) 6.512sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 28 tst: l 1.001 a 0.734  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.284sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 29 tr: l 1.050 a 0.715  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.186793 cl_acc 1.000 161.229sec(train) 7.591sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 29 tst: l 1.032 a 0.727  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.707sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 30 tr: l 1.068 a 0.708  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.184925 cl_acc 1.000 159.503sec(train) 8.771sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 30 tst: l 1.019 a 0.730  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.379sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 31 tr: l 1.052 a 0.713  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.183076 cl_acc 1.000 146.149sec(train) 5.557sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 31 tst: l 1.017 a 0.731  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.154sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 32 tr: l 1.038 a 0.722  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.181245 cl_acc 1.000 156.788sec(train) 7.821sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 32 tst: l 0.995 a 0.737  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.689sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 33 tr: l 1.030 a 0.721  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.179433 cl_acc 1.000 154.506sec(train) 8.485sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 33 tst: l 0.997 a 0.738  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.565sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 34 tr: l 1.044 a 0.719  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.177638 cl_acc 1.000 144.990sec(train) 8.136sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 34 tst: l 1.003 a 0.740  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.715sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 35 tr: l 1.008 a 0.728  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.175862 cl_acc 1.000 147.391sec(train) 6.520sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 35 tst: l 0.996 a 0.741  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.286sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 36 tr: l 1.010 a 0.728  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.174103 cl_acc 1.000 143.241sec(train) 7.156sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 36 tst: l 1.000 a 0.736  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.292sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 37 tr: l 1.035 a 0.722  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.172362 cl_acc 1.000 141.816sec(train) 6.236sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 37 tst: l 0.972 a 0.746  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.429sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 38 tr: l 1.016 a 0.727  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.170639 cl_acc 1.000 168.071sec(train) 7.018sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 38 tst: l 0.974 a 0.747  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.193sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 39 tr: l 0.980 a 0.740  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.168932 cl_acc 1.000 141.159sec(train) 8.495sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 39 tst: l 0.963 a 0.749  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.329sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 40 tr: l 1.002 a 0.733  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.167243 cl_acc 1.000 145.327sec(train) 6.466sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 40 tst: l 0.976 a 0.747  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.269sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 41 tr: l 0.987 a 0.737  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.165571 cl_acc 1.000 135.676sec(train) 6.275sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 41 tst: l 0.949 a 0.756  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.151sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 42 tr: l 0.975 a 0.741  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.163915 cl_acc 1.000 137.901sec(train) 5.813sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 42 tst: l 0.954 a 0.753  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.152sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 43 tr: l 1.013 a 0.730  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.162276 cl_acc 1.000 139.492sec(train) 5.676sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 43 tst: l 0.972 a 0.748  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.147sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 44 tr: l 0.965 a 0.744  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.160653 cl_acc 1.000 144.738sec(train) 6.014sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 44 tst: l 0.954 a 0.753  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.123sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 45 tr: l 0.983 a 0.739  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.159046 cl_acc 1.000 150.364sec(train) 6.393sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 45 tst: l 0.941 a 0.756  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.176sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 46 tr: l 0.977 a 0.741  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.157456 cl_acc 1.000 166.451sec(train) 5.719sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 46 tst: l 0.960 a 0.749  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.120sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 47 tr: l 0.954 a 0.747  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.155881 cl_acc 1.000 154.636sec(train) 6.243sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 47 tst: l 0.947 a 0.753  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.220sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 48 tr: l 0.964 a 0.746  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.154323 cl_acc 1.000 161.370sec(train) 6.555sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 48 tst: l 0.940 a 0.756  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.293sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 49 tr: l 0.940 a 0.752  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.152779 cl_acc 1.000 152.139sec(train) 5.768sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 49 tst: l 0.944 a 0.757  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.108sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 50 tr: l 0.951 a 0.749  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.151252 cl_acc 1.000 139.386sec(train) 8.084sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 50 tst: l 0.936 a 0.758  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.511sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 51 tr: l 0.956 a 0.748  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.149739 cl_acc 1.000 163.941sec(train) 6.395sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 51 tst: l 0.949 a 0.757  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.239sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 52 tr: l 0.938 a 0.754  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.148242 cl_acc 1.000 157.389sec(train) 6.276sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 52 tst: l 0.950 a 0.756  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.223sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 53 tr: l 0.949 a 0.752  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.146759 cl_acc 1.000 167.768sec(train) 5.697sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 53 tst: l 0.953 a 0.755  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.342sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 54 tr: l 0.917 a 0.760  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.145292 cl_acc 1.000 153.324sec(train) 6.679sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 54 tst: l 0.920 a 0.763  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.411sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 55 tr: l 0.919 a 0.758  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.143839 cl_acc 1.000 167.178sec(train) 6.690sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 55 tst: l 0.924 a 0.761  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.287sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 56 tr: l 0.926 a 0.756  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.142400 cl_acc 1.000 135.756sec(train) 7.326sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 56 tst: l 0.921 a 0.763  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.354sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 57 tr: l 0.912 a 0.761  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.140976 cl_acc 1.000 145.801sec(train) 5.913sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 57 tst: l 0.911 a 0.768  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.281sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 58 tr: l 0.921 a 0.758  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.139567 cl_acc 1.000 145.620sec(train) 5.831sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 58 tst: l 0.912 a 0.765  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.163sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 59 tr: l 0.924 a 0.758  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.138171 cl_acc 1.000 163.612sec(train) 6.773sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 59 tst: l 0.905 a 0.767  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.289sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 60 tr: l 0.901 a 0.765  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.136789 cl_acc 1.000 154.300sec(train) 5.955sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 60 tst: l 0.923 a 0.762  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.340sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 61 tr: l 0.906 a 0.763  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.135421 cl_acc 1.000 142.819sec(train) 6.292sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 61 tst: l 0.919 a 0.765  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.237sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 62 tr: l 0.885 a 0.767  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.134067 cl_acc 1.000 160.262sec(train) 6.140sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 62 tst: l 0.896 a 0.768  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.254sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 63 tr: l 0.900 a 0.765  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.132726 cl_acc 1.000 143.958sec(train) 7.103sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 63 tst: l 0.918 a 0.764  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.472sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 64 tr: l 0.893 a 0.767  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.131399 cl_acc 1.000 150.782sec(train) 6.714sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 64 tst: l 0.905 a 0.767  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.307sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 65 tr: l 0.881 a 0.769  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.130085 cl_acc 1.000 142.005sec(train) 6.180sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 65 tst: l 0.891 a 0.770  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.131sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 66 tr: l 0.882 a 0.771  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.128784 cl_acc 1.000 142.116sec(train) 7.116sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 66 tst: l 0.910 a 0.765  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.246sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 67 tr: l 0.887 a 0.768  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.127496 cl_acc 1.000 134.351sec(train) 6.018sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 67 tst: l 0.901 a 0.769  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.137sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 68 tr: l 0.891 a 0.768  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.126221 cl_acc 1.000 134.966sec(train) 7.792sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 68 tst: l 0.890 a 0.773  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.491sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 69 tr: l 0.881 a 0.771  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.124959 cl_acc 1.000 141.738sec(train) 8.659sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 69 tst: l 0.899 a 0.770  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.605sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 70 tr: l 0.866 a 0.775  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.123710 cl_acc 1.000 143.124sec(train) 7.712sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 70 tst: l 0.893 a 0.772  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.266sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 71 tr: l 0.882 a 0.769  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.122473 cl_acc 1.000 149.529sec(train) 6.679sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 71 tst: l 0.868 a 0.777  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.504sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 72 tr: l 0.866 a 0.774  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.121248 cl_acc 1.000 142.550sec(train) 8.253sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 72 tst: l 0.867 a 0.778  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 2.009sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 73 tr: l 0.860 a 0.777  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.120035 cl_acc 1.000 145.219sec(train) 6.412sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 73 tst: l 0.897 a 0.771  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.323sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 74 tr: l 0.838 a 0.783  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.118835 cl_acc 1.000 142.293sec(train) 5.871sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 74 tst: l 0.890 a 0.770  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.132sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 75 tr: l 0.863 a 0.776  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.117647 cl_acc 1.000 142.733sec(train) 8.567sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 75 tst: l 0.905 a 0.770  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.746sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 76 tr: l 0.853 a 0.776  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.116470 cl_acc 1.000 143.019sec(train) 5.652sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 76 tst: l 0.885 a 0.773  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.116sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 77 tr: l 0.852 a 0.778  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.115305 cl_acc 1.000 136.440sec(train) 7.313sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 77 tst: l 0.873 a 0.774  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.309sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 78 tr: l 0.861 a 0.775  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.114152 cl_acc 1.000 150.203sec(train) 5.580sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 78 tst: l 0.883 a 0.774  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.104sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 79 tr: l 0.825 a 0.786  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.113011 cl_acc 1.000 153.862sec(train) 5.654sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 79 tst: l 0.883 a 0.775  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.317sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 80 tr: l 0.836 a 0.783  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.111881 cl_acc 1.000 148.528sec(train) 6.909sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 80 tst: l 0.854 a 0.778  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.401sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 81 tr: l 0.831 a 0.786  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.110762 cl_acc 1.000 156.878sec(train) 6.588sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 81 tst: l 0.861 a 0.778  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.185sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 82 tr: l 0.840 a 0.782  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.109654 cl_acc 1.000 150.802sec(train) 7.758sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 82 tst: l 0.867 a 0.776  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.703sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 83 tr: l 0.825 a 0.786  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.108558 cl_acc 1.000 144.099sec(train) 6.836sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 83 tst: l 0.863 a 0.779  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.316sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 84 tr: l 0.828 a 0.786  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.107472 cl_acc 1.000 142.540sec(train) 5.778sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 84 tst: l 0.862 a 0.777  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.139sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 85 tr: l 0.830 a 0.784  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.106398 cl_acc 1.000 136.162sec(train) 6.092sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 85 tst: l 0.885 a 0.773  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.228sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 86 tr: l 0.822 a 0.788  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.105334 cl_acc 1.000 1415.594sec(train) 32.586sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 86 tst: l 0.871 a 0.776  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 4.088sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 87 tr: l 0.805 a 0.792  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.104280 cl_acc 1.000 2302.476sec(train) 31.294sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 87 tst: l 0.856 a 0.781  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 4.869sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 88 tr: l 0.810 a 0.790  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.103237 cl_acc 1.000 2299.162sec(train) 32.654sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 88 tst: l 0.854 a 0.777  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 5.321sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 89 tr: l 0.809 a 0.791  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.102205 cl_acc 1.000 2291.775sec(train) 31.551sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 89 tst: l 0.869 a 0.778  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 4.769sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 90 tr: l 0.799 a 0.793  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.101183 cl_acc 1.000 2278.109sec(train) 32.401sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 90 tst: l 0.848 a 0.782  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 4.557sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 91 tr: l 0.801 a 0.792  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.100171 cl_acc 1.000 2287.529sec(train) 31.671sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 91 tst: l 0.864 a 0.777  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 4.609sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 92 tr: l 0.794 a 0.794  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.099169 cl_acc 1.000 2287.592sec(train) 32.836sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 92 tst: l 0.856 a 0.781  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 5.336sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 93 tr: l 0.778 a 0.800  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.098178 cl_acc 1.000 2284.555sec(train) 32.505sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 93 tst: l 0.859 a 0.781  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 4.576sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 94 tr: l 0.796 a 0.793  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.097196 cl_acc 1.000 2285.252sec(train) 34.350sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 94 tst: l 0.851 a 0.780  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 5.395sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 95 tr: l 0.784 a 0.798  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.096224 cl_acc 1.000 2286.209sec(train) 33.484sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 95 tst: l 0.855 a 0.782  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 4.437sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 96 tr: l 0.777 a 0.799  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.095262 cl_acc 1.000 2107.384sec(train) 26.595sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 96 tst: l 0.848 a 0.781  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 4.101sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 97 tr: l 0.768 a 0.801  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.094309 cl_acc 1.000 1559.144sec(train) 19.621sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 97 tst: l 0.852 a 0.780  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 2.805sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 98 tr: l 0.775 a 0.799  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.093366 cl_acc 1.000 1226.839sec(train) 18.835sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 98 tst: l 0.832 a 0.787  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 2.929sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 99 tr: l 0.774 a 0.802  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.092432 cl_acc 1.000 1228.428sec(train) 18.980sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 99 tst: l 0.829 a 0.789  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 3.100sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 100 tr: l 0.760 a 0.805  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.091508 cl_acc 1.000 1228.188sec(train) 18.865sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 100 tst: l 0.851 a 0.782  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 3.399sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 101 tr: l 0.786 a 0.796  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.090593 cl_acc 1.000 349.661sec(train) 5.802sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 101 tst: l 0.853 a 0.784  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.208sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 102 tr: l 0.761 a 0.802  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.089687 cl_acc 1.000 143.731sec(train) 7.280sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 102 tst: l 0.814 a 0.788  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.483sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 103 tr: l 0.772 a 0.801  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.088790 cl_acc 1.000 147.791sec(train) 5.911sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 103 tst: l 0.837 a 0.785  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.218sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 104 tr: l 0.782 a 0.797  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.087902 cl_acc 1.000 152.123sec(train) 6.218sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 104 tst: l 0.846 a 0.784  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.185sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 105 tr: l 0.762 a 0.802  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.087023 cl_acc 1.000 146.856sec(train) 5.798sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 105 tst: l 0.820 a 0.790  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.131sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 106 tr: l 0.770 a 0.799  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.086153 cl_acc 1.000 147.982sec(train) 5.845sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 106 tst: l 0.840 a 0.784  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.151sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 107 tr: l 0.746 a 0.807  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.085292 cl_acc 1.000 151.769sec(train) 5.837sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 107 tst: l 0.828 a 0.786  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.160sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 108 tr: l 0.751 a 0.806  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.084439 cl_acc 1.000 148.503sec(train) 5.845sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 108 tst: l 0.819 a 0.787  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.171sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 109 tr: l 0.748 a 0.808  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.083594 cl_acc 1.000 162.428sec(train) 6.034sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 109 tst: l 0.839 a 0.788  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.141sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 110 tr: l 0.735 a 0.810  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.082758 cl_acc 1.000 169.536sec(train) 6.844sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 110 tst: l 0.827 a 0.786  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.263sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 111 tr: l 0.766 a 0.802  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.081931 cl_acc 1.000 155.334sec(train) 8.035sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 111 tst: l 0.825 a 0.788  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.640sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 112 tr: l 0.728 a 0.812  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.081111 cl_acc 1.000 145.304sec(train) 8.515sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 112 tst: l 0.831 a 0.787  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.412sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 113 tr: l 0.726 a 0.814  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.080300 cl_acc 1.000 152.487sec(train) 6.926sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 113 tst: l 0.842 a 0.786  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.331sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 114 tr: l 0.754 a 0.805  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.079497 cl_acc 1.000 146.484sec(train) 6.532sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 114 tst: l 0.835 a 0.788  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.264sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 115 tr: l 0.755 a 0.805  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.078702 cl_acc 1.000 152.585sec(train) 7.967sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 115 tst: l 0.818 a 0.791  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.348sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 116 tr: l 0.731 a 0.812  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.077915 cl_acc 1.000 146.465sec(train) 5.707sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 116 tst: l 0.825 a 0.789  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.128sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 117 tr: l 0.743 a 0.807  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.077136 cl_acc 1.000 152.463sec(train) 5.867sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 117 tst: l 0.837 a 0.787  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.166sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 118 tr: l 0.737 a 0.808  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.076365 cl_acc 1.000 144.519sec(train) 5.903sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 118 tst: l 0.817 a 0.792  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.167sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 119 tr: l 0.752 a 0.805  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.075601 cl_acc 1.000 144.243sec(train) 5.803sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 119 tst: l 0.823 a 0.788  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.252sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 120 tr: l 0.734 a 0.811  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.074845 cl_acc 1.000 157.270sec(train) 5.939sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 120 tst: l 0.823 a 0.789  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.313sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 121 tr: l 0.721 a 0.814  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.074097 cl_acc 1.000 161.850sec(train) 6.968sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 121 tst: l 0.816 a 0.792  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.351sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 122 tr: l 0.730 a 0.811  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.073356 cl_acc 1.000 166.745sec(train) 7.115sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 122 tst: l 0.808 a 0.794  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.417sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 123 tr: l 0.713 a 0.817  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.072622 cl_acc 1.000 153.739sec(train) 6.476sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 123 tst: l 0.817 a 0.792  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.240sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 124 tr: l 0.719 a 0.814  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.071896 cl_acc 1.000 146.344sec(train) 7.092sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 124 tst: l 0.819 a 0.788  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.228sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 125 tr: l 0.717 a 0.815  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.071177 cl_acc 1.000 165.434sec(train) 5.997sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 125 tst: l 0.814 a 0.789  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.349sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 126 tr: l 0.712 a 0.815  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.070465 cl_acc 1.000 145.837sec(train) 6.963sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 126 tst: l 0.815 a 0.789  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.295sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 127 tr: l 0.713 a 0.817  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.069761 cl_acc 1.000 147.706sec(train) 5.914sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 127 tst: l 0.812 a 0.793  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.166sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 128 tr: l 0.706 a 0.819  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.069063 cl_acc 1.000 158.742sec(train) 5.797sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 128 tst: l 0.818 a 0.792  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 129 tr: l 0.694 a 0.823  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.068372 cl_acc 1.000 145.647sec(train) 5.848sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 129 tst: l 0.802 a 0.794  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.164sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 130 tr: l 0.707 a 0.819  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.067689 cl_acc 1.000 168.531sec(train) 5.921sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 130 tst: l 0.814 a 0.790  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.164sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 131 tr: l 0.712 a 0.815  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.067012 cl_acc 1.000 150.894sec(train) 6.787sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 131 tst: l 0.801 a 0.793  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.294sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 132 tr: l 0.691 a 0.820  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.066342 cl_acc 1.000 152.724sec(train) 5.891sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 132 tst: l 0.813 a 0.790  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.154sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 133 tr: l 0.696 a 0.820  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.065678 cl_acc 1.000 144.849sec(train) 6.878sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 133 tst: l 0.802 a 0.793  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.500sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 134 tr: l 0.703 a 0.818  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.065021 cl_acc 1.000 152.823sec(train) 6.122sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 134 tst: l 0.808 a 0.793  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.354sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 135 tr: l 0.706 a 0.817  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.064371 cl_acc 1.000 145.618sec(train) 5.967sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 135 tst: l 0.804 a 0.796  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.156sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 136 tr: l 0.678 a 0.825  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.063727 cl_acc 1.000 154.258sec(train) 5.831sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 136 tst: l 0.791 a 0.795  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 137 tr: l 0.697 a 0.820  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.063090 cl_acc 1.000 143.586sec(train) 5.789sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 137 tst: l 0.794 a 0.794  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.202sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 138 tr: l 0.677 a 0.826  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.062459 cl_acc 1.000 151.898sec(train) 5.736sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 138 tst: l 0.801 a 0.794  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.129sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 139 tr: l 0.683 a 0.823  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.061835 cl_acc 1.000 165.100sec(train) 7.248sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 139 tst: l 0.810 a 0.794  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.297sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 140 tr: l 0.679 a 0.824  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.061216 cl_acc 1.000 148.030sec(train) 5.920sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 140 tst: l 0.798 a 0.796  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.173sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 141 tr: l 0.690 a 0.822  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.060604 cl_acc 1.000 151.095sec(train) 6.566sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 141 tst: l 0.797 a 0.796  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.450sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 142 tr: l 0.681 a 0.823  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.059998 cl_acc 1.000 149.051sec(train) 5.941sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 142 tst: l 0.789 a 0.798  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.138sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 143 tr: l 0.687 a 0.821  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.059398 cl_acc 1.000 148.823sec(train) 6.945sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 143 tst: l 0.799 a 0.796  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.538sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 144 tr: l 0.687 a 0.824  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.058804 cl_acc 1.000 170.183sec(train) 6.438sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 144 tst: l 0.778 a 0.799  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.435sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 145 tr: l 0.684 a 0.823  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.058216 cl_acc 1.000 176.217sec(train) 6.024sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 145 tst: l 0.793 a 0.798  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.193sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 146 tr: l 0.676 a 0.826  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.057634 cl_acc 1.000 150.000sec(train) 6.934sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 146 tst: l 0.795 a 0.797  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.507sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 147 tr: l 0.661 a 0.829  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.057058 cl_acc 1.000 246.859sec(train) 10.195sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 147 tst: l 0.794 a 0.797  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.834sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 148 tr: l 0.658 a 0.829  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.056487 cl_acc 1.000 296.060sec(train) 10.361sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 148 tst: l 0.782 a 0.799  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.741sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 149 tr: l 0.668 a 0.827  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.055922 cl_acc 1.000 427.934sec(train) 10.476sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 149 tst: l 0.776 a 0.801  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.716sec\n",
      "result written at output/results.pickle\n",
      "---train cluster Ended in 14.79 hour (53244.982 sec) \n",
      "---------------------------------DFCA, lr: 0.25, seed: 409---------------------------------\n",
      "config: {'m': 100, 'm_test': 20, 'p': 2, 'n': 1000, 'participation_rate': 1, '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:1754471083.238061  926711 gpu_device.cc:2019] Created device /job:localhost/replica:0/task:0/device:GPU:0 with 18963 MB memory:  -> device: 2, name: NVIDIA A100-SXM4-40GB, pci bus id: 0000:81:00.0, compute capability: 8.0\n",
      "2025-08-06 11:04:43.367416: W tensorflow/c/c_api.cc:305] Operation '{name:'softmax_linear/biases/Assign' id:221 op device:{requested: '/device:CPU:0', assigned: ''} def:{{{node softmax_linear/biases/Assign}} = Assign[T=DT_FLOAT, _class=[\"loc:@softmax_linear/biases\"], _has_manual_control_dependencies=true, use_locking=true, validate_shape=true, _device=\"/device:CPU:0\"](softmax_linear/biases, softmax_linear/biases/Initializer/Const)}}' was changed by setting attribute after it was run by a session. This mutation will have no effect, and will trigger an error in the future. Either don't modify nodes after running them or create a new session.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "finding good initializer from train data\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch -1 tr: l 4.673 a 0.102  clct[np.int64(100), np.int64(0)] ans[np.int64(50), np.int64(50)] cl_acc 0.500 11.770sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-08-06 11:04:55.251001: W tensorflow/c/c_api.cc:305] Operation '{name:'softmax_linear/biases/Assign' id:221 op device:{requested: '/device:CPU:0', assigned: ''} def:{{{node softmax_linear/biases/Assign}} = Assign[T=DT_FLOAT, _class=[\"loc:@softmax_linear/biases\"], _has_manual_control_dependencies=true, use_locking=true, validate_shape=true, _device=\"/device:CPU:0\"](softmax_linear/biases, softmax_linear/biases/Initializer/Const)}}' was changed by setting attribute after it was run by a session. This mutation will have no effect, and will trigger an error in the future. Either don't modify nodes after running them or create a new session.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch -1 tr: l 4.671 a 0.099  clct[np.int64(100), np.int64(0)] ans[np.int64(50), np.int64(50)] cl_acc 0.500 10.513sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-08-06 11:05:05.916300: W tensorflow/c/c_api.cc:305] Operation '{name:'softmax_linear/biases/Assign' id:221 op device:{requested: '/device:CPU:0', assigned: ''} def:{{{node softmax_linear/biases/Assign}} = Assign[T=DT_FLOAT, _class=[\"loc:@softmax_linear/biases\"], _has_manual_control_dependencies=true, use_locking=true, validate_shape=true, _device=\"/device:CPU:0\"](softmax_linear/biases, softmax_linear/biases/Initializer/Const)}}' was changed by setting attribute after it was run by a session. This mutation will have no effect, and will trigger an error in the future. Either don't modify nodes after running them or create a new session.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch -1 tr: l 4.677 a 0.096  clct[np.int64(87), np.int64(13)] ans[np.int64(50), np.int64(50)] cl_acc 0.630 7.566sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-08-06 11:05:13.596922: W tensorflow/c/c_api.cc:305] Operation '{name:'softmax_linear/biases/Assign' id:221 op device:{requested: '/device:CPU:0', assigned: ''} def:{{{node softmax_linear/biases/Assign}} = Assign[T=DT_FLOAT, _class=[\"loc:@softmax_linear/biases\"], _has_manual_control_dependencies=true, use_locking=true, validate_shape=true, _device=\"/device:CPU:0\"](softmax_linear/biases, softmax_linear/biases/Initializer/Const)}}' was changed by setting attribute after it was run by a session. This mutation will have no effect, and will trigger an error in the future. Either don't modify nodes after running them or create a new session.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch -1 tr: l 4.674 a 0.106  clct[np.int64(1), np.int64(99)] ans[np.int64(50), np.int64(50)] cl_acc 0.510 7.593sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-08-06 11:05:21.308645: W tensorflow/c/c_api.cc:305] Operation '{name:'softmax_linear/biases/Assign' id:221 op device:{requested: '/device:CPU:0', assigned: ''} def:{{{node softmax_linear/biases/Assign}} = Assign[T=DT_FLOAT, _class=[\"loc:@softmax_linear/biases\"], _has_manual_control_dependencies=true, use_locking=true, validate_shape=true, _device=\"/device:CPU:0\"](softmax_linear/biases, softmax_linear/biases/Initializer/Const)}}' was changed by setting attribute after it was run by a session. This mutation will have no effect, and will trigger an error in the future. Either don't modify nodes after running them or create a new session.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch -1 tr: l 4.676 a 0.119  clct[np.int64(100), np.int64(0)] ans[np.int64(50), np.int64(50)] cl_acc 0.500 6.728sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-08-06 11:05:28.162159: W tensorflow/c/c_api.cc:305] Operation '{name:'softmax_linear/biases/Assign' id:221 op device:{requested: '/device:CPU:0', assigned: ''} def:{{{node softmax_linear/biases/Assign}} = Assign[T=DT_FLOAT, _class=[\"loc:@softmax_linear/biases\"], _has_manual_control_dependencies=true, use_locking=true, validate_shape=true, _device=\"/device:CPU:0\"](softmax_linear/biases, softmax_linear/biases/Initializer/Const)}}' was changed by setting attribute after it was run by a session. This mutation will have no effect, and will trigger an error in the future. Either don't modify nodes after running them or create a new session.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch -1 tr: l 4.674 a 0.093  clct[np.int64(44), np.int64(56)] ans[np.int64(50), np.int64(50)] cl_acc 0.660 9.418sec\n",
      "found good initializer\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch -1 tr: l 4.674 a 0.095  clct[np.int64(45), np.int64(55)] ans[np.int64(50), np.int64(50)] cl_acc 0.650 8.188sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch -1 tst: l 4.675 a 0.093  clct[np.int64(6), np.int64(14)] ans[np.int64(10), np.int64(10)] cl_acc 0.500 1.566sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0 tr: l 3.791 a 0.225  clct[np.int64(40), np.int64(60)] ans[np.int64(50), np.int64(50)] lr 0.250000 cl_acc 0.700 157.051sec(train) 7.273sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0 tst: l 3.777 a 0.251  clct[np.int64(7), np.int64(13)] ans[np.int64(10), np.int64(10)] cl_acc 0.650 1.356sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1 tr: l 3.113 a 0.302  clct[np.int64(30), np.int64(70)] ans[np.int64(50), np.int64(50)] lr 0.247500 cl_acc 0.780 144.008sec(train) 6.186sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1 tst: l 3.096 a 0.318  clct[np.int64(6), np.int64(14)] ans[np.int64(10), np.int64(10)] cl_acc 0.700 1.154sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2 tr: l 2.519 a 0.381  clct[np.int64(48), np.int64(52)] ans[np.int64(50), np.int64(50)] lr 0.245025 cl_acc 0.980 146.285sec(train) 6.552sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2 tst: l 2.446 a 0.423  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.635sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3 tr: l 2.154 a 0.430  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.242575 cl_acc 1.000 136.709sec(train) 5.934sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3 tst: l 2.066 a 0.476  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.263sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4 tr: l 1.905 a 0.472  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.240149 cl_acc 1.000 134.747sec(train) 6.356sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4 tst: l 1.820 a 0.510  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.151sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5 tr: l 1.703 a 0.515  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.237748 cl_acc 1.000 146.003sec(train) 5.989sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5 tst: l 1.605 a 0.556  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.164sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6 tr: l 1.594 a 0.532  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.235370 cl_acc 1.000 139.101sec(train) 6.316sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6 tst: l 1.490 a 0.575  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.204sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7 tr: l 1.511 a 0.554  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.233016 cl_acc 1.000 151.798sec(train) 8.065sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7 tst: l 1.392 a 0.599  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.516sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8 tr: l 1.409 a 0.581  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.230686 cl_acc 1.000 137.399sec(train) 6.239sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8 tst: l 1.315 a 0.616  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.178sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9 tr: l 1.363 a 0.597  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.228379 cl_acc 1.000 140.559sec(train) 6.472sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9 tst: l 1.237 a 0.640  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.222sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10 tr: l 1.318 a 0.609  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.226096 cl_acc 1.000 138.827sec(train) 6.093sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10 tst: l 1.219 a 0.648  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.189sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11 tr: l 1.294 a 0.617  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.223835 cl_acc 1.000 146.198sec(train) 7.004sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11 tst: l 1.182 a 0.659  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.376sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12 tr: l 1.267 a 0.628  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.221596 cl_acc 1.000 145.845sec(train) 6.220sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12 tst: l 1.150 a 0.667  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.151sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13 tr: l 1.232 a 0.640  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.219380 cl_acc 1.000 159.620sec(train) 6.710sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13 tst: l 1.121 a 0.677  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.291sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14 tr: l 1.229 a 0.641  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.217186 cl_acc 1.000 141.941sec(train) 6.307sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14 tst: l 1.120 a 0.682  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.175sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15 tr: l 1.180 a 0.658  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.215015 cl_acc 1.000 145.232sec(train) 6.508sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15 tst: l 1.086 a 0.694  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.313sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16 tr: l 1.178 a 0.663  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.212864 cl_acc 1.000 149.835sec(train) 6.355sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16 tst: l 1.082 a 0.699  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.186sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17 tr: l 1.174 a 0.663  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.210736 cl_acc 1.000 135.213sec(train) 6.691sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17 tst: l 1.096 a 0.700  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.181sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18 tr: l 1.148 a 0.674  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.208628 cl_acc 1.000 142.881sec(train) 6.395sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18 tst: l 1.068 a 0.706  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.176sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19 tr: l 1.170 a 0.668  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.206542 cl_acc 1.000 134.610sec(train) 6.879sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19 tst: l 1.056 a 0.710  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.380sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20 tr: l 1.148 a 0.674  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.204477 cl_acc 1.000 155.876sec(train) 6.504sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20 tst: l 1.051 a 0.712  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.219sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21 tr: l 1.123 a 0.685  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.202432 cl_acc 1.000 138.324sec(train) 6.099sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21 tst: l 1.038 a 0.720  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.173sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22 tr: l 1.125 a 0.687  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.200408 cl_acc 1.000 419.297sec(train) 10.904sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22 tst: l 1.034 a 0.719  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.802sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23 tr: l 1.105 a 0.694  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.198404 cl_acc 1.000 145.707sec(train) 6.077sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23 tst: l 1.045 a 0.719  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.236sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24 tr: l 1.105 a 0.692  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.196420 cl_acc 1.000 145.165sec(train) 7.715sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24 tst: l 1.045 a 0.721  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.692sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25 tr: l 1.098 a 0.697  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.194455 cl_acc 1.000 145.722sec(train) 7.261sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25 tst: l 1.008 a 0.729  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.426sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 26 tr: l 1.069 a 0.704  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.192511 cl_acc 1.000 395.556sec(train) 11.221sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 26 tst: l 1.046 a 0.721  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 2.043sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 27 tr: l 1.065 a 0.708  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.190586 cl_acc 1.000 398.579sec(train) 10.823sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 27 tst: l 1.021 a 0.729  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.853sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 28 tr: l 1.081 a 0.703  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.188680 cl_acc 1.000 286.053sec(train) 9.544sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 28 tst: l 1.020 a 0.728  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.679sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 29 tr: l 1.074 a 0.706  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.186793 cl_acc 1.000 182.932sec(train) 9.386sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 29 tst: l 1.011 a 0.730  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.722sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 30 tr: l 1.075 a 0.705  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.184925 cl_acc 1.000 193.216sec(train) 9.448sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 30 tst: l 0.999 a 0.736  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.774sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 31 tr: l 1.031 a 0.721  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.183076 cl_acc 1.000 152.738sec(train) 6.957sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 31 tst: l 1.005 a 0.735  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.291sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 32 tr: l 1.031 a 0.722  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.181245 cl_acc 1.000 150.444sec(train) 8.544sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 32 tst: l 0.997 a 0.739  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.673sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 33 tr: l 1.044 a 0.718  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.179433 cl_acc 1.000 137.134sec(train) 5.792sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 33 tst: l 0.991 a 0.740  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 34 tr: l 1.019 a 0.725  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.177638 cl_acc 1.000 134.432sec(train) 5.756sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 34 tst: l 0.979 a 0.744  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.164sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 35 tr: l 1.022 a 0.726  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.175862 cl_acc 1.000 134.257sec(train) 6.278sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 35 tst: l 0.997 a 0.738  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.283sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 36 tr: l 1.006 a 0.728  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.174103 cl_acc 1.000 164.333sec(train) 6.019sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 36 tst: l 0.981 a 0.743  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.182sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 37 tr: l 1.023 a 0.727  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.172362 cl_acc 1.000 406.217sec(train) 11.003sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 37 tst: l 0.986 a 0.743  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.831sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 38 tr: l 1.018 a 0.727  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.170639 cl_acc 1.000 357.107sec(train) 10.049sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 38 tst: l 0.975 a 0.747  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.875sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 39 tr: l 0.996 a 0.734  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.168932 cl_acc 1.000 221.619sec(train) 6.262sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 39 tst: l 0.971 a 0.746  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.177sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 40 tr: l 0.998 a 0.732  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.167243 cl_acc 1.000 135.586sec(train) 5.900sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 40 tst: l 0.978 a 0.747  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.236sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 41 tr: l 0.994 a 0.733  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.165571 cl_acc 1.000 136.942sec(train) 10.698sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 41 tst: l 0.965 a 0.749  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.978sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 42 tr: l 0.991 a 0.735  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.163915 cl_acc 1.000 250.112sec(train) 6.028sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 42 tst: l 0.965 a 0.750  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.181sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 43 tr: l 0.986 a 0.736  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.162276 cl_acc 1.000 152.567sec(train) 6.815sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 43 tst: l 0.969 a 0.748  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.194sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 44 tr: l 0.978 a 0.738  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.160653 cl_acc 1.000 267.941sec(train) 9.263sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 44 tst: l 0.975 a 0.746  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.724sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 45 tr: l 0.970 a 0.741  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.159046 cl_acc 1.000 143.160sec(train) 8.239sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 45 tst: l 0.963 a 0.752  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.471sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 46 tr: l 0.980 a 0.738  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.157456 cl_acc 1.000 143.815sec(train) 6.881sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 46 tst: l 0.973 a 0.747  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.390sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 47 tr: l 0.957 a 0.746  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.155881 cl_acc 1.000 135.414sec(train) 6.030sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 47 tst: l 0.943 a 0.754  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.339sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 48 tr: l 0.967 a 0.743  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.154323 cl_acc 1.000 138.600sec(train) 6.743sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 48 tst: l 0.940 a 0.758  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.249sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 49 tr: l 0.953 a 0.747  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.152779 cl_acc 1.000 136.506sec(train) 7.577sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 49 tst: l 0.938 a 0.754  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.538sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 50 tr: l 0.948 a 0.749  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.151252 cl_acc 1.000 136.785sec(train) 6.033sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 50 tst: l 0.910 a 0.765  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.207sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 51 tr: l 0.938 a 0.752  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.149739 cl_acc 1.000 155.933sec(train) 5.850sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 51 tst: l 0.919 a 0.762  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.244sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 52 tr: l 0.958 a 0.745  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.148242 cl_acc 1.000 140.326sec(train) 6.585sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 52 tst: l 0.920 a 0.761  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.193sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 53 tr: l 0.960 a 0.746  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.146759 cl_acc 1.000 139.958sec(train) 7.864sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 53 tst: l 0.933 a 0.757  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.694sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 54 tr: l 0.961 a 0.745  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.145292 cl_acc 1.000 136.062sec(train) 6.587sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 54 tst: l 0.938 a 0.760  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.419sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 55 tr: l 0.932 a 0.755  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.143839 cl_acc 1.000 135.986sec(train) 7.236sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 55 tst: l 0.944 a 0.759  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.316sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 56 tr: l 0.945 a 0.750  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.142400 cl_acc 1.000 141.551sec(train) 7.906sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 56 tst: l 0.918 a 0.763  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.294sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 57 tr: l 0.931 a 0.754  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.140976 cl_acc 1.000 136.226sec(train) 5.983sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 57 tst: l 0.924 a 0.764  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.172sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 58 tr: l 0.910 a 0.761  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.139567 cl_acc 1.000 144.351sec(train) 8.343sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 58 tst: l 0.915 a 0.764  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.534sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 59 tr: l 0.910 a 0.758  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.138171 cl_acc 1.000 140.501sec(train) 6.715sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 59 tst: l 0.906 a 0.769  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.287sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 60 tr: l 0.898 a 0.764  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.136789 cl_acc 1.000 136.000sec(train) 6.609sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 60 tst: l 0.913 a 0.765  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.165sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 61 tr: l 0.898 a 0.764  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.135421 cl_acc 1.000 141.217sec(train) 6.220sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 61 tst: l 0.903 a 0.770  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.158sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 62 tr: l 0.890 a 0.767  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.134067 cl_acc 1.000 134.802sec(train) 6.516sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 62 tst: l 0.915 a 0.767  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.154sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 63 tr: l 0.896 a 0.763  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.132726 cl_acc 1.000 148.696sec(train) 6.420sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 63 tst: l 0.891 a 0.773  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.387sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 64 tr: l 0.888 a 0.766  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.131399 cl_acc 1.000 135.225sec(train) 6.370sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 64 tst: l 0.891 a 0.770  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.184sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 65 tr: l 0.870 a 0.770  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.130085 cl_acc 1.000 134.279sec(train) 5.885sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 65 tst: l 0.874 a 0.774  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.122sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 66 tr: l 0.885 a 0.767  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.128784 cl_acc 1.000 156.240sec(train) 5.837sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 66 tst: l 0.876 a 0.774  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.337sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 67 tr: l 0.881 a 0.768  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.127496 cl_acc 1.000 136.987sec(train) 6.397sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 67 tst: l 0.889 a 0.774  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.278sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 68 tr: l 0.887 a 0.766  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.126221 cl_acc 1.000 135.835sec(train) 5.695sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 68 tst: l 0.896 a 0.768  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.128sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 69 tr: l 0.874 a 0.771  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.124959 cl_acc 1.000 139.315sec(train) 5.714sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 69 tst: l 0.881 a 0.774  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.192sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 70 tr: l 0.884 a 0.768  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.123710 cl_acc 1.000 138.697sec(train) 7.536sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 70 tst: l 0.902 a 0.769  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.462sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 71 tr: l 0.867 a 0.774  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.122473 cl_acc 1.000 149.992sec(train) 6.298sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 71 tst: l 0.891 a 0.771  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.249sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 72 tr: l 0.865 a 0.774  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.121248 cl_acc 1.000 134.453sec(train) 6.283sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 72 tst: l 0.887 a 0.772  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.133sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 73 tr: l 0.846 a 0.779  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.120035 cl_acc 1.000 135.362sec(train) 5.786sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 73 tst: l 0.872 a 0.777  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.139sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 74 tr: l 0.859 a 0.775  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.118835 cl_acc 1.000 142.146sec(train) 6.223sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 74 tst: l 0.886 a 0.773  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.353sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 75 tr: l 0.857 a 0.775  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.117647 cl_acc 1.000 134.531sec(train) 5.943sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 75 tst: l 0.873 a 0.773  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 76 tr: l 0.852 a 0.778  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.116470 cl_acc 1.000 140.926sec(train) 6.367sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 76 tst: l 0.868 a 0.777  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.148sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 77 tr: l 0.836 a 0.782  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.115305 cl_acc 1.000 133.550sec(train) 5.940sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 77 tst: l 0.869 a 0.776  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.136sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 78 tr: l 0.854 a 0.776  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.114152 cl_acc 1.000 136.716sec(train) 7.132sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 78 tst: l 0.866 a 0.776  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.418sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 79 tr: l 0.833 a 0.782  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.113011 cl_acc 1.000 133.784sec(train) 7.549sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 79 tst: l 0.864 a 0.778  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.373sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 80 tr: l 0.845 a 0.779  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.111881 cl_acc 1.000 157.134sec(train) 7.429sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 80 tst: l 0.856 a 0.781  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.399sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 81 tr: l 0.851 a 0.777  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.110762 cl_acc 1.000 138.686sec(train) 7.474sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 81 tst: l 0.859 a 0.778  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.486sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 82 tr: l 0.837 a 0.780  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.109654 cl_acc 1.000 135.781sec(train) 7.389sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 82 tst: l 0.839 a 0.785  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.452sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 83 tr: l 0.822 a 0.786  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.108558 cl_acc 1.000 135.900sec(train) 7.619sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 83 tst: l 0.866 a 0.778  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.508sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 84 tr: l 0.838 a 0.782  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.107472 cl_acc 1.000 141.913sec(train) 7.016sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 84 tst: l 0.872 a 0.779  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.425sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 85 tr: l 0.833 a 0.781  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.106398 cl_acc 1.000 144.506sec(train) 7.629sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 85 tst: l 0.872 a 0.778  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.371sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 86 tr: l 0.809 a 0.789  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.105334 cl_acc 1.000 144.279sec(train) 6.566sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 86 tst: l 0.828 a 0.786  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.233sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 87 tr: l 0.812 a 0.788  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.104280 cl_acc 1.000 154.079sec(train) 7.094sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 87 tst: l 0.858 a 0.779  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.351sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 88 tr: l 0.821 a 0.785  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.103237 cl_acc 1.000 136.401sec(train) 6.370sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 88 tst: l 0.853 a 0.781  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.361sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 89 tr: l 0.821 a 0.784  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.102205 cl_acc 1.000 136.053sec(train) 6.155sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 89 tst: l 0.832 a 0.789  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.128sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 90 tr: l 0.802 a 0.790  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.101183 cl_acc 1.000 144.546sec(train) 5.905sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 90 tst: l 0.832 a 0.787  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.202sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 91 tr: l 0.806 a 0.789  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.100171 cl_acc 1.000 136.459sec(train) 5.891sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 91 tst: l 0.844 a 0.785  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.252sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 92 tr: l 0.816 a 0.786  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.099169 cl_acc 1.000 135.400sec(train) 6.002sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 92 tst: l 0.857 a 0.782  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.152sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 93 tr: l 0.811 a 0.788  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.098178 cl_acc 1.000 155.062sec(train) 7.865sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 93 tst: l 0.816 a 0.791  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.476sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 94 tr: l 0.795 a 0.793  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.097196 cl_acc 1.000 142.005sec(train) 5.863sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 94 tst: l 0.852 a 0.783  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.201sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 95 tr: l 0.794 a 0.794  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.096224 cl_acc 1.000 143.050sec(train) 5.899sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 95 tst: l 0.828 a 0.788  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.172sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 96 tr: l 0.798 a 0.791  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.095262 cl_acc 1.000 136.997sec(train) 5.869sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 96 tst: l 0.839 a 0.787  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.164sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 97 tr: l 0.797 a 0.790  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.094309 cl_acc 1.000 139.308sec(train) 5.925sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 97 tst: l 0.849 a 0.784  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.266sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 98 tr: l 0.777 a 0.798  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.093366 cl_acc 1.000 141.552sec(train) 7.324sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 98 tst: l 0.822 a 0.789  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.181sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 99 tr: l 0.782 a 0.796  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.092432 cl_acc 1.000 140.324sec(train) 6.313sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 99 tst: l 0.860 a 0.784  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.362sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 100 tr: l 0.760 a 0.803  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.091508 cl_acc 1.000 139.887sec(train) 6.440sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 100 tst: l 0.822 a 0.789  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.410sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 101 tr: l 0.784 a 0.794  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.090593 cl_acc 1.000 158.414sec(train) 6.111sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 101 tst: l 0.840 a 0.788  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.151sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 102 tr: l 0.781 a 0.795  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.089687 cl_acc 1.000 141.328sec(train) 6.898sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 102 tst: l 0.811 a 0.790  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.176sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 103 tr: l 0.784 a 0.794  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.088790 cl_acc 1.000 135.324sec(train) 6.130sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 103 tst: l 0.838 a 0.785  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.281sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 104 tr: l 0.788 a 0.793  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.087902 cl_acc 1.000 134.193sec(train) 6.136sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 104 tst: l 0.810 a 0.794  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.185sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 105 tr: l 0.778 a 0.796  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.087023 cl_acc 1.000 145.183sec(train) 5.871sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 105 tst: l 0.817 a 0.793  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.173sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 106 tr: l 0.774 a 0.798  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.086153 cl_acc 1.000 155.527sec(train) 6.748sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 106 tst: l 0.810 a 0.793  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.250sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 107 tr: l 0.762 a 0.799  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.085292 cl_acc 1.000 138.315sec(train) 5.888sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 107 tst: l 0.808 a 0.795  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.129sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 108 tr: l 0.757 a 0.803  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.084439 cl_acc 1.000 136.541sec(train) 6.355sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 108 tst: l 0.809 a 0.795  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.262sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 109 tr: l 0.768 a 0.799  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.083594 cl_acc 1.000 134.620sec(train) 7.494sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 109 tst: l 0.824 a 0.792  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.496sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 110 tr: l 0.754 a 0.804  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.082758 cl_acc 1.000 136.080sec(train) 7.517sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 110 tst: l 0.819 a 0.790  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.535sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 111 tr: l 0.752 a 0.803  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.081931 cl_acc 1.000 149.071sec(train) 6.254sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 111 tst: l 0.810 a 0.793  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.168sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 112 tr: l 0.753 a 0.805  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.081111 cl_acc 1.000 139.505sec(train) 6.719sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 112 tst: l 0.813 a 0.793  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.287sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 113 tr: l 0.741 a 0.805  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.080300 cl_acc 1.000 157.419sec(train) 9.019sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 113 tst: l 0.803 a 0.793  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.582sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 114 tr: l 0.754 a 0.803  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.079497 cl_acc 1.000 143.230sec(train) 6.461sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 114 tst: l 0.820 a 0.792  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.171sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 115 tr: l 0.747 a 0.806  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.078702 cl_acc 1.000 144.591sec(train) 5.975sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 115 tst: l 0.817 a 0.795  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.169sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 116 tr: l 0.738 a 0.808  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.077915 cl_acc 1.000 139.430sec(train) 6.160sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 116 tst: l 0.807 a 0.794  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.174sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 117 tr: l 0.730 a 0.810  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.077136 cl_acc 1.000 146.331sec(train) 6.118sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 117 tst: l 0.801 a 0.797  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.203sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 118 tr: l 0.737 a 0.809  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.076365 cl_acc 1.000 157.225sec(train) 5.969sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 118 tst: l 0.820 a 0.792  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.182sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 119 tr: l 0.734 a 0.808  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.075601 cl_acc 1.000 141.074sec(train) 5.813sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 119 tst: l 0.805 a 0.794  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.142sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 120 tr: l 0.738 a 0.806  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.074845 cl_acc 1.000 135.610sec(train) 6.149sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 120 tst: l 0.792 a 0.798  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.208sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 121 tr: l 0.729 a 0.808  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.074097 cl_acc 1.000 135.570sec(train) 5.888sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 121 tst: l 0.809 a 0.794  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.156sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 122 tr: l 0.737 a 0.807  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.073356 cl_acc 1.000 136.474sec(train) 6.017sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 122 tst: l 0.786 a 0.796  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.155sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 123 tr: l 0.730 a 0.811  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.072622 cl_acc 1.000 143.560sec(train) 6.727sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 123 tst: l 0.783 a 0.799  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.204sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 124 tr: l 0.723 a 0.811  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.071896 cl_acc 1.000 142.221sec(train) 7.335sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 124 tst: l 0.806 a 0.794  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.524sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 125 tr: l 0.711 a 0.815  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.071177 cl_acc 1.000 136.806sec(train) 6.279sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 125 tst: l 0.800 a 0.794  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.186sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 126 tr: l 0.717 a 0.812  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.070465 cl_acc 1.000 157.562sec(train) 5.845sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 126 tst: l 0.797 a 0.797  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.149sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 127 tr: l 0.713 a 0.814  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.069761 cl_acc 1.000 147.208sec(train) 6.005sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 127 tst: l 0.778 a 0.800  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.180sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 128 tr: l 0.711 a 0.815  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.069063 cl_acc 1.000 145.518sec(train) 7.492sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 128 tst: l 0.797 a 0.797  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.469sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 129 tr: l 0.712 a 0.814  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.068372 cl_acc 1.000 149.199sec(train) 7.533sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 129 tst: l 0.790 a 0.797  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.480sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 130 tr: l 0.711 a 0.813  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.067689 cl_acc 1.000 142.608sec(train) 5.965sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 130 tst: l 0.774 a 0.802  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.164sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 131 tr: l 0.714 a 0.813  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.067012 cl_acc 1.000 144.315sec(train) 7.652sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 131 tst: l 0.785 a 0.797  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.369sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 132 tr: l 0.685 a 0.822  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.066342 cl_acc 1.000 135.853sec(train) 7.889sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 132 tst: l 0.788 a 0.800  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.523sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 133 tr: l 0.694 a 0.819  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.065678 cl_acc 1.000 143.375sec(train) 6.146sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 133 tst: l 0.795 a 0.801  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.157sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 134 tr: l 0.708 a 0.815  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.065021 cl_acc 1.000 138.173sec(train) 7.690sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 134 tst: l 0.788 a 0.799  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.471sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 135 tr: l 0.701 a 0.816  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.064371 cl_acc 1.000 136.284sec(train) 5.918sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 135 tst: l 0.787 a 0.797  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.140sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 136 tr: l 0.699 a 0.817  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.063727 cl_acc 1.000 137.582sec(train) 6.561sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 136 tst: l 0.767 a 0.801  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.263sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 137 tr: l 0.695 a 0.819  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.063090 cl_acc 1.000 136.504sec(train) 8.454sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 137 tst: l 0.775 a 0.800  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.672sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 138 tr: l 0.672 a 0.825  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.062459 cl_acc 1.000 136.687sec(train) 6.719sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 138 tst: l 0.770 a 0.803  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.411sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 139 tr: l 0.700 a 0.818  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.061835 cl_acc 1.000 139.094sec(train) 6.742sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 139 tst: l 0.775 a 0.803  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.227sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 140 tr: l 0.680 a 0.822  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.061216 cl_acc 1.000 141.683sec(train) 5.935sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 140 tst: l 0.763 a 0.803  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.176sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 141 tr: l 0.668 a 0.826  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.060604 cl_acc 1.000 142.532sec(train) 8.031sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 141 tst: l 0.781 a 0.800  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.584sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 142 tr: l 0.693 a 0.820  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.059998 cl_acc 1.000 151.100sec(train) 6.799sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 142 tst: l 0.764 a 0.806  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.176sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 143 tr: l 0.687 a 0.820  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.059398 cl_acc 1.000 143.858sec(train) 6.048sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 143 tst: l 0.780 a 0.800  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.141sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 144 tr: l 0.677 a 0.824  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.058804 cl_acc 1.000 135.109sec(train) 6.020sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 144 tst: l 0.781 a 0.799  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.484sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 145 tr: l 0.669 a 0.827  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.058216 cl_acc 1.000 135.882sec(train) 5.969sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 145 tst: l 0.780 a 0.801  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.135sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 146 tr: l 0.670 a 0.826  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.057634 cl_acc 1.000 135.304sec(train) 7.335sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 146 tst: l 0.779 a 0.803  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.449sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 147 tr: l 0.669 a 0.825  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.057058 cl_acc 1.000 135.642sec(train) 6.814sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 147 tst: l 0.774 a 0.802  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.339sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 148 tr: l 0.679 a 0.824  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.056487 cl_acc 1.000 150.858sec(train) 5.979sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 148 tst: l 0.769 a 0.805  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.255sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 149 tr: l 0.661 a 0.827  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.055922 cl_acc 1.000 138.637sec(train) 6.025sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 149 tst: l 0.780 a 0.801  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.175sec\n",
      "result written at output/results.pickle\n",
      "---train cluster Ended in 6.78 hour (24401.680 sec) \n",
      "---------------------------------DFCA, lr: 0.25, seed: 4506---------------------------------\n",
      "config: {'m': 100, 'm_test': 20, 'p': 2, 'n': 1000, 'participation_rate': 1, '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:1754495485.059969  926711 gpu_device.cc:2019] Created device /job:localhost/replica:0/task:0/device:GPU:0 with 18963 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": [
      "finding good initializer from train data\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-08-06 17:51:25.282665: W tensorflow/c/c_api.cc:305] Operation '{name:'softmax_linear/biases/Assign' id:221 op device:{requested: '/device:CPU:0', assigned: ''} def:{{{node softmax_linear/biases/Assign}} = Assign[T=DT_FLOAT, _class=[\"loc:@softmax_linear/biases\"], _has_manual_control_dependencies=true, use_locking=true, validate_shape=true, _device=\"/device:CPU:0\"](softmax_linear/biases, softmax_linear/biases/Initializer/Const)}}' was changed by setting attribute after it was run by a session. This mutation will have no effect, and will trigger an error in the future. Either don't modify nodes after running them or create a new session.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch -1 tr: l 4.676 a 0.101  clct[np.int64(18), np.int64(82)] ans[np.int64(50), np.int64(50)] cl_acc 0.640 8.554sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-08-06 17:51:33.965432: W tensorflow/c/c_api.cc:305] Operation '{name:'softmax_linear/biases/Assign' id:221 op device:{requested: '/device:CPU:0', assigned: ''} def:{{{node softmax_linear/biases/Assign}} = Assign[T=DT_FLOAT, _class=[\"loc:@softmax_linear/biases\"], _has_manual_control_dependencies=true, use_locking=true, validate_shape=true, _device=\"/device:CPU:0\"](softmax_linear/biases, softmax_linear/biases/Initializer/Const)}}' was changed by setting attribute after it was run by a session. This mutation will have no effect, and will trigger an error in the future. Either don't modify nodes after running them or create a new session.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch -1 tr: l 4.677 a 0.106  clct[np.int64(29), np.int64(71)] ans[np.int64(50), np.int64(50)] cl_acc 0.550 6.901sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-08-06 17:51:40.992364: W tensorflow/c/c_api.cc:305] Operation '{name:'softmax_linear/biases/Assign' id:221 op device:{requested: '/device:CPU:0', assigned: ''} def:{{{node softmax_linear/biases/Assign}} = Assign[T=DT_FLOAT, _class=[\"loc:@softmax_linear/biases\"], _has_manual_control_dependencies=true, use_locking=true, validate_shape=true, _device=\"/device:CPU:0\"](softmax_linear/biases, softmax_linear/biases/Initializer/Const)}}' was changed by setting attribute after it was run by a session. This mutation will have no effect, and will trigger an error in the future. Either don't modify nodes after running them or create a new session.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch -1 tr: l 4.674 a 0.098  clct[np.int64(86), np.int64(14)] ans[np.int64(50), np.int64(50)] cl_acc 0.640 6.889sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-08-06 17:51:47.999463: W tensorflow/c/c_api.cc:305] Operation '{name:'softmax_linear/biases/Assign' id:221 op device:{requested: '/device:CPU:0', assigned: ''} def:{{{node softmax_linear/biases/Assign}} = Assign[T=DT_FLOAT, _class=[\"loc:@softmax_linear/biases\"], _has_manual_control_dependencies=true, use_locking=true, validate_shape=true, _device=\"/device:CPU:0\"](softmax_linear/biases, softmax_linear/biases/Initializer/Const)}}' was changed by setting attribute after it was run by a session. This mutation will have no effect, and will trigger an error in the future. Either don't modify nodes after running them or create a new session.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch -1 tr: l 4.675 a 0.105  clct[np.int64(60), np.int64(40)] ans[np.int64(50), np.int64(50)] cl_acc 0.640 6.147sec\n",
      "found good initializer\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch -1 tr: l 4.675 a 0.106  clct[np.int64(58), np.int64(42)] ans[np.int64(50), np.int64(50)] cl_acc 0.620 6.712sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch -1 tst: l 4.675 a 0.107  clct[np.int64(7), np.int64(13)] ans[np.int64(10), np.int64(10)] cl_acc 0.550 1.499sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0 tr: l 3.788 a 0.226  clct[np.int64(40), np.int64(60)] ans[np.int64(50), np.int64(50)] lr 0.250000 cl_acc 0.680 155.979sec(train) 6.454sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0 tst: l 3.762 a 0.255  clct[np.int64(11), np.int64(9)] ans[np.int64(10), np.int64(10)] cl_acc 0.550 1.378sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1 tr: l 3.123 a 0.296  clct[np.int64(56), np.int64(44)] ans[np.int64(50), np.int64(50)] lr 0.247500 cl_acc 0.740 153.425sec(train) 7.667sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1 tst: l 3.101 a 0.317  clct[np.int64(13), np.int64(7)] ans[np.int64(10), np.int64(10)] cl_acc 0.750 1.419sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2 tr: l 2.606 a 0.353  clct[np.int64(55), np.int64(45)] ans[np.int64(50), np.int64(50)] lr 0.245025 cl_acc 0.770 168.825sec(train) 7.377sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2 tst: l 2.577 a 0.372  clct[np.int64(11), np.int64(9)] ans[np.int64(10), np.int64(10)] cl_acc 0.850 1.222sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3 tr: l 2.252 a 0.395  clct[np.int64(51), np.int64(49)] ans[np.int64(50), np.int64(50)] lr 0.242575 cl_acc 0.910 158.640sec(train) 6.874sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3 tst: l 2.175 a 0.438  clct[np.int64(11), np.int64(9)] ans[np.int64(10), np.int64(10)] cl_acc 0.950 1.355sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4 tr: l 1.937 a 0.454  clct[np.int64(51), np.int64(49)] ans[np.int64(50), np.int64(50)] lr 0.240149 cl_acc 0.990 156.771sec(train) 7.101sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4 tst: l 1.843 a 0.498  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.429sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5 tr: l 1.751 a 0.494  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.237748 cl_acc 1.000 158.972sec(train) 6.565sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5 tst: l 1.648 a 0.537  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.359sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6 tr: l 1.612 a 0.523  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.235370 cl_acc 1.000 157.782sec(train) 6.404sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6 tst: l 1.497 a 0.568  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.170sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7 tr: l 1.488 a 0.558  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.233016 cl_acc 1.000 169.289sec(train) 7.625sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7 tst: l 1.385 a 0.596  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.421sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8 tr: l 1.416 a 0.578  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.230686 cl_acc 1.000 154.983sec(train) 6.503sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8 tst: l 1.318 a 0.613  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.147sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9 tr: l 1.363 a 0.590  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.228379 cl_acc 1.000 152.689sec(train) 7.231sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9 tst: l 1.249 a 0.634  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.325sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10 tr: l 1.307 a 0.611  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.226096 cl_acc 1.000 156.684sec(train) 8.680sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10 tst: l 1.207 a 0.646  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.843sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11 tr: l 1.284 a 0.620  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.223835 cl_acc 1.000 166.887sec(train) 6.257sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11 tst: l 1.179 a 0.656  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.389sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12 tr: l 1.261 a 0.628  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.221596 cl_acc 1.000 150.360sec(train) 6.046sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12 tst: l 1.173 a 0.661  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.180sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13 tr: l 1.236 a 0.638  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.219380 cl_acc 1.000 150.934sec(train) 6.792sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13 tst: l 1.114 a 0.681  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.157sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14 tr: l 1.212 a 0.646  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.217186 cl_acc 1.000 162.779sec(train) 7.555sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14 tst: l 1.137 a 0.673  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.508sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15 tr: l 1.190 a 0.657  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.215015 cl_acc 1.000 165.149sec(train) 7.631sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15 tst: l 1.102 a 0.689  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.591sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16 tr: l 1.174 a 0.664  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.212864 cl_acc 1.000 150.069sec(train) 7.606sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16 tst: l 1.110 a 0.689  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.352sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17 tr: l 1.170 a 0.666  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.210736 cl_acc 1.000 157.840sec(train) 6.005sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17 tst: l 1.103 a 0.691  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.218sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18 tr: l 1.144 a 0.673  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.208628 cl_acc 1.000 167.187sec(train) 7.272sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18 tst: l 1.063 a 0.706  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.622sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19 tr: l 1.149 a 0.675  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.206542 cl_acc 1.000 158.301sec(train) 7.105sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19 tst: l 1.069 a 0.705  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.308sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20 tr: l 1.122 a 0.687  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.204477 cl_acc 1.000 151.349sec(train) 8.228sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20 tst: l 1.058 a 0.711  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.723sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21 tr: l 1.130 a 0.685  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.202432 cl_acc 1.000 171.939sec(train) 6.978sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21 tst: l 1.056 a 0.714  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.490sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22 tr: l 1.115 a 0.689  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.200408 cl_acc 1.000 149.697sec(train) 6.840sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22 tst: l 1.057 a 0.712  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.416sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23 tr: l 1.110 a 0.693  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.198404 cl_acc 1.000 157.987sec(train) 6.372sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23 tst: l 1.037 a 0.719  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.184sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24 tr: l 1.106 a 0.695  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.196420 cl_acc 1.000 168.231sec(train) 6.957sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24 tst: l 1.044 a 0.716  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.542sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25 tr: l 1.097 a 0.698  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.194455 cl_acc 1.000 153.789sec(train) 7.016sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25 tst: l 1.024 a 0.720  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.243sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 26 tr: l 1.095 a 0.701  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.192511 cl_acc 1.000 150.664sec(train) 6.758sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 26 tst: l 1.025 a 0.726  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.150sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 27 tr: l 1.070 a 0.707  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.190586 cl_acc 1.000 149.111sec(train) 6.875sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 27 tst: l 1.003 a 0.731  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.202sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 28 tr: l 1.083 a 0.704  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.188680 cl_acc 1.000 149.815sec(train) 5.941sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 28 tst: l 1.033 a 0.724  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.427sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 29 tr: l 1.080 a 0.706  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.186793 cl_acc 1.000 165.692sec(train) 6.369sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 29 tst: l 0.993 a 0.733  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.128sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 30 tr: l 1.057 a 0.713  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.184925 cl_acc 1.000 148.724sec(train) 6.377sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 30 tst: l 1.009 a 0.735  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.161sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 31 tr: l 1.059 a 0.714  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.183076 cl_acc 1.000 148.928sec(train) 6.657sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 31 tst: l 0.990 a 0.736  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.387sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 32 tr: l 1.051 a 0.715  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.181245 cl_acc 1.000 148.925sec(train) 6.772sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 32 tst: l 1.023 a 0.730  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.184sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 33 tr: l 1.033 a 0.721  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.179433 cl_acc 1.000 152.994sec(train) 7.319sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 33 tst: l 0.968 a 0.746  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.556sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 34 tr: l 1.034 a 0.720  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.177638 cl_acc 1.000 157.916sec(train) 7.073sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 34 tst: l 0.983 a 0.741  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.523sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 35 tr: l 1.029 a 0.723  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.175862 cl_acc 1.000 148.017sec(train) 5.792sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 35 tst: l 0.969 a 0.741  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.424sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 36 tr: l 1.017 a 0.726  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.174103 cl_acc 1.000 149.242sec(train) 7.413sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 36 tst: l 0.976 a 0.741  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.393sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 37 tr: l 1.010 a 0.728  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.172362 cl_acc 1.000 168.984sec(train) 7.417sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 37 tst: l 0.988 a 0.740  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.475sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 38 tr: l 1.030 a 0.723  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.170639 cl_acc 1.000 158.464sec(train) 7.445sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 38 tst: l 0.967 a 0.750  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.530sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 39 tr: l 1.016 a 0.726  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.168932 cl_acc 1.000 148.835sec(train) 7.342sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 39 tst: l 0.971 a 0.746  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.495sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 40 tr: l 0.988 a 0.735  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.167243 cl_acc 1.000 156.663sec(train) 8.618sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 40 tst: l 0.966 a 0.747  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.491sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 41 tr: l 1.003 a 0.731  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.165571 cl_acc 1.000 155.174sec(train) 8.535sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 41 tst: l 0.931 a 0.757  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.301sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 42 tr: l 0.978 a 0.737  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.163915 cl_acc 1.000 152.325sec(train) 8.188sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 42 tst: l 0.967 a 0.749  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.829sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 43 tr: l 0.994 a 0.734  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.162276 cl_acc 1.000 157.524sec(train) 7.852sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 43 tst: l 0.947 a 0.752  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.509sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 44 tr: l 0.990 a 0.736  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.160653 cl_acc 1.000 158.885sec(train) 7.871sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 44 tst: l 0.956 a 0.751  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.765sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 45 tr: l 0.979 a 0.739  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.159046 cl_acc 1.000 159.093sec(train) 6.555sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 45 tst: l 0.943 a 0.755  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.346sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 46 tr: l 0.968 a 0.744  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.157456 cl_acc 1.000 154.254sec(train) 7.333sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 46 tst: l 0.939 a 0.757  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.544sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 47 tr: l 0.956 a 0.746  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.155881 cl_acc 1.000 163.308sec(train) 7.889sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 47 tst: l 0.943 a 0.754  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.599sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 48 tr: l 0.963 a 0.745  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.154323 cl_acc 1.000 151.682sec(train) 7.344sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 48 tst: l 0.945 a 0.756  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.445sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 49 tr: l 0.953 a 0.749  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.152779 cl_acc 1.000 151.476sec(train) 7.397sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 49 tst: l 0.925 a 0.762  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.361sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 50 tr: l 0.970 a 0.742  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.151252 cl_acc 1.000 152.622sec(train) 8.021sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 50 tst: l 0.935 a 0.757  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.701sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 51 tr: l 0.958 a 0.746  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.149739 cl_acc 1.000 155.353sec(train) 7.393sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 51 tst: l 0.929 a 0.759  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.343sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 52 tr: l 0.938 a 0.751  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.148242 cl_acc 1.000 156.403sec(train) 8.070sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 52 tst: l 0.913 a 0.762  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.614sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 53 tr: l 0.925 a 0.756  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.146759 cl_acc 1.000 155.014sec(train) 5.936sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 53 tst: l 0.906 a 0.765  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.216sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 54 tr: l 0.924 a 0.757  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.145292 cl_acc 1.000 149.860sec(train) 5.844sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 54 tst: l 0.929 a 0.760  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.381sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 55 tr: l 0.948 a 0.749  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.143839 cl_acc 1.000 148.961sec(train) 7.615sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 55 tst: l 0.933 a 0.761  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.521sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 56 tr: l 0.923 a 0.755  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.142400 cl_acc 1.000 160.361sec(train) 6.799sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 56 tst: l 0.899 a 0.767  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.147sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 57 tr: l 0.920 a 0.757  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.140976 cl_acc 1.000 175.640sec(train) 6.879sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 57 tst: l 0.907 a 0.767  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.386sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 58 tr: l 0.914 a 0.760  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.139567 cl_acc 1.000 174.596sec(train) 7.531sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 58 tst: l 0.907 a 0.767  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.599sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 59 tr: l 0.918 a 0.756  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.138171 cl_acc 1.000 172.225sec(train) 6.430sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 59 tst: l 0.901 a 0.768  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.271sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 60 tr: l 0.896 a 0.765  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.136789 cl_acc 1.000 159.114sec(train) 8.631sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 60 tst: l 0.913 a 0.765  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.694sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 61 tr: l 0.899 a 0.763  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.135421 cl_acc 1.000 157.803sec(train) 7.600sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 61 tst: l 0.926 a 0.763  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.468sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 62 tr: l 0.893 a 0.766  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.134067 cl_acc 1.000 150.610sec(train) 8.321sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 62 tst: l 0.897 a 0.771  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.754sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 63 tr: l 0.902 a 0.761  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.132726 cl_acc 1.000 151.004sec(train) 8.050sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 63 tst: l 0.884 a 0.771  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.481sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 64 tr: l 0.908 a 0.758  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.131399 cl_acc 1.000 148.775sec(train) 8.603sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 64 tst: l 0.900 a 0.773  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.853sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 65 tr: l 0.892 a 0.765  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.130085 cl_acc 1.000 158.636sec(train) 8.485sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 65 tst: l 0.894 a 0.772  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.877sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 66 tr: l 0.902 a 0.761  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.128784 cl_acc 1.000 159.010sec(train) 7.967sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 66 tst: l 0.897 a 0.770  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.634sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 67 tr: l 0.887 a 0.766  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.127496 cl_acc 1.000 149.996sec(train) 9.535sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 67 tst: l 0.866 a 0.777  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.655sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 68 tr: l 0.886 a 0.769  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.126221 cl_acc 1.000 153.969sec(train) 8.019sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 68 tst: l 0.872 a 0.777  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.629sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 69 tr: l 0.872 a 0.772  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.124959 cl_acc 1.000 152.421sec(train) 8.594sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 69 tst: l 0.887 a 0.774  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.758sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 70 tr: l 0.877 a 0.768  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.123710 cl_acc 1.000 153.420sec(train) 7.704sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 70 tst: l 0.879 a 0.775  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.570sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 71 tr: l 0.889 a 0.766  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.122473 cl_acc 1.000 151.033sec(train) 7.874sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 71 tst: l 0.881 a 0.776  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.504sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 72 tr: l 0.882 a 0.768  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.121248 cl_acc 1.000 149.186sec(train) 5.894sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 72 tst: l 0.872 a 0.776  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.482sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 73 tr: l 0.856 a 0.776  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.120035 cl_acc 1.000 149.223sec(train) 5.962sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 73 tst: l 0.869 a 0.776  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.447sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 74 tr: l 0.841 a 0.780  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.118835 cl_acc 1.000 154.518sec(train) 8.019sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 74 tst: l 0.866 a 0.779  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.480sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 75 tr: l 0.872 a 0.771  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.117647 cl_acc 1.000 171.116sec(train) 8.921sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 75 tst: l 0.889 a 0.773  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.644sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 76 tr: l 0.858 a 0.776  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.116470 cl_acc 1.000 155.065sec(train) 8.139sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 76 tst: l 0.866 a 0.776  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.395sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 77 tr: l 0.853 a 0.777  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.115305 cl_acc 1.000 163.019sec(train) 8.407sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 77 tst: l 0.874 a 0.775  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.754sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 78 tr: l 0.836 a 0.781  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.114152 cl_acc 1.000 158.243sec(train) 7.757sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 78 tst: l 0.856 a 0.780  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.454sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 79 tr: l 0.846 a 0.780  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.113011 cl_acc 1.000 151.085sec(train) 8.061sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 79 tst: l 0.850 a 0.785  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.454sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 80 tr: l 0.849 a 0.778  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.111881 cl_acc 1.000 149.245sec(train) 7.479sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 80 tst: l 0.867 a 0.780  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.416sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 81 tr: l 0.859 a 0.775  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.110762 cl_acc 1.000 160.236sec(train) 7.784sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 81 tst: l 0.848 a 0.784  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.511sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 82 tr: l 0.841 a 0.780  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.109654 cl_acc 1.000 150.063sec(train) 7.455sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 82 tst: l 0.844 a 0.782  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.475sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 83 tr: l 0.816 a 0.787  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.108558 cl_acc 1.000 146.964sec(train) 5.975sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 83 tst: l 0.861 a 0.783  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.126sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 84 tr: l 0.808 a 0.790  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.107472 cl_acc 1.000 169.275sec(train) 7.216sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 84 tst: l 0.860 a 0.782  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.265sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 85 tr: l 0.825 a 0.784  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.106398 cl_acc 1.000 151.832sec(train) 5.771sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 85 tst: l 0.861 a 0.781  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.129sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 86 tr: l 0.817 a 0.787  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.105334 cl_acc 1.000 148.122sec(train) 5.861sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 86 tst: l 0.845 a 0.785  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.161sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 87 tr: l 0.808 a 0.789  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.104280 cl_acc 1.000 169.636sec(train) 5.863sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 87 tst: l 0.837 a 0.789  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.193sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 88 tr: l 0.835 a 0.780  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.103237 cl_acc 1.000 151.090sec(train) 5.776sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 88 tst: l 0.827 a 0.789  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.239sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 89 tr: l 0.819 a 0.786  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.102205 cl_acc 1.000 154.157sec(train) 5.809sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 89 tst: l 0.848 a 0.784  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.166sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 90 tr: l 0.818 a 0.786  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.101183 cl_acc 1.000 171.868sec(train) 7.441sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 90 tst: l 0.839 a 0.785  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.465sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 91 tr: l 0.810 a 0.790  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.100171 cl_acc 1.000 148.062sec(train) 7.460sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 91 tst: l 0.838 a 0.788  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.517sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 92 tr: l 0.802 a 0.790  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.099169 cl_acc 1.000 163.029sec(train) 8.160sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 92 tst: l 0.834 a 0.785  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.621sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 93 tr: l 0.803 a 0.790  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.098178 cl_acc 1.000 153.772sec(train) 8.972sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 93 tst: l 0.842 a 0.786  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.729sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 94 tr: l 0.789 a 0.795  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.097196 cl_acc 1.000 154.107sec(train) 7.672sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 94 tst: l 0.819 a 0.789  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.458sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 95 tr: l 0.802 a 0.789  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.096224 cl_acc 1.000 155.383sec(train) 7.562sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 95 tst: l 0.822 a 0.790  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.492sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 96 tr: l 0.790 a 0.794  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.095262 cl_acc 1.000 148.964sec(train) 7.773sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 96 tst: l 0.833 a 0.786  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.504sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 97 tr: l 0.795 a 0.792  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.094309 cl_acc 1.000 148.078sec(train) 7.467sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 97 tst: l 0.822 a 0.791  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.525sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 98 tr: l 0.806 a 0.789  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.093366 cl_acc 1.000 149.085sec(train) 6.101sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 98 tst: l 0.833 a 0.784  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.396sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 99 tr: l 0.774 a 0.798  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.092432 cl_acc 1.000 153.163sec(train) 7.711sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 99 tst: l 0.813 a 0.790  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.489sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 100 tr: l 0.791 a 0.794  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.091508 cl_acc 1.000 166.484sec(train) 7.835sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 100 tst: l 0.828 a 0.789  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.609sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 101 tr: l 0.782 a 0.796  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.090593 cl_acc 1.000 169.346sec(train) 7.943sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 101 tst: l 0.819 a 0.790  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.558sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 102 tr: l 0.772 a 0.801  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.089687 cl_acc 1.000 157.666sec(train) 8.443sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 102 tst: l 0.823 a 0.789  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.732sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 103 tr: l 0.789 a 0.795  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.088790 cl_acc 1.000 154.705sec(train) 9.034sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 103 tst: l 0.814 a 0.793  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.907sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 104 tr: l 0.756 a 0.805  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.087902 cl_acc 1.000 173.798sec(train) 8.087sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 104 tst: l 0.829 a 0.790  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.688sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 105 tr: l 0.778 a 0.795  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.087023 cl_acc 1.000 167.846sec(train) 8.024sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 105 tst: l 0.823 a 0.792  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.528sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 106 tr: l 0.769 a 0.798  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.086153 cl_acc 1.000 150.976sec(train) 7.773sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 106 tst: l 0.825 a 0.791  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.488sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 107 tr: l 0.765 a 0.801  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.085292 cl_acc 1.000 154.050sec(train) 8.431sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 107 tst: l 0.811 a 0.796  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.476sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 108 tr: l 0.758 a 0.804  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.084439 cl_acc 1.000 150.847sec(train) 7.496sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 108 tst: l 0.821 a 0.790  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.451sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 109 tr: l 0.772 a 0.797  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.083594 cl_acc 1.000 161.268sec(train) 7.817sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 109 tst: l 0.810 a 0.795  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.564sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 110 tr: l 0.758 a 0.802  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.082758 cl_acc 1.000 160.531sec(train) 7.628sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 110 tst: l 0.804 a 0.799  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.539sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 111 tr: l 0.764 a 0.799  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.081931 cl_acc 1.000 153.957sec(train) 5.750sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 111 tst: l 0.805 a 0.796  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.132sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 112 tr: l 0.755 a 0.804  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.081111 cl_acc 1.000 153.478sec(train) 6.631sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 112 tst: l 0.798 a 0.796  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.155sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 113 tr: l 0.752 a 0.805  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.080300 cl_acc 1.000 148.609sec(train) 6.357sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 113 tst: l 0.806 a 0.793  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.132sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 114 tr: l 0.747 a 0.807  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.079497 cl_acc 1.000 154.837sec(train) 5.978sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 114 tst: l 0.798 a 0.796  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.433sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 115 tr: l 0.737 a 0.809  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.078702 cl_acc 1.000 155.521sec(train) 7.938sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 115 tst: l 0.807 a 0.794  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.533sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 116 tr: l 0.732 a 0.810  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.077915 cl_acc 1.000 169.511sec(train) 7.366sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 116 tst: l 0.797 a 0.797  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.549sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 117 tr: l 0.734 a 0.809  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.077136 cl_acc 1.000 148.431sec(train) 7.506sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 117 tst: l 0.799 a 0.796  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.460sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 118 tr: l 0.738 a 0.808  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.076365 cl_acc 1.000 157.271sec(train) 6.652sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 118 tst: l 0.803 a 0.797  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.316sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 119 tr: l 0.737 a 0.808  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.075601 cl_acc 1.000 154.539sec(train) 6.129sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 119 tst: l 0.800 a 0.797  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.200sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 120 tr: l 0.723 a 0.812  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.074845 cl_acc 1.000 149.544sec(train) 5.947sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 120 tst: l 0.789 a 0.798  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.174sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 121 tr: l 0.720 a 0.813  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.074097 cl_acc 1.000 150.834sec(train) 7.318sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 121 tst: l 0.795 a 0.800  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.431sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 122 tr: l 0.718 a 0.811  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.073356 cl_acc 1.000 155.815sec(train) 7.609sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 122 tst: l 0.793 a 0.798  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.557sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 123 tr: l 0.721 a 0.813  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.072622 cl_acc 1.000 154.110sec(train) 8.828sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 123 tst: l 0.798 a 0.796  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.694sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 124 tr: l 0.713 a 0.814  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.071896 cl_acc 1.000 150.804sec(train) 8.903sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 124 tst: l 0.804 a 0.795  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.985sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 125 tr: l 0.726 a 0.811  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.071177 cl_acc 1.000 149.205sec(train) 7.996sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 125 tst: l 0.793 a 0.800  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.495sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 126 tr: l 0.700 a 0.818  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.070465 cl_acc 1.000 158.845sec(train) 7.571sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 126 tst: l 0.797 a 0.794  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.658sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 127 tr: l 0.724 a 0.811  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.069761 cl_acc 1.000 152.225sec(train) 8.450sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 127 tst: l 0.780 a 0.800  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.548sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 128 tr: l 0.715 a 0.813  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.069063 cl_acc 1.000 148.394sec(train) 7.244sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 128 tst: l 0.798 a 0.797  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.501sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 129 tr: l 0.704 a 0.816  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.068372 cl_acc 1.000 148.489sec(train) 7.405sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 129 tst: l 0.793 a 0.799  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.438sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 130 tr: l 0.718 a 0.814  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.067689 cl_acc 1.000 160.144sec(train) 7.263sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 130 tst: l 0.782 a 0.801  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.268sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 131 tr: l 0.690 a 0.820  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.067012 cl_acc 1.000 158.158sec(train) 7.413sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 131 tst: l 0.779 a 0.801  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.417sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 132 tr: l 0.702 a 0.818  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.066342 cl_acc 1.000 148.283sec(train) 7.781sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 132 tst: l 0.784 a 0.799  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.541sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 133 tr: l 0.712 a 0.814  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.065678 cl_acc 1.000 149.244sec(train) 7.540sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 133 tst: l 0.781 a 0.802  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.445sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 134 tr: l 0.701 a 0.817  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.065021 cl_acc 1.000 153.684sec(train) 7.544sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 134 tst: l 0.790 a 0.799  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.628sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 135 tr: l 0.705 a 0.816  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.064371 cl_acc 1.000 161.383sec(train) 8.406sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 135 tst: l 0.780 a 0.802  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.651sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 136 tr: l 0.676 a 0.824  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.063727 cl_acc 1.000 156.874sec(train) 7.472sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 136 tst: l 0.781 a 0.801  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.696sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 137 tr: l 0.691 a 0.820  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.063090 cl_acc 1.000 147.656sec(train) 7.470sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 137 tst: l 0.771 a 0.802  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.514sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 138 tr: l 0.709 a 0.814  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.062459 cl_acc 1.000 150.672sec(train) 7.617sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 138 tst: l 0.775 a 0.802  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.532sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 139 tr: l 0.693 a 0.818  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.061835 cl_acc 1.000 150.745sec(train) 7.898sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 139 tst: l 0.771 a 0.804  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.613sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 140 tr: l 0.691 a 0.819  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.061216 cl_acc 1.000 151.835sec(train) 7.641sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 140 tst: l 0.774 a 0.799  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.508sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 141 tr: l 0.686 a 0.821  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.060604 cl_acc 1.000 172.367sec(train) 8.297sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 141 tst: l 0.774 a 0.804  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.373sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 142 tr: l 0.686 a 0.821  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.059998 cl_acc 1.000 151.503sec(train) 7.845sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 142 tst: l 0.781 a 0.801  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.477sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 143 tr: l 0.686 a 0.821  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.059398 cl_acc 1.000 163.326sec(train) 6.570sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 143 tst: l 0.761 a 0.803  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.182sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 144 tr: l 0.676 a 0.824  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.058804 cl_acc 1.000 152.621sec(train) 6.795sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 144 tst: l 0.764 a 0.804  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.169sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 145 tr: l 0.664 a 0.826  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.058216 cl_acc 1.000 148.693sec(train) 7.280sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 145 tst: l 0.765 a 0.804  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.482sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 146 tr: l 0.677 a 0.824  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.057634 cl_acc 1.000 149.178sec(train) 8.826sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 146 tst: l 0.781 a 0.799  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.717sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 147 tr: l 0.678 a 0.823  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.057058 cl_acc 1.000 150.756sec(train) 7.758sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 147 tst: l 0.775 a 0.802  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.511sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 148 tr: l 0.662 a 0.827  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.056487 cl_acc 1.000 159.398sec(train) 8.488sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 148 tst: l 0.768 a 0.806  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.605sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 149 tr: l 0.669 a 0.825  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.055922 cl_acc 1.000 150.008sec(train) 7.811sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 149 tst: l 0.759 a 0.806  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.355sec\n",
      "result written at output/results.pickle\n",
      "---train cluster Ended in 6.88 hour (24765.310 sec) \n",
      "---------------------------------DFCA, lr: 0.25, seed: 4012---------------------------------\n",
      "config: {'m': 100, 'm_test': 20, 'p': 2, 'n': 1000, 'participation_rate': 1, '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:1754520250.283379  926711 gpu_device.cc:2019] Created device /job:localhost/replica:0/task:0/device:GPU:0 with 18963 MB memory:  -> device: 2, name: NVIDIA A100-SXM4-40GB, pci bus id: 0000:81:00.0, compute capability: 8.0\n",
      "2025-08-07 00:44:10.424808: W tensorflow/c/c_api.cc:305] Operation '{name:'softmax_linear/biases/Assign' id:221 op device:{requested: '/device:CPU:0', assigned: ''} def:{{{node softmax_linear/biases/Assign}} = Assign[T=DT_FLOAT, _class=[\"loc:@softmax_linear/biases\"], _has_manual_control_dependencies=true, use_locking=true, validate_shape=true, _device=\"/device:CPU:0\"](softmax_linear/biases, softmax_linear/biases/Initializer/Const)}}' was changed by setting attribute after it was run by a session. This mutation will have no effect, and will trigger an error in the future. Either don't modify nodes after running them or create a new session.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "finding good initializer from train data\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch -1 tr: l 4.674 a 0.102  clct[np.int64(8), np.int64(92)] ans[np.int64(50), np.int64(50)] cl_acc 0.580 7.024sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-08-07 00:44:17.556257: W tensorflow/c/c_api.cc:305] Operation '{name:'softmax_linear/biases/Assign' id:221 op device:{requested: '/device:CPU:0', assigned: ''} def:{{{node softmax_linear/biases/Assign}} = Assign[T=DT_FLOAT, _class=[\"loc:@softmax_linear/biases\"], _has_manual_control_dependencies=true, use_locking=true, validate_shape=true, _device=\"/device:CPU:0\"](softmax_linear/biases, softmax_linear/biases/Initializer/Const)}}' was changed by setting attribute after it was run by a session. This mutation will have no effect, and will trigger an error in the future. Either don't modify nodes after running them or create a new session.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch -1 tr: l 4.676 a 0.100  clct[np.int64(100), np.int64(0)] ans[np.int64(50), np.int64(50)] cl_acc 0.500 5.958sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-08-07 00:44:23.657731: W tensorflow/c/c_api.cc:305] Operation '{name:'softmax_linear/biases/Assign' id:221 op device:{requested: '/device:CPU:0', assigned: ''} def:{{{node softmax_linear/biases/Assign}} = Assign[T=DT_FLOAT, _class=[\"loc:@softmax_linear/biases\"], _has_manual_control_dependencies=true, use_locking=true, validate_shape=true, _device=\"/device:CPU:0\"](softmax_linear/biases, softmax_linear/biases/Initializer/Const)}}' was changed by setting attribute after it was run by a session. This mutation will have no effect, and will trigger an error in the future. Either don't modify nodes after running them or create a new session.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch -1 tr: l 4.673 a 0.099  clct[np.int64(100), np.int64(0)] ans[np.int64(50), np.int64(50)] cl_acc 0.500 5.939sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-08-07 00:44:29.736124: W tensorflow/c/c_api.cc:305] Operation '{name:'softmax_linear/biases/Assign' id:221 op device:{requested: '/device:CPU:0', assigned: ''} def:{{{node softmax_linear/biases/Assign}} = Assign[T=DT_FLOAT, _class=[\"loc:@softmax_linear/biases\"], _has_manual_control_dependencies=true, use_locking=true, validate_shape=true, _device=\"/device:CPU:0\"](softmax_linear/biases, softmax_linear/biases/Initializer/Const)}}' was changed by setting attribute after it was run by a session. This mutation will have no effect, and will trigger an error in the future. Either don't modify nodes after running them or create a new session.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch -1 tr: l 4.677 a 0.108  clct[np.int64(46), np.int64(54)] ans[np.int64(50), np.int64(50)] cl_acc 0.560 6.013sec\n",
      "found good initializer\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch -1 tr: l 4.677 a 0.107  clct[np.int64(47), np.int64(53)] ans[np.int64(50), np.int64(50)] cl_acc 0.550 6.454sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch -1 tst: l 4.677 a 0.109  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 0.600 1.529sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0 tr: l 3.795 a 0.224  clct[np.int64(25), np.int64(75)] ans[np.int64(50), np.int64(50)] lr 0.250000 cl_acc 0.550 152.802sec(train) 6.043sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0 tst: l 3.800 a 0.229  clct[np.int64(4), np.int64(16)] ans[np.int64(10), np.int64(10)] cl_acc 0.600 1.228sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1 tr: l 3.166 a 0.279  clct[np.int64(29), np.int64(71)] ans[np.int64(50), np.int64(50)] lr 0.247500 cl_acc 0.610 160.165sec(train) 6.066sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1 tst: l 3.134 a 0.301  clct[np.int64(7), np.int64(13)] ans[np.int64(10), np.int64(10)] cl_acc 0.650 1.179sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2 tr: l 2.656 a 0.333  clct[np.int64(29), np.int64(71)] ans[np.int64(50), np.int64(50)] lr 0.245025 cl_acc 0.670 159.427sec(train) 6.073sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2 tst: l 2.604 a 0.362  clct[np.int64(4), np.int64(16)] ans[np.int64(10), np.int64(10)] cl_acc 0.600 1.278sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3 tr: l 2.271 a 0.385  clct[np.int64(36), np.int64(64)] ans[np.int64(50), np.int64(50)] lr 0.242575 cl_acc 0.840 152.181sec(train) 6.187sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3 tst: l 2.198 a 0.421  clct[np.int64(7), np.int64(13)] ans[np.int64(10), np.int64(10)] cl_acc 0.850 1.270sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4 tr: l 1.980 a 0.441  clct[np.int64(48), np.int64(52)] ans[np.int64(50), np.int64(50)] lr 0.240149 cl_acc 0.980 163.889sec(train) 6.934sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4 tst: l 1.895 a 0.479  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.695sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5 tr: l 1.762 a 0.486  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.237748 cl_acc 1.000 165.825sec(train) 6.011sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5 tst: l 1.657 a 0.528  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.172sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6 tr: l 1.606 a 0.526  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.235370 cl_acc 1.000 161.750sec(train) 6.577sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6 tst: l 1.494 a 0.571  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.156sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7 tr: l 1.522 a 0.546  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.233016 cl_acc 1.000 153.534sec(train) 6.390sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7 tst: l 1.407 a 0.592  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.183sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8 tr: l 1.424 a 0.575  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.230686 cl_acc 1.000 162.661sec(train) 6.540sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8 tst: l 1.323 a 0.615  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.187sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9 tr: l 1.358 a 0.594  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.228379 cl_acc 1.000 172.812sec(train) 6.526sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9 tst: l 1.243 a 0.637  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.265sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10 tr: l 1.313 a 0.609  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.226096 cl_acc 1.000 158.773sec(train) 6.237sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10 tst: l 1.203 a 0.649  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.172sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11 tr: l 1.276 a 0.621  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.223835 cl_acc 1.000 148.086sec(train) 6.087sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11 tst: l 1.190 a 0.655  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.291sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12 tr: l 1.246 a 0.631  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.221596 cl_acc 1.000 154.486sec(train) 6.103sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12 tst: l 1.157 a 0.666  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.176sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13 tr: l 1.232 a 0.640  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.219380 cl_acc 1.000 162.125sec(train) 6.008sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13 tst: l 1.154 a 0.670  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.213sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14 tr: l 1.195 a 0.652  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.217186 cl_acc 1.000 155.077sec(train) 5.923sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14 tst: l 1.119 a 0.677  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.184sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15 tr: l 1.187 a 0.655  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.215015 cl_acc 1.000 156.259sec(train) 8.293sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15 tst: l 1.096 a 0.687  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.590sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16 tr: l 1.166 a 0.665  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.212864 cl_acc 1.000 156.375sec(train) 5.850sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16 tst: l 1.095 a 0.694  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.153sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17 tr: l 1.147 a 0.672  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.210736 cl_acc 1.000 159.149sec(train) 5.960sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17 tst: l 1.075 a 0.699  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.143sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18 tr: l 1.150 a 0.673  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.208628 cl_acc 1.000 155.778sec(train) 6.844sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18 tst: l 1.085 a 0.703  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.202sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19 tr: l 1.137 a 0.675  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.206542 cl_acc 1.000 148.874sec(train) 6.449sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19 tst: l 1.051 a 0.708  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.177sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20 tr: l 1.126 a 0.683  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.204477 cl_acc 1.000 161.218sec(train) 7.260sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20 tst: l 1.039 a 0.713  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.204sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21 tr: l 1.100 a 0.693  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.202432 cl_acc 1.000 155.825sec(train) 6.373sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21 tst: l 1.082 a 0.703  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.194sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22 tr: l 1.126 a 0.685  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.200408 cl_acc 1.000 154.271sec(train) 5.968sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22 tst: l 1.054 a 0.712  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.185sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23 tr: l 1.115 a 0.688  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.198404 cl_acc 1.000 166.509sec(train) 5.931sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23 tst: l 1.053 a 0.714  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.590sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24 tr: l 1.094 a 0.697  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.196420 cl_acc 1.000 163.926sec(train) 5.945sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24 tst: l 1.020 a 0.724  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.167sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25 tr: l 1.097 a 0.696  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.194455 cl_acc 1.000 173.949sec(train) 6.022sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25 tst: l 1.017 a 0.725  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.168sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 26 tr: l 1.072 a 0.705  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.192511 cl_acc 1.000 148.357sec(train) 6.018sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 26 tst: l 1.018 a 0.725  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.180sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 27 tr: l 1.068 a 0.708  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.190586 cl_acc 1.000 165.098sec(train) 5.982sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 27 tst: l 1.008 a 0.731  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.171sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 28 tr: l 1.070 a 0.706  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.188680 cl_acc 1.000 150.414sec(train) 5.978sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 28 tst: l 1.040 a 0.722  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.173sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 29 tr: l 1.045 a 0.716  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.186793 cl_acc 1.000 154.523sec(train) 5.997sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 29 tst: l 1.005 a 0.733  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.173sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 30 tr: l 1.044 a 0.715  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.184925 cl_acc 1.000 155.146sec(train) 5.731sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 30 tst: l 1.013 a 0.730  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.134sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 31 tr: l 1.047 a 0.714  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.183076 cl_acc 1.000 145.958sec(train) 5.756sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 31 tst: l 0.994 a 0.735  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.132sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 32 tr: l 1.043 a 0.717  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.181245 cl_acc 1.000 148.698sec(train) 5.861sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 32 tst: l 1.026 a 0.729  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.141sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 33 tr: l 1.045 a 0.717  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.179433 cl_acc 1.000 160.052sec(train) 5.884sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 33 tst: l 0.983 a 0.739  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.170sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 34 tr: l 1.030 a 0.723  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.177638 cl_acc 1.000 156.709sec(train) 5.912sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 34 tst: l 0.992 a 0.737  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.161sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 35 tr: l 1.009 a 0.730  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.175862 cl_acc 1.000 150.366sec(train) 5.896sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 35 tst: l 0.973 a 0.742  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.139sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 36 tr: l 1.031 a 0.724  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.174103 cl_acc 1.000 153.564sec(train) 5.866sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 36 tst: l 0.977 a 0.744  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.140sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 37 tr: l 1.029 a 0.725  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.172362 cl_acc 1.000 151.978sec(train) 5.847sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 37 tst: l 0.980 a 0.746  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.147sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 38 tr: l 1.007 a 0.731  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.170639 cl_acc 1.000 159.908sec(train) 5.831sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 38 tst: l 0.977 a 0.745  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.154sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 39 tr: l 1.000 a 0.734  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.168932 cl_acc 1.000 160.861sec(train) 5.755sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 39 tst: l 0.969 a 0.746  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.138sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 40 tr: l 0.998 a 0.735  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.167243 cl_acc 1.000 149.339sec(train) 5.884sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 40 tst: l 0.969 a 0.746  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.165sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 41 tr: l 0.977 a 0.740  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.165571 cl_acc 1.000 156.777sec(train) 5.928sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 41 tst: l 0.947 a 0.752  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.165sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 42 tr: l 0.988 a 0.736  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.163915 cl_acc 1.000 154.202sec(train) 5.892sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 42 tst: l 0.946 a 0.751  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.147sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 43 tr: l 0.983 a 0.739  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.162276 cl_acc 1.000 153.249sec(train) 5.816sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 43 tst: l 0.979 a 0.745  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.131sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 44 tr: l 0.982 a 0.738  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.160653 cl_acc 1.000 154.392sec(train) 5.773sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 44 tst: l 0.976 a 0.748  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.125sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 45 tr: l 0.952 a 0.749  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.159046 cl_acc 1.000 150.169sec(train) 5.747sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 45 tst: l 0.958 a 0.750  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.114sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 46 tr: l 0.980 a 0.738  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.157456 cl_acc 1.000 145.446sec(train) 5.788sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 46 tst: l 0.937 a 0.754  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.134sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 47 tr: l 0.969 a 0.745  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.155881 cl_acc 1.000 154.206sec(train) 5.960sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 47 tst: l 0.957 a 0.754  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.156sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 48 tr: l 0.958 a 0.745  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.154323 cl_acc 1.000 146.237sec(train) 5.777sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 48 tst: l 0.941 a 0.758  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.140sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 49 tr: l 0.943 a 0.752  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.152779 cl_acc 1.000 149.004sec(train) 5.806sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 49 tst: l 0.930 a 0.759  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 50 tr: l 0.937 a 0.753  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.151252 cl_acc 1.000 146.773sec(train) 5.933sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 50 tst: l 0.923 a 0.761  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.163sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 51 tr: l 0.942 a 0.752  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.149739 cl_acc 1.000 149.603sec(train) 5.831sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 51 tst: l 0.951 a 0.755  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.118sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 52 tr: l 0.946 a 0.750  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.148242 cl_acc 1.000 150.464sec(train) 5.898sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 52 tst: l 0.938 a 0.759  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.165sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 53 tr: l 0.956 a 0.748  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.146759 cl_acc 1.000 147.227sec(train) 5.898sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 53 tst: l 0.930 a 0.760  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.143sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 54 tr: l 0.933 a 0.753  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.145292 cl_acc 1.000 151.759sec(train) 5.891sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 54 tst: l 0.935 a 0.758  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.164sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 55 tr: l 0.910 a 0.760  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.143839 cl_acc 1.000 162.454sec(train) 5.992sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 55 tst: l 0.951 a 0.756  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.183sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 56 tr: l 0.917 a 0.758  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.142400 cl_acc 1.000 148.471sec(train) 5.905sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 56 tst: l 0.931 a 0.759  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.159sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 57 tr: l 0.919 a 0.757  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.140976 cl_acc 1.000 149.132sec(train) 5.756sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 57 tst: l 0.914 a 0.763  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 58 tr: l 0.914 a 0.759  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.139567 cl_acc 1.000 146.662sec(train) 5.847sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 58 tst: l 0.917 a 0.763  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.150sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 59 tr: l 0.910 a 0.761  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.138171 cl_acc 1.000 159.561sec(train) 5.829sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 59 tst: l 0.895 a 0.768  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.130sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 60 tr: l 0.896 a 0.766  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.136789 cl_acc 1.000 148.244sec(train) 5.911sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 60 tst: l 0.906 a 0.765  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.157sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 61 tr: l 0.900 a 0.764  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.135421 cl_acc 1.000 174.421sec(train) 5.956sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 61 tst: l 0.918 a 0.766  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.182sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 62 tr: l 0.900 a 0.765  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.134067 cl_acc 1.000 154.246sec(train) 5.951sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 62 tst: l 0.902 a 0.770  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.169sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 63 tr: l 0.891 a 0.767  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.132726 cl_acc 1.000 157.639sec(train) 5.885sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 63 tst: l 0.903 a 0.767  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.161sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 64 tr: l 0.887 a 0.767  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.131399 cl_acc 1.000 155.516sec(train) 5.893sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 64 tst: l 0.898 a 0.768  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.143sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 65 tr: l 0.881 a 0.769  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.130085 cl_acc 1.000 147.152sec(train) 5.924sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 65 tst: l 0.906 a 0.768  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.160sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 66 tr: l 0.881 a 0.768  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.128784 cl_acc 1.000 160.891sec(train) 5.859sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 66 tst: l 0.887 a 0.770  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.141sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 67 tr: l 0.876 a 0.769  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.127496 cl_acc 1.000 162.123sec(train) 5.876sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 67 tst: l 0.896 a 0.769  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.274sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 68 tr: l 0.877 a 0.771  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.126221 cl_acc 1.000 147.407sec(train) 5.794sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 68 tst: l 0.909 a 0.766  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.132sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 69 tr: l 0.876 a 0.771  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.124959 cl_acc 1.000 156.584sec(train) 5.953sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 69 tst: l 0.896 a 0.771  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.180sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 70 tr: l 0.863 a 0.777  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.123710 cl_acc 1.000 165.812sec(train) 5.889sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 70 tst: l 0.890 a 0.772  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.161sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 71 tr: l 0.867 a 0.774  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.122473 cl_acc 1.000 146.960sec(train) 5.877sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 71 tst: l 0.883 a 0.774  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.139sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 72 tr: l 0.865 a 0.775  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.121248 cl_acc 1.000 153.823sec(train) 5.839sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 72 tst: l 0.891 a 0.774  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.134sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 73 tr: l 0.842 a 0.780  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.120035 cl_acc 1.000 161.769sec(train) 5.937sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 73 tst: l 0.880 a 0.771  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.154sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 74 tr: l 0.858 a 0.776  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.118835 cl_acc 1.000 146.192sec(train) 5.778sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 74 tst: l 0.889 a 0.770  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.139sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 75 tr: l 0.869 a 0.772  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.117647 cl_acc 1.000 156.045sec(train) 5.762sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 75 tst: l 0.883 a 0.777  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.137sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 76 tr: l 0.853 a 0.777  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.116470 cl_acc 1.000 146.243sec(train) 5.932sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 76 tst: l 0.864 a 0.777  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.168sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 77 tr: l 0.856 a 0.776  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.115305 cl_acc 1.000 149.337sec(train) 5.978sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 77 tst: l 0.885 a 0.772  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.161sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 78 tr: l 0.855 a 0.777  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.114152 cl_acc 1.000 146.124sec(train) 5.948sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 78 tst: l 0.894 a 0.771  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.158sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 79 tr: l 0.844 a 0.780  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.113011 cl_acc 1.000 153.344sec(train) 6.491sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 79 tst: l 0.860 a 0.778  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.169sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 80 tr: l 0.828 a 0.785  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.111881 cl_acc 1.000 150.833sec(train) 5.762sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 80 tst: l 0.858 a 0.780  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.103sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 81 tr: l 0.824 a 0.787  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.110762 cl_acc 1.000 146.973sec(train) 5.963sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 81 tst: l 0.863 a 0.777  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.147sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 82 tr: l 0.828 a 0.784  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.109654 cl_acc 1.000 148.022sec(train) 5.900sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 82 tst: l 0.874 a 0.777  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.163sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 83 tr: l 0.829 a 0.784  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.108558 cl_acc 1.000 148.583sec(train) 5.947sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 83 tst: l 0.859 a 0.780  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.163sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 84 tr: l 0.813 a 0.788  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.107472 cl_acc 1.000 153.453sec(train) 6.047sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 84 tst: l 0.852 a 0.781  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.189sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 85 tr: l 0.822 a 0.786  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.106398 cl_acc 1.000 161.233sec(train) 5.987sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 85 tst: l 0.849 a 0.782  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.177sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 86 tr: l 0.824 a 0.787  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.105334 cl_acc 1.000 166.831sec(train) 5.942sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 86 tst: l 0.858 a 0.781  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.179sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 87 tr: l 0.819 a 0.787  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.104280 cl_acc 1.000 154.080sec(train) 6.015sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 87 tst: l 0.852 a 0.784  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.175sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 88 tr: l 0.809 a 0.790  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.103237 cl_acc 1.000 146.757sec(train) 6.021sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 88 tst: l 0.823 a 0.788  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.194sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 89 tr: l 0.815 a 0.787  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.102205 cl_acc 1.000 166.836sec(train) 6.074sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 89 tst: l 0.852 a 0.782  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.189sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 90 tr: l 0.816 a 0.786  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.101183 cl_acc 1.000 152.458sec(train) 6.029sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 90 tst: l 0.846 a 0.785  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.183sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 91 tr: l 0.795 a 0.794  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.100171 cl_acc 1.000 149.862sec(train) 6.019sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 91 tst: l 0.840 a 0.786  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.164sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 92 tr: l 0.787 a 0.796  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.099169 cl_acc 1.000 157.746sec(train) 5.826sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 92 tst: l 0.853 a 0.785  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.152sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 93 tr: l 0.785 a 0.797  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.098178 cl_acc 1.000 148.475sec(train) 5.989sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 93 tst: l 0.842 a 0.784  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.176sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 94 tr: l 0.812 a 0.788  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.097196 cl_acc 1.000 158.916sec(train) 8.201sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 94 tst: l 0.833 a 0.786  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.431sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 95 tr: l 0.783 a 0.797  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.096224 cl_acc 1.000 148.459sec(train) 6.427sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 95 tst: l 0.830 a 0.788  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.203sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 96 tr: l 0.763 a 0.803  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.095262 cl_acc 1.000 153.914sec(train) 5.953sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 96 tst: l 0.831 a 0.788  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.173sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 97 tr: l 0.773 a 0.800  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.094309 cl_acc 1.000 168.932sec(train) 5.893sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 97 tst: l 0.841 a 0.784  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.128sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 98 tr: l 0.804 a 0.792  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.093366 cl_acc 1.000 168.618sec(train) 5.831sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 98 tst: l 0.842 a 0.785  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.138sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 99 tr: l 0.782 a 0.798  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.092432 cl_acc 1.000 156.736sec(train) 5.968sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 99 tst: l 0.835 a 0.787  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.160sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 100 tr: l 0.796 a 0.794  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.091508 cl_acc 1.000 159.317sec(train) 6.011sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 100 tst: l 0.840 a 0.786  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.170sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 101 tr: l 0.796 a 0.793  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.090593 cl_acc 1.000 159.805sec(train) 7.580sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 101 tst: l 0.840 a 0.785  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.400sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 102 tr: l 0.789 a 0.795  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.089687 cl_acc 1.000 165.745sec(train) 6.223sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 102 tst: l 0.836 a 0.786  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.142sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 103 tr: l 0.757 a 0.803  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.088790 cl_acc 1.000 171.550sec(train) 7.527sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 103 tst: l 0.837 a 0.786  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.404sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 104 tr: l 0.768 a 0.801  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.087902 cl_acc 1.000 164.217sec(train) 5.866sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 104 tst: l 0.819 a 0.790  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.163sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 105 tr: l 0.773 a 0.800  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.087023 cl_acc 1.000 148.076sec(train) 6.068sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 105 tst: l 0.834 a 0.790  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.203sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 106 tr: l 0.754 a 0.804  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.086153 cl_acc 1.000 174.353sec(train) 5.904sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 106 tst: l 0.833 a 0.788  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.164sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 107 tr: l 0.764 a 0.801  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.085292 cl_acc 1.000 160.018sec(train) 5.830sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 107 tst: l 0.819 a 0.791  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.133sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 108 tr: l 0.756 a 0.804  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.084439 cl_acc 1.000 150.042sec(train) 5.862sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 108 tst: l 0.816 a 0.794  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.156sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 109 tr: l 0.739 a 0.809  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.083594 cl_acc 1.000 170.418sec(train) 6.006sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 109 tst: l 0.833 a 0.789  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.179sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 110 tr: l 0.759 a 0.802  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.082758 cl_acc 1.000 158.374sec(train) 5.983sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 110 tst: l 0.819 a 0.794  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.184sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 111 tr: l 0.767 a 0.800  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.081931 cl_acc 1.000 156.639sec(train) 6.018sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 111 tst: l 0.820 a 0.793  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.192sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 112 tr: l 0.757 a 0.803  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.081111 cl_acc 1.000 149.951sec(train) 6.018sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 112 tst: l 0.824 a 0.791  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.177sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 113 tr: l 0.743 a 0.807  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.080300 cl_acc 1.000 160.630sec(train) 6.021sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 113 tst: l 0.819 a 0.791  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.177sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 114 tr: l 0.747 a 0.806  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.079497 cl_acc 1.000 178.102sec(train) 6.013sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 114 tst: l 0.823 a 0.791  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.194sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 115 tr: l 0.751 a 0.804  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.078702 cl_acc 1.000 159.373sec(train) 6.028sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 115 tst: l 0.827 a 0.792  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.187sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 116 tr: l 0.733 a 0.810  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.077915 cl_acc 1.000 149.906sec(train) 5.924sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 116 tst: l 0.824 a 0.792  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.174sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 117 tr: l 0.759 a 0.803  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.077136 cl_acc 1.000 175.638sec(train) 5.947sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 117 tst: l 0.810 a 0.793  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.153sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 118 tr: l 0.730 a 0.811  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.076365 cl_acc 1.000 148.249sec(train) 5.833sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 118 tst: l 0.819 a 0.794  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.139sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 119 tr: l 0.718 a 0.815  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.075601 cl_acc 1.000 147.288sec(train) 6.051sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 119 tst: l 0.800 a 0.796  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.198sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 120 tr: l 0.720 a 0.814  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.074845 cl_acc 1.000 149.477sec(train) 5.913sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 120 tst: l 0.825 a 0.788  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.172sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 121 tr: l 0.715 a 0.814  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.074097 cl_acc 1.000 151.777sec(train) 5.895sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 121 tst: l 0.810 a 0.791  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.149sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 122 tr: l 0.709 a 0.817  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.073356 cl_acc 1.000 145.606sec(train) 5.963sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 122 tst: l 0.805 a 0.795  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.174sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 123 tr: l 0.726 a 0.811  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.072622 cl_acc 1.000 155.519sec(train) 5.940sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 123 tst: l 0.782 a 0.800  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.165sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 124 tr: l 0.717 a 0.813  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.071896 cl_acc 1.000 167.368sec(train) 6.008sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 124 tst: l 0.802 a 0.795  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.183sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 125 tr: l 0.721 a 0.812  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.071177 cl_acc 1.000 147.687sec(train) 5.936sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 125 tst: l 0.793 a 0.799  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 126 tr: l 0.719 a 0.813  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.070465 cl_acc 1.000 148.320sec(train) 6.004sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 126 tst: l 0.800 a 0.797  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.172sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 127 tr: l 0.713 a 0.815  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.069761 cl_acc 1.000 147.966sec(train) 5.924sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 127 tst: l 0.788 a 0.798  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.150sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 128 tr: l 0.697 a 0.818  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.069063 cl_acc 1.000 156.285sec(train) 5.996sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 128 tst: l 0.795 a 0.795  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.184sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 129 tr: l 0.694 a 0.820  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.068372 cl_acc 1.000 154.242sec(train) 5.868sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 129 tst: l 0.803 a 0.798  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.143sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 130 tr: l 0.717 a 0.813  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.067689 cl_acc 1.000 153.351sec(train) 5.911sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 130 tst: l 0.796 a 0.798  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.167sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 131 tr: l 0.692 a 0.822  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.067012 cl_acc 1.000 147.395sec(train) 5.932sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 131 tst: l 0.791 a 0.798  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.153sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 132 tr: l 0.697 a 0.820  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.066342 cl_acc 1.000 148.438sec(train) 5.816sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 132 tst: l 0.802 a 0.796  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 133 tr: l 0.696 a 0.820  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.065678 cl_acc 1.000 147.618sec(train) 5.892sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 133 tst: l 0.815 a 0.795  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.161sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 134 tr: l 0.701 a 0.820  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.065021 cl_acc 1.000 148.661sec(train) 6.003sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 134 tst: l 0.796 a 0.797  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.177sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 135 tr: l 0.686 a 0.823  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.064371 cl_acc 1.000 152.306sec(train) 5.923sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 135 tst: l 0.799 a 0.798  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.152sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 136 tr: l 0.679 a 0.826  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.063727 cl_acc 1.000 147.072sec(train) 5.922sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 136 tst: l 0.790 a 0.797  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.140sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 137 tr: l 0.681 a 0.824  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.063090 cl_acc 1.000 148.071sec(train) 5.993sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 137 tst: l 0.788 a 0.798  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.165sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 138 tr: l 0.699 a 0.819  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.062459 cl_acc 1.000 152.636sec(train) 5.985sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 138 tst: l 0.791 a 0.797  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.174sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 139 tr: l 0.688 a 0.821  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.061835 cl_acc 1.000 148.047sec(train) 5.986sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 139 tst: l 0.779 a 0.799  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.176sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 140 tr: l 0.681 a 0.823  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.061216 cl_acc 1.000 166.641sec(train) 5.965sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 140 tst: l 0.793 a 0.797  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.156sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 141 tr: l 0.680 a 0.822  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.060604 cl_acc 1.000 148.616sec(train) 5.921sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 141 tst: l 0.788 a 0.799  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.164sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 142 tr: l 0.675 a 0.824  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.059998 cl_acc 1.000 159.269sec(train) 5.993sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 142 tst: l 0.773 a 0.802  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.184sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 143 tr: l 0.668 a 0.828  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.059398 cl_acc 1.000 151.380sec(train) 6.006sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 143 tst: l 0.781 a 0.799  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.175sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 144 tr: l 0.696 a 0.819  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.058804 cl_acc 1.000 149.755sec(train) 5.947sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 144 tst: l 0.777 a 0.801  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.159sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 145 tr: l 0.672 a 0.826  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.058216 cl_acc 1.000 152.895sec(train) 5.961sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 145 tst: l 0.765 a 0.803  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.185sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 146 tr: l 0.650 a 0.832  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.057634 cl_acc 1.000 149.269sec(train) 5.909sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 146 tst: l 0.786 a 0.799  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.171sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 147 tr: l 0.668 a 0.826  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.057058 cl_acc 1.000 150.669sec(train) 5.925sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 147 tst: l 0.782 a 0.800  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.155sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 148 tr: l 0.667 a 0.825  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.056487 cl_acc 1.000 151.321sec(train) 5.898sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 148 tst: l 0.773 a 0.801  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.179sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 149 tr: l 0.663 a 0.827  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.055922 cl_acc 1.000 148.946sec(train) 5.953sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 149 tst: l 0.762 a 0.803  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.188sec\n",
      "result written at output/results.pickle\n",
      "---train cluster Ended in 6.78 hour (24394.779 sec) \n",
      "---------------------------------DFCA, lr: 0.25, seed: 3657---------------------------------\n",
      "config: {'m': 100, 'm_test': 20, 'p': 2, 'n': 1000, 'participation_rate': 1, '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:1754544645.089517  926711 gpu_device.cc:2019] Created device /job:localhost/replica:0/task:0/device:GPU:0 with 18963 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": [
      "finding good initializer from train data\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-08-07 07:30:45.324789: W tensorflow/c/c_api.cc:305] Operation '{name:'softmax_linear/biases/Assign' id:221 op device:{requested: '/device:CPU:0', assigned: ''} def:{{{node softmax_linear/biases/Assign}} = Assign[T=DT_FLOAT, _class=[\"loc:@softmax_linear/biases\"], _has_manual_control_dependencies=true, use_locking=true, validate_shape=true, _device=\"/device:CPU:0\"](softmax_linear/biases, softmax_linear/biases/Initializer/Const)}}' was changed by setting attribute after it was run by a session. This mutation will have no effect, and will trigger an error in the future. Either don't modify nodes after running them or create a new session.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch -1 tr: l 4.673 a 0.097  clct[np.int64(0), np.int64(100)] ans[np.int64(50), np.int64(50)] cl_acc 0.500 7.130sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-08-07 07:30:52.572108: W tensorflow/c/c_api.cc:305] Operation '{name:'softmax_linear/biases/Assign' id:221 op device:{requested: '/device:CPU:0', assigned: ''} def:{{{node softmax_linear/biases/Assign}} = Assign[T=DT_FLOAT, _class=[\"loc:@softmax_linear/biases\"], _has_manual_control_dependencies=true, use_locking=true, validate_shape=true, _device=\"/device:CPU:0\"](softmax_linear/biases, softmax_linear/biases/Initializer/Const)}}' was changed by setting attribute after it was run by a session. This mutation will have no effect, and will trigger an error in the future. Either don't modify nodes after running them or create a new session.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch -1 tr: l 4.674 a 0.088  clct[np.int64(0), np.int64(100)] ans[np.int64(50), np.int64(50)] cl_acc 0.500 8.823sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-08-07 07:31:01.518017: W tensorflow/c/c_api.cc:305] Operation '{name:'softmax_linear/biases/Assign' id:221 op device:{requested: '/device:CPU:0', assigned: ''} def:{{{node softmax_linear/biases/Assign}} = Assign[T=DT_FLOAT, _class=[\"loc:@softmax_linear/biases\"], _has_manual_control_dependencies=true, use_locking=true, validate_shape=true, _device=\"/device:CPU:0\"](softmax_linear/biases, softmax_linear/biases/Initializer/Const)}}' was changed by setting attribute after it was run by a session. This mutation will have no effect, and will trigger an error in the future. Either don't modify nodes after running them or create a new session.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch -1 tr: l 4.681 a 0.091  clct[np.int64(85), np.int64(15)] ans[np.int64(50), np.int64(50)] cl_acc 0.550 9.383sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-08-07 07:31:11.059381: W tensorflow/c/c_api.cc:305] Operation '{name:'softmax_linear/biases/Assign' id:221 op device:{requested: '/device:CPU:0', assigned: ''} def:{{{node softmax_linear/biases/Assign}} = Assign[T=DT_FLOAT, _class=[\"loc:@softmax_linear/biases\"], _has_manual_control_dependencies=true, use_locking=true, validate_shape=true, _device=\"/device:CPU:0\"](softmax_linear/biases, softmax_linear/biases/Initializer/Const)}}' was changed by setting attribute after it was run by a session. This mutation will have no effect, and will trigger an error in the future. Either don't modify nodes after running them or create a new session.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch -1 tr: l 4.675 a 0.099  clct[np.int64(100), np.int64(0)] ans[np.int64(50), np.int64(50)] cl_acc 0.500 9.316sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-08-07 07:31:20.490441: W tensorflow/c/c_api.cc:305] Operation '{name:'softmax_linear/biases/Assign' id:221 op device:{requested: '/device:CPU:0', assigned: ''} def:{{{node softmax_linear/biases/Assign}} = Assign[T=DT_FLOAT, _class=[\"loc:@softmax_linear/biases\"], _has_manual_control_dependencies=true, use_locking=true, validate_shape=true, _device=\"/device:CPU:0\"](softmax_linear/biases, softmax_linear/biases/Initializer/Const)}}' was changed by setting attribute after it was run by a session. This mutation will have no effect, and will trigger an error in the future. Either don't modify nodes after running them or create a new session.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch -1 tr: l 4.670 a 0.089  clct[np.int64(0), np.int64(100)] ans[np.int64(50), np.int64(50)] cl_acc 0.500 8.665sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-08-07 07:31:29.278130: W tensorflow/c/c_api.cc:305] Operation '{name:'softmax_linear/biases/Assign' id:221 op device:{requested: '/device:CPU:0', assigned: ''} def:{{{node softmax_linear/biases/Assign}} = Assign[T=DT_FLOAT, _class=[\"loc:@softmax_linear/biases\"], _has_manual_control_dependencies=true, use_locking=true, validate_shape=true, _device=\"/device:CPU:0\"](softmax_linear/biases, softmax_linear/biases/Initializer/Const)}}' was changed by setting attribute after it was run by a session. This mutation will have no effect, and will trigger an error in the future. Either don't modify nodes after running them or create a new session.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch -1 tr: l 4.673 a 0.103  clct[np.int64(71), np.int64(29)] ans[np.int64(50), np.int64(50)] cl_acc 0.590 8.178sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-08-07 07:31:37.580201: W tensorflow/c/c_api.cc:305] Operation '{name:'softmax_linear/biases/Assign' id:221 op device:{requested: '/device:CPU:0', assigned: ''} def:{{{node softmax_linear/biases/Assign}} = Assign[T=DT_FLOAT, _class=[\"loc:@softmax_linear/biases\"], _has_manual_control_dependencies=true, use_locking=true, validate_shape=true, _device=\"/device:CPU:0\"](softmax_linear/biases, softmax_linear/biases/Initializer/Const)}}' was changed by setting attribute after it was run by a session. This mutation will have no effect, and will trigger an error in the future. Either don't modify nodes after running them or create a new session.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch -1 tr: l 4.674 a 0.100  clct[np.int64(15), np.int64(85)] ans[np.int64(50), np.int64(50)] cl_acc 0.610 8.455sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-08-07 07:31:46.174967: W tensorflow/c/c_api.cc:305] Operation '{name:'softmax_linear/biases/Assign' id:221 op device:{requested: '/device:CPU:0', assigned: ''} def:{{{node softmax_linear/biases/Assign}} = Assign[T=DT_FLOAT, _class=[\"loc:@softmax_linear/biases\"], _has_manual_control_dependencies=true, use_locking=true, validate_shape=true, _device=\"/device:CPU:0\"](softmax_linear/biases, softmax_linear/biases/Initializer/Const)}}' was changed by setting attribute after it was run by a session. This mutation will have no effect, and will trigger an error in the future. Either don't modify nodes after running them or create a new session.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch -1 tr: l 4.672 a 0.104  clct[np.int64(0), np.int64(100)] ans[np.int64(50), np.int64(50)] cl_acc 0.500 8.563sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-08-07 07:31:54.851115: W tensorflow/c/c_api.cc:305] Operation '{name:'softmax_linear/biases/Assign' id:221 op device:{requested: '/device:CPU:0', assigned: ''} def:{{{node softmax_linear/biases/Assign}} = Assign[T=DT_FLOAT, _class=[\"loc:@softmax_linear/biases\"], _has_manual_control_dependencies=true, use_locking=true, validate_shape=true, _device=\"/device:CPU:0\"](softmax_linear/biases, softmax_linear/biases/Initializer/Const)}}' was changed by setting attribute after it was run by a session. This mutation will have no effect, and will trigger an error in the future. Either don't modify nodes after running them or create a new session.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch -1 tr: l 4.671 a 0.095  clct[np.int64(100), np.int64(0)] ans[np.int64(50), np.int64(50)] cl_acc 0.500 7.848sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-08-07 07:32:02.820720: W tensorflow/c/c_api.cc:305] Operation '{name:'softmax_linear/biases/Assign' id:221 op device:{requested: '/device:CPU:0', assigned: ''} def:{{{node softmax_linear/biases/Assign}} = Assign[T=DT_FLOAT, _class=[\"loc:@softmax_linear/biases\"], _has_manual_control_dependencies=true, use_locking=true, validate_shape=true, _device=\"/device:CPU:0\"](softmax_linear/biases, softmax_linear/biases/Initializer/Const)}}' was changed by setting attribute after it was run by a session. This mutation will have no effect, and will trigger an error in the future. Either don't modify nodes after running them or create a new session.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch -1 tr: l 4.673 a 0.102  clct[np.int64(100), np.int64(0)] ans[np.int64(50), np.int64(50)] cl_acc 0.500 8.678sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-08-07 07:32:11.615848: W tensorflow/c/c_api.cc:305] Operation '{name:'softmax_linear/biases/Assign' id:221 op device:{requested: '/device:CPU:0', assigned: ''} def:{{{node softmax_linear/biases/Assign}} = Assign[T=DT_FLOAT, _class=[\"loc:@softmax_linear/biases\"], _has_manual_control_dependencies=true, use_locking=true, validate_shape=true, _device=\"/device:CPU:0\"](softmax_linear/biases, softmax_linear/biases/Initializer/Const)}}' was changed by setting attribute after it was run by a session. This mutation will have no effect, and will trigger an error in the future. Either don't modify nodes after running them or create a new session.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch -1 tr: l 4.674 a 0.101  clct[np.int64(16), np.int64(84)] ans[np.int64(50), np.int64(50)] cl_acc 0.560 8.522sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-08-07 07:32:20.282539: W tensorflow/c/c_api.cc:305] Operation '{name:'softmax_linear/biases/Assign' id:221 op device:{requested: '/device:CPU:0', assigned: ''} def:{{{node softmax_linear/biases/Assign}} = Assign[T=DT_FLOAT, _class=[\"loc:@softmax_linear/biases\"], _has_manual_control_dependencies=true, use_locking=true, validate_shape=true, _device=\"/device:CPU:0\"](softmax_linear/biases, softmax_linear/biases/Initializer/Const)}}' was changed by setting attribute after it was run by a session. This mutation will have no effect, and will trigger an error in the future. Either don't modify nodes after running them or create a new session.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch -1 tr: l 4.673 a 0.099  clct[np.int64(98), np.int64(2)] ans[np.int64(50), np.int64(50)] cl_acc 0.500 9.034sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-08-07 07:32:29.438154: W tensorflow/c/c_api.cc:305] Operation '{name:'softmax_linear/biases/Assign' id:221 op device:{requested: '/device:CPU:0', assigned: ''} def:{{{node softmax_linear/biases/Assign}} = Assign[T=DT_FLOAT, _class=[\"loc:@softmax_linear/biases\"], _has_manual_control_dependencies=true, use_locking=true, validate_shape=true, _device=\"/device:CPU:0\"](softmax_linear/biases, softmax_linear/biases/Initializer/Const)}}' was changed by setting attribute after it was run by a session. This mutation will have no effect, and will trigger an error in the future. Either don't modify nodes after running them or create a new session.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch -1 tr: l 4.675 a 0.105  clct[np.int64(3), np.int64(97)] ans[np.int64(50), np.int64(50)] cl_acc 0.510 8.970sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-08-07 07:32:38.534422: W tensorflow/c/c_api.cc:305] Operation '{name:'softmax_linear/biases/Assign' id:221 op device:{requested: '/device:CPU:0', assigned: ''} def:{{{node softmax_linear/biases/Assign}} = Assign[T=DT_FLOAT, _class=[\"loc:@softmax_linear/biases\"], _has_manual_control_dependencies=true, use_locking=true, validate_shape=true, _device=\"/device:CPU:0\"](softmax_linear/biases, softmax_linear/biases/Initializer/Const)}}' was changed by setting attribute after it was run by a session. This mutation will have no effect, and will trigger an error in the future. Either don't modify nodes after running them or create a new session.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch -1 tr: l 4.673 a 0.108  clct[np.int64(100), np.int64(0)] ans[np.int64(50), np.int64(50)] cl_acc 0.500 8.398sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-08-07 07:32:47.052430: W tensorflow/c/c_api.cc:305] Operation '{name:'softmax_linear/biases/Assign' id:221 op device:{requested: '/device:CPU:0', assigned: ''} def:{{{node softmax_linear/biases/Assign}} = Assign[T=DT_FLOAT, _class=[\"loc:@softmax_linear/biases\"], _has_manual_control_dependencies=true, use_locking=true, validate_shape=true, _device=\"/device:CPU:0\"](softmax_linear/biases, softmax_linear/biases/Initializer/Const)}}' was changed by setting attribute after it was run by a session. This mutation will have no effect, and will trigger an error in the future. Either don't modify nodes after running them or create a new session.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch -1 tr: l 4.672 a 0.106  clct[np.int64(100), np.int64(0)] ans[np.int64(50), np.int64(50)] cl_acc 0.500 6.175sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-08-07 07:32:53.350180: W tensorflow/c/c_api.cc:305] Operation '{name:'softmax_linear/biases/Assign' id:221 op device:{requested: '/device:CPU:0', assigned: ''} def:{{{node softmax_linear/biases/Assign}} = Assign[T=DT_FLOAT, _class=[\"loc:@softmax_linear/biases\"], _has_manual_control_dependencies=true, use_locking=true, validate_shape=true, _device=\"/device:CPU:0\"](softmax_linear/biases, softmax_linear/biases/Initializer/Const)}}' was changed by setting attribute after it was run by a session. This mutation will have no effect, and will trigger an error in the future. Either don't modify nodes after running them or create a new session.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch -1 tr: l 4.674 a 0.097  clct[np.int64(88), np.int64(12)] ans[np.int64(50), np.int64(50)] cl_acc 0.540 7.480sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-08-07 07:33:00.953534: W tensorflow/c/c_api.cc:305] Operation '{name:'softmax_linear/biases/Assign' id:221 op device:{requested: '/device:CPU:0', assigned: ''} def:{{{node softmax_linear/biases/Assign}} = Assign[T=DT_FLOAT, _class=[\"loc:@softmax_linear/biases\"], _has_manual_control_dependencies=true, use_locking=true, validate_shape=true, _device=\"/device:CPU:0\"](softmax_linear/biases, softmax_linear/biases/Initializer/Const)}}' was changed by setting attribute after it was run by a session. This mutation will have no effect, and will trigger an error in the future. Either don't modify nodes after running them or create a new session.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch -1 tr: l 4.676 a 0.101  clct[np.int64(67), np.int64(33)] ans[np.int64(50), np.int64(50)] cl_acc 0.730 6.897sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-08-07 07:33:07.974991: W tensorflow/c/c_api.cc:305] Operation '{name:'softmax_linear/biases/Assign' id:221 op device:{requested: '/device:CPU:0', assigned: ''} def:{{{node softmax_linear/biases/Assign}} = Assign[T=DT_FLOAT, _class=[\"loc:@softmax_linear/biases\"], _has_manual_control_dependencies=true, use_locking=true, validate_shape=true, _device=\"/device:CPU:0\"](softmax_linear/biases, softmax_linear/biases/Initializer/Const)}}' was changed by setting attribute after it was run by a session. This mutation will have no effect, and will trigger an error in the future. Either don't modify nodes after running them or create a new session.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch -1 tr: l 4.674 a 0.087  clct[np.int64(56), np.int64(44)] ans[np.int64(50), np.int64(50)] cl_acc 0.500 5.843sec\n",
      "found good initializer\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch -1 tr: l 4.674 a 0.090  clct[np.int64(51), np.int64(49)] ans[np.int64(50), np.int64(50)] cl_acc 0.530 5.845sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch -1 tst: l 4.674 a 0.089  clct[np.int64(12), np.int64(8)] ans[np.int64(10), np.int64(10)] cl_acc 0.600 1.160sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0 tr: l 3.791 a 0.218  clct[np.int64(57), np.int64(43)] ans[np.int64(50), np.int64(50)] lr 0.250000 cl_acc 0.650 145.590sec(train) 6.249sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0 tst: l 3.784 a 0.224  clct[np.int64(15), np.int64(5)] ans[np.int64(10), np.int64(10)] cl_acc 0.550 1.208sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1 tr: l 3.122 a 0.296  clct[np.int64(66), np.int64(34)] ans[np.int64(50), np.int64(50)] lr 0.247500 cl_acc 0.760 145.302sec(train) 6.356sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1 tst: l 3.111 a 0.310  clct[np.int64(15), np.int64(5)] ans[np.int64(10), np.int64(10)] cl_acc 0.650 1.194sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2 tr: l 2.566 a 0.364  clct[np.int64(52), np.int64(48)] ans[np.int64(50), np.int64(50)] lr 0.245025 cl_acc 0.960 141.735sec(train) 6.217sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2 tst: l 2.530 a 0.400  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.152sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3 tr: l 2.139 a 0.432  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.242575 cl_acc 1.000 139.920sec(train) 6.611sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3 tst: l 2.055 a 0.477  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.250sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4 tr: l 1.894 a 0.472  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.240149 cl_acc 1.000 167.748sec(train) 7.057sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4 tst: l 1.790 a 0.515  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.302sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5 tr: l 1.723 a 0.506  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.237748 cl_acc 1.000 136.322sec(train) 6.721sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5 tst: l 1.603 a 0.551  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.191sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6 tr: l 1.590 a 0.532  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.235370 cl_acc 1.000 160.082sec(train) 5.998sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6 tst: l 1.464 a 0.588  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.200sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7 tr: l 1.468 a 0.570  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.233016 cl_acc 1.000 148.516sec(train) 6.669sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7 tst: l 1.377 a 0.602  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.165sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8 tr: l 1.398 a 0.584  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.230686 cl_acc 1.000 144.401sec(train) 6.461sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8 tst: l 1.296 a 0.627  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.184sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9 tr: l 1.346 a 0.602  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.228379 cl_acc 1.000 153.827sec(train) 6.438sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9 tst: l 1.236 a 0.642  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.172sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10 tr: l 1.286 a 0.620  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.226096 cl_acc 1.000 146.138sec(train) 6.369sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10 tst: l 1.183 a 0.660  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.185sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11 tr: l 1.261 a 0.627  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.223835 cl_acc 1.000 137.621sec(train) 6.297sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11 tst: l 1.150 a 0.669  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.168sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12 tr: l 1.239 a 0.635  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.221596 cl_acc 1.000 143.804sec(train) 6.018sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12 tst: l 1.128 a 0.675  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.159sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13 tr: l 1.208 a 0.647  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.219380 cl_acc 1.000 143.036sec(train) 6.128sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13 tst: l 1.121 a 0.683  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.202sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14 tr: l 1.195 a 0.654  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.217186 cl_acc 1.000 144.040sec(train) 6.262sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14 tst: l 1.085 a 0.692  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.236sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15 tr: l 1.178 a 0.659  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.215015 cl_acc 1.000 139.199sec(train) 6.178sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15 tst: l 1.097 a 0.686  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.233sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16 tr: l 1.170 a 0.663  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.212864 cl_acc 1.000 145.459sec(train) 7.184sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16 tst: l 1.071 a 0.697  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.483sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17 tr: l 1.141 a 0.676  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.210736 cl_acc 1.000 142.636sec(train) 7.255sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17 tst: l 1.079 a 0.699  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.173sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18 tr: l 1.166 a 0.668  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.208628 cl_acc 1.000 165.287sec(train) 8.089sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18 tst: l 1.052 a 0.702  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.573sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19 tr: l 1.134 a 0.679  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.206542 cl_acc 1.000 137.955sec(train) 6.327sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19 tst: l 1.042 a 0.712  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.177sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20 tr: l 1.121 a 0.685  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.204477 cl_acc 1.000 136.888sec(train) 6.911sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20 tst: l 1.052 a 0.709  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.301sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21 tr: l 1.105 a 0.690  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.202432 cl_acc 1.000 140.878sec(train) 6.057sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21 tst: l 1.039 a 0.716  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.185sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22 tr: l 1.113 a 0.690  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.200408 cl_acc 1.000 140.368sec(train) 5.804sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22 tst: l 1.012 a 0.724  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.129sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23 tr: l 1.108 a 0.690  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.198404 cl_acc 1.000 143.082sec(train) 6.029sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23 tst: l 1.020 a 0.722  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.182sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24 tr: l 1.104 a 0.694  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.196420 cl_acc 1.000 139.202sec(train) 6.183sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24 tst: l 1.028 a 0.722  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.200sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25 tr: l 1.086 a 0.699  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.194455 cl_acc 1.000 152.922sec(train) 7.140sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25 tst: l 1.005 a 0.729  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.629sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 26 tr: l 1.085 a 0.701  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.192511 cl_acc 1.000 143.459sec(train) 9.105sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 26 tst: l 1.028 a 0.724  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.479sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 27 tr: l 1.085 a 0.700  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.190586 cl_acc 1.000 148.773sec(train) 6.352sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 27 tst: l 1.012 a 0.725  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.196sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 28 tr: l 1.063 a 0.709  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.188680 cl_acc 1.000 136.342sec(train) 6.716sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 28 tst: l 1.032 a 0.722  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.504sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 29 tr: l 1.053 a 0.713  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.186793 cl_acc 1.000 141.048sec(train) 6.019sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 29 tst: l 1.000 a 0.733  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.462sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 30 tr: l 1.063 a 0.709  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.184925 cl_acc 1.000 139.723sec(train) 6.752sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 30 tst: l 0.988 a 0.736  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.176sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 31 tr: l 1.052 a 0.715  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.183076 cl_acc 1.000 137.983sec(train) 6.459sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 31 tst: l 1.016 a 0.731  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.174sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 32 tr: l 1.055 a 0.712  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.181245 cl_acc 1.000 138.590sec(train) 5.954sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 32 tst: l 0.992 a 0.736  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.171sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 33 tr: l 1.016 a 0.724  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.179433 cl_acc 1.000 147.592sec(train) 6.027sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 33 tst: l 0.970 a 0.743  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.240sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 34 tr: l 1.014 a 0.726  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.177638 cl_acc 1.000 153.581sec(train) 6.041sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 34 tst: l 0.999 a 0.736  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.193sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 35 tr: l 1.025 a 0.723  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.175862 cl_acc 1.000 142.203sec(train) 6.238sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 35 tst: l 0.982 a 0.743  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.182sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 36 tr: l 1.007 a 0.730  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.174103 cl_acc 1.000 142.334sec(train) 6.229sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 36 tst: l 0.995 a 0.738  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.167sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 37 tr: l 1.032 a 0.721  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.172362 cl_acc 1.000 153.980sec(train) 5.989sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 37 tst: l 0.961 a 0.746  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.158sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 38 tr: l 0.994 a 0.731  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.170639 cl_acc 1.000 138.007sec(train) 5.929sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 38 tst: l 0.954 a 0.747  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.466sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 39 tr: l 0.998 a 0.732  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.168932 cl_acc 1.000 161.271sec(train) 6.430sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 39 tst: l 0.939 a 0.753  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.271sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 40 tr: l 0.979 a 0.738  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.167243 cl_acc 1.000 138.306sec(train) 5.943sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 40 tst: l 0.938 a 0.754  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.159sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 41 tr: l 1.005 a 0.732  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.165571 cl_acc 1.000 139.512sec(train) 5.931sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 41 tst: l 0.928 a 0.757  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.221sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 42 tr: l 0.985 a 0.737  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.163915 cl_acc 1.000 141.090sec(train) 6.090sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 42 tst: l 0.941 a 0.756  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.225sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 43 tr: l 0.979 a 0.740  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.162276 cl_acc 1.000 136.452sec(train) 6.330sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 43 tst: l 0.961 a 0.751  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.185sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 44 tr: l 0.978 a 0.739  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.160653 cl_acc 1.000 143.271sec(train) 5.809sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 44 tst: l 0.928 a 0.757  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.269sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 45 tr: l 0.979 a 0.738  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.159046 cl_acc 1.000 141.552sec(train) 5.853sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 45 tst: l 0.926 a 0.758  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.142sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 46 tr: l 0.950 a 0.746  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.157456 cl_acc 1.000 161.250sec(train) 5.964sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 46 tst: l 0.928 a 0.755  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.179sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 47 tr: l 0.956 a 0.744  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.155881 cl_acc 1.000 161.252sec(train) 5.838sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 47 tst: l 0.937 a 0.755  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.372sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 48 tr: l 0.953 a 0.744  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.154323 cl_acc 1.000 153.956sec(train) 5.739sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 48 tst: l 0.925 a 0.759  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 49 tr: l 0.943 a 0.748  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.152779 cl_acc 1.000 142.953sec(train) 8.216sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 49 tst: l 0.930 a 0.758  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.323sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 50 tr: l 0.942 a 0.749  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.151252 cl_acc 1.000 135.040sec(train) 5.977sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 50 tst: l 0.915 a 0.761  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.131sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 51 tr: l 0.944 a 0.751  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.149739 cl_acc 1.000 139.589sec(train) 8.060sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 51 tst: l 0.909 a 0.763  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.590sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 52 tr: l 0.930 a 0.756  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.148242 cl_acc 1.000 137.310sec(train) 5.762sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 52 tst: l 0.902 a 0.763  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.104sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 53 tr: l 0.931 a 0.752  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.146759 cl_acc 1.000 141.269sec(train) 5.877sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 53 tst: l 0.890 a 0.769  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.302sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 54 tr: l 0.931 a 0.753  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.145292 cl_acc 1.000 135.480sec(train) 5.905sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 54 tst: l 0.906 a 0.767  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.227sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 55 tr: l 0.913 a 0.760  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.143839 cl_acc 1.000 135.865sec(train) 5.606sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 55 tst: l 0.899 a 0.768  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.199sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 56 tr: l 0.928 a 0.755  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.142400 cl_acc 1.000 141.924sec(train) 5.460sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 56 tst: l 0.921 a 0.764  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.044sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 57 tr: l 0.912 a 0.760  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.140976 cl_acc 1.000 131.897sec(train) 5.496sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 57 tst: l 0.902 a 0.766  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.044sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 58 tr: l 0.892 a 0.765  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.139567 cl_acc 1.000 126.869sec(train) 5.537sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 58 tst: l 0.877 a 0.771  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.063sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 59 tr: l 0.897 a 0.764  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.138171 cl_acc 1.000 121.934sec(train) 5.451sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 59 tst: l 0.901 a 0.766  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.081sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 60 tr: l 0.908 a 0.761  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.136789 cl_acc 1.000 135.908sec(train) 6.007sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 60 tst: l 0.897 a 0.769  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.165sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 61 tr: l 0.905 a 0.760  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.135421 cl_acc 1.000 148.419sec(train) 5.439sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 61 tst: l 0.871 a 0.776  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.010sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 62 tr: l 0.902 a 0.761  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.134067 cl_acc 1.000 129.687sec(train) 5.692sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 62 tst: l 0.890 a 0.770  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.087sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 63 tr: l 0.909 a 0.761  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.132726 cl_acc 1.000 133.368sec(train) 5.523sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 63 tst: l 0.889 a 0.766  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.127sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 64 tr: l 0.911 a 0.760  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.131399 cl_acc 1.000 132.736sec(train) 5.518sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 64 tst: l 0.884 a 0.773  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.039sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 65 tr: l 0.898 a 0.763  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.130085 cl_acc 1.000 145.008sec(train) 5.840sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 65 tst: l 0.877 a 0.776  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.201sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 66 tr: l 0.882 a 0.768  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.128784 cl_acc 1.000 143.388sec(train) 5.992sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 66 tst: l 0.873 a 0.771  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.192sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 67 tr: l 0.890 a 0.766  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.127496 cl_acc 1.000 135.751sec(train) 5.913sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 67 tst: l 0.876 a 0.772  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.162sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 68 tr: l 0.863 a 0.774  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.126221 cl_acc 1.000 144.986sec(train) 5.927sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 68 tst: l 0.873 a 0.775  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.136sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 69 tr: l 0.868 a 0.772  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.124959 cl_acc 1.000 135.530sec(train) 6.016sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 69 tst: l 0.869 a 0.776  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.156sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 70 tr: l 0.869 a 0.772  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.123710 cl_acc 1.000 137.190sec(train) 5.974sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 70 tst: l 0.873 a 0.773  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.175sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 71 tr: l 0.853 a 0.776  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.122473 cl_acc 1.000 145.419sec(train) 6.245sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 71 tst: l 0.862 a 0.779  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.155sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 72 tr: l 0.841 a 0.780  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.121248 cl_acc 1.000 144.089sec(train) 6.047sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 72 tst: l 0.875 a 0.775  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.221sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 73 tr: l 0.858 a 0.774  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.120035 cl_acc 1.000 135.946sec(train) 6.076sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 73 tst: l 0.860 a 0.777  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.237sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 74 tr: l 0.840 a 0.780  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.118835 cl_acc 1.000 147.839sec(train) 6.492sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 74 tst: l 0.855 a 0.779  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.196sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 75 tr: l 0.824 a 0.786  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.117647 cl_acc 1.000 158.027sec(train) 9.066sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 75 tst: l 0.843 a 0.781  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.818sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 76 tr: l 0.845 a 0.780  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.116470 cl_acc 1.000 136.747sec(train) 5.883sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 76 tst: l 0.855 a 0.776  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.143sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 77 tr: l 0.830 a 0.783  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.115305 cl_acc 1.000 152.991sec(train) 7.763sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 77 tst: l 0.855 a 0.780  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.310sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 78 tr: l 0.837 a 0.780  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.114152 cl_acc 1.000 139.539sec(train) 6.306sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 78 tst: l 0.844 a 0.782  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.198sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 79 tr: l 0.848 a 0.779  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.113011 cl_acc 1.000 157.886sec(train) 5.944sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 79 tst: l 0.860 a 0.778  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.187sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 80 tr: l 0.829 a 0.783  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.111881 cl_acc 1.000 135.322sec(train) 5.904sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 80 tst: l 0.841 a 0.780  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.214sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 81 tr: l 0.821 a 0.786  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.110762 cl_acc 1.000 135.601sec(train) 6.365sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 81 tst: l 0.840 a 0.785  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.221sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 82 tr: l 0.830 a 0.784  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.109654 cl_acc 1.000 156.990sec(train) 6.679sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 82 tst: l 0.852 a 0.779  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.177sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 83 tr: l 0.829 a 0.782  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.108558 cl_acc 1.000 135.248sec(train) 5.747sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 83 tst: l 0.840 a 0.784  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.127sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 84 tr: l 0.829 a 0.783  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.107472 cl_acc 1.000 144.567sec(train) 5.875sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 84 tst: l 0.857 a 0.781  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.175sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 85 tr: l 0.817 a 0.788  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.106398 cl_acc 1.000 135.559sec(train) 5.890sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 85 tst: l 0.832 a 0.784  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.152sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 86 tr: l 0.813 a 0.787  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.105334 cl_acc 1.000 141.280sec(train) 6.538sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 86 tst: l 0.824 a 0.787  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.132sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 87 tr: l 0.824 a 0.784  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.104280 cl_acc 1.000 142.481sec(train) 6.148sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 87 tst: l 0.826 a 0.787  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.169sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 88 tr: l 0.809 a 0.788  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.103237 cl_acc 1.000 136.714sec(train) 5.571sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 88 tst: l 0.822 a 0.788  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.038sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 89 tr: l 0.805 a 0.790  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.102205 cl_acc 1.000 143.666sec(train) 5.678sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 89 tst: l 0.823 a 0.788  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.171sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 90 tr: l 0.807 a 0.788  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.101183 cl_acc 1.000 132.923sec(train) 5.548sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 90 tst: l 0.824 a 0.788  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.127sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 91 tr: l 0.803 a 0.791  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.100171 cl_acc 1.000 139.968sec(train) 5.471sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 91 tst: l 0.810 a 0.791  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.091sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 92 tr: l 0.800 a 0.791  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.099169 cl_acc 1.000 151.412sec(train) 5.568sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 92 tst: l 0.818 a 0.791  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.119sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 93 tr: l 0.798 a 0.792  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.098178 cl_acc 1.000 158.472sec(train) 6.103sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 93 tst: l 0.821 a 0.790  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.157sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 94 tr: l 0.807 a 0.789  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.097196 cl_acc 1.000 149.338sec(train) 6.502sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 94 tst: l 0.817 a 0.791  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 95 tr: l 0.793 a 0.793  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.096224 cl_acc 1.000 148.467sec(train) 5.209sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 95 tst: l 0.828 a 0.789  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.004sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 96 tr: l 0.790 a 0.794  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.095262 cl_acc 1.000 156.922sec(train) 5.082sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 96 tst: l 0.834 a 0.784  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.151sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 97 tr: l 0.810 a 0.789  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.094309 cl_acc 1.000 144.590sec(train) 5.239sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 97 tst: l 0.831 a 0.789  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.101sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 98 tr: l 0.777 a 0.797  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.093366 cl_acc 1.000 160.029sec(train) 5.319sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 98 tst: l 0.826 a 0.784  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 0.990sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 99 tr: l 0.782 a 0.795  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.092432 cl_acc 1.000 159.842sec(train) 5.407sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 99 tst: l 0.824 a 0.788  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.013sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 100 tr: l 0.772 a 0.799  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.091508 cl_acc 1.000 141.119sec(train) 5.092sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 100 tst: l 0.819 a 0.789  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.077sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 101 tr: l 0.771 a 0.799  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.090593 cl_acc 1.000 153.756sec(train) 5.658sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 101 tst: l 0.812 a 0.790  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.123sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 102 tr: l 0.777 a 0.798  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.089687 cl_acc 1.000 145.330sec(train) 5.720sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 102 tst: l 0.813 a 0.789  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.074sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 103 tr: l 0.785 a 0.793  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.088790 cl_acc 1.000 152.461sec(train) 6.479sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 103 tst: l 0.798 a 0.791  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.038sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 104 tr: l 0.780 a 0.796  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.087902 cl_acc 1.000 151.092sec(train) 5.327sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 104 tst: l 0.799 a 0.792  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.089sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 105 tr: l 0.767 a 0.800  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.087023 cl_acc 1.000 150.347sec(train) 5.932sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 105 tst: l 0.803 a 0.794  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.099sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 106 tr: l 0.746 a 0.806  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.086153 cl_acc 1.000 148.164sec(train) 5.483sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 106 tst: l 0.821 a 0.789  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.040sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 107 tr: l 0.757 a 0.804  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.085292 cl_acc 1.000 142.162sec(train) 5.757sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 107 tst: l 0.813 a 0.791  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.084sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 108 tr: l 0.763 a 0.801  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.084439 cl_acc 1.000 143.629sec(train) 6.181sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 108 tst: l 0.809 a 0.791  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.249sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 109 tr: l 0.761 a 0.802  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.083594 cl_acc 1.000 149.364sec(train) 5.868sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 109 tst: l 0.817 a 0.789  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.149sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 110 tr: l 0.749 a 0.806  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.082758 cl_acc 1.000 143.438sec(train) 6.191sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 110 tst: l 0.805 a 0.793  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.078sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 111 tr: l 0.753 a 0.805  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.081931 cl_acc 1.000 142.950sec(train) 5.649sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 111 tst: l 0.816 a 0.791  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.215sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 112 tr: l 0.748 a 0.804  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.081111 cl_acc 1.000 144.766sec(train) 5.794sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 112 tst: l 0.805 a 0.793  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.027sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 113 tr: l 0.747 a 0.805  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.080300 cl_acc 1.000 148.591sec(train) 6.006sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 113 tst: l 0.778 a 0.798  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.206sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 114 tr: l 0.756 a 0.803  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.079497 cl_acc 1.000 165.453sec(train) 5.605sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 114 tst: l 0.809 a 0.791  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.036sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 115 tr: l 0.735 a 0.809  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.078702 cl_acc 1.000 156.827sec(train) 5.894sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 115 tst: l 0.775 a 0.799  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.053sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 116 tr: l 0.741 a 0.806  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.077915 cl_acc 1.000 158.815sec(train) 5.830sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 116 tst: l 0.796 a 0.794  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.051sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 117 tr: l 0.725 a 0.812  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.077136 cl_acc 1.000 142.480sec(train) 5.816sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 117 tst: l 0.763 a 0.804  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 118 tr: l 0.743 a 0.805  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.076365 cl_acc 1.000 147.499sec(train) 6.264sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 118 tst: l 0.779 a 0.795  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.028sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 119 tr: l 0.726 a 0.810  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.075601 cl_acc 1.000 146.285sec(train) 5.497sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 119 tst: l 0.777 a 0.799  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.062sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 120 tr: l 0.718 a 0.813  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.074845 cl_acc 1.000 156.632sec(train) 5.155sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 120 tst: l 0.781 a 0.799  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 0.983sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 121 tr: l 0.711 a 0.815  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.074097 cl_acc 1.000 159.939sec(train) 5.312sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 121 tst: l 0.778 a 0.798  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.152sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 122 tr: l 0.722 a 0.811  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.073356 cl_acc 1.000 152.004sec(train) 6.537sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 122 tst: l 0.777 a 0.798  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.546sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 123 tr: l 0.728 a 0.810  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.072622 cl_acc 1.000 164.835sec(train) 5.701sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 123 tst: l 0.774 a 0.800  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.107sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 124 tr: l 0.715 a 0.814  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.071896 cl_acc 1.000 153.487sec(train) 6.027sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 124 tst: l 0.787 a 0.798  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.109sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 125 tr: l 0.707 a 0.818  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.071177 cl_acc 1.000 156.504sec(train) 5.507sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 125 tst: l 0.778 a 0.802  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.159sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 126 tr: l 0.709 a 0.816  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.070465 cl_acc 1.000 159.690sec(train) 5.441sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 126 tst: l 0.776 a 0.800  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.164sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 127 tr: l 0.715 a 0.814  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.069761 cl_acc 1.000 147.128sec(train) 5.549sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 127 tst: l 0.786 a 0.797  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.085sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 128 tr: l 0.714 a 0.813  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.069063 cl_acc 1.000 145.699sec(train) 5.303sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 128 tst: l 0.762 a 0.805  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.185sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 129 tr: l 0.718 a 0.813  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.068372 cl_acc 1.000 146.488sec(train) 5.449sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 129 tst: l 0.777 a 0.801  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 0.979sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 130 tr: l 0.701 a 0.817  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.067689 cl_acc 1.000 144.674sec(train) 6.582sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 130 tst: l 0.772 a 0.802  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.192sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 131 tr: l 0.693 a 0.820  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.067012 cl_acc 1.000 144.340sec(train) 5.524sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 131 tst: l 0.772 a 0.803  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.214sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 132 tr: l 0.700 a 0.816  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.066342 cl_acc 1.000 146.337sec(train) 5.416sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 132 tst: l 0.780 a 0.799  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 0.941sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 133 tr: l 0.706 a 0.817  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.065678 cl_acc 1.000 148.422sec(train) 6.017sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 133 tst: l 0.753 a 0.806  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.029sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 134 tr: l 0.693 a 0.819  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.065021 cl_acc 1.000 152.286sec(train) 5.335sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 134 tst: l 0.755 a 0.803  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.070sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 135 tr: l 0.688 a 0.822  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.064371 cl_acc 1.000 151.098sec(train) 6.100sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 135 tst: l 0.772 a 0.800  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.146sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 136 tr: l 0.692 a 0.820  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.063727 cl_acc 1.000 154.587sec(train) 5.144sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 136 tst: l 0.772 a 0.803  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.058sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 137 tr: l 0.673 a 0.826  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.063090 cl_acc 1.000 143.210sec(train) 5.612sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 137 tst: l 0.766 a 0.804  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 138 tr: l 0.679 a 0.823  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.062459 cl_acc 1.000 150.332sec(train) 5.455sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 138 tst: l 0.753 a 0.805  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.132sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 139 tr: l 0.672 a 0.826  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.061835 cl_acc 1.000 148.355sec(train) 5.292sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 139 tst: l 0.758 a 0.805  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.147sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 140 tr: l 0.673 a 0.825  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.061216 cl_acc 1.000 157.133sec(train) 5.975sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 140 tst: l 0.761 a 0.804  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.211sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 141 tr: l 0.678 a 0.824  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.060604 cl_acc 1.000 143.830sec(train) 5.625sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 141 tst: l 0.744 a 0.807  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.049sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 142 tr: l 0.679 a 0.821  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.059998 cl_acc 1.000 147.168sec(train) 5.472sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 142 tst: l 0.759 a 0.805  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.122sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 143 tr: l 0.676 a 0.825  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.059398 cl_acc 1.000 147.446sec(train) 5.581sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 143 tst: l 0.756 a 0.805  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.166sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 144 tr: l 0.670 a 0.825  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.058804 cl_acc 1.000 154.541sec(train) 5.265sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 144 tst: l 0.763 a 0.804  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.048sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 145 tr: l 0.663 a 0.828  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.058216 cl_acc 1.000 167.061sec(train) 5.324sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 145 tst: l 0.747 a 0.807  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.050sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 146 tr: l 0.671 a 0.826  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.057634 cl_acc 1.000 151.825sec(train) 5.450sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 146 tst: l 0.743 a 0.810  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.023sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 147 tr: l 0.678 a 0.823  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.057058 cl_acc 1.000 164.948sec(train) 5.272sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 147 tst: l 0.750 a 0.809  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.041sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 148 tr: l 0.675 a 0.823  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.056487 cl_acc 1.000 158.982sec(train) 5.273sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 148 tst: l 0.746 a 0.808  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.073sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 149 tr: l 0.665 a 0.828  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.055922 cl_acc 1.000 151.582sec(train) 5.684sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 149 tst: l 0.757 a 0.806  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000 1.122sec\n",
      "result written at output/results.pickle\n",
      "---train cluster Ended in 6.43 hour (23147.641 sec) \n"
     ]
    }
   ],
   "source": [
    "import dfca as DFCA\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\"---------------------------------DFCA-GI, 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:2\" if torch.cuda.is_available() else \"cpu\")\n",
    "        print(f\"Using device: {device}\")\n",
    "\n",
    "        exp = DFCA.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",
    "    dfca.append(res_mean)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-08-07T11:56:28.546245Z",
     "iopub.status.busy": "2025-08-07T11:56:28.545758Z",
     "iopub.status.idle": "2025-08-07T11:56:29.165573Z",
     "shell.execute_reply": "2025-08-07T11:56:29.164857Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Average Test Loss (Last Epoch): 0.7669\n",
      "Average Test Accuracy (Last Epoch): 0.8035\n",
      "Average Cluster Accuracy (Last Epoch): 1.0000\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA1YAAAH3CAYAAAC4g84JAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjMsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvZiW1igAAAAlwSFlzAAAPYQAAD2EBqD+naQAAciZJREFUeJzt3Xd8U/X+x/F3uncpe9OyBAFBQByIoCKCghPBhaBeRX6CG/cVUC/qFbeigopeFxe3gCgyRVSmgKiAQtmzQPduz++Pc5M2JOlK2pO0r+fjcR5Jz8qn37SQd7/f8z02wzAMAQAAAACqLMjqAgAAAAAg0BGsAAAAAMBLBCsAAAAA8BLBCgAAAAC8RLACAAAAAC8RrAAAAADASwQrAAAAAPASwQoAAAAAvESwAgAAAAAvEawAAECFJCYmymazOS2TJ0+2rJ5vv/3WpZ5169a57DdmzBiX/QYMGFDzBaNG7d+/XxEREU7v+2uvvWZ1WajFCFZAJbn7YOHNMmbMGKu/Jbc2bNigyZMnuyy+9O6777ptk3fffdenrwNI8ur31MrwAPfy8/N1xx13OK0bPHiwevXqZVFF1ti2bZsmT56sM888U82bN1d4eLgaNmyobt26afz48Vq2bFm1vO7Ro0f12Wef6YEHHtCQIUN00kknqV69egoNDVV0dLRatGih888/X4899pj++uuvCp1zwIABVfr9fPTRR92er3nz5i7/x/7zn/9USkqKt98+4FaI1QUA8E8bNmzQlClTXNbzAROAP3jjjTdcPrA/8sgjFlVT8/Lz8/XAAw/o1VdfVWFhodO2o0eP6ujRo9q8ebNee+01DRkyRDNnzlSLFi188tp33HGHXnvtNRUXF7vdXlhYqOzsbO3fv19LlizRk08+qVtvvVXPPfecoqOjfVJDRT3wwAN6++23HW10/Phx/etf/9ILL7xQo3WgbqDHCgAABJScnBz961//clp35pln6uyzz7aoopqVm5uryy67TC+++KJLqHJnwYIFOuecc7Rz506fvP7u3bs9hip3DMPQm2++qSFDhigvL88nNVRUUlKSrrrqKqd1r7/+uvbt21ejdaBuoMcKqKRTTjlFDRs2dLtt//79OnDggMv6jh07KjY21u0xSUlJPq0PQMXFxMTopJNOKne/5s2b10A1qKhZs2bp8OHDTutuuOEGi6qpeY8++qgWLFjgsj4yMlJt27bVgQMHdOzYMadtO3bs0NVXX62ffvpJQUG+/7t6gwYN1LRpU7evbbdixQo9/fTTmjRpUoXOGRYWpm7dupW7X3k9caNGjdLHH3/s+DovL08vv/yynnnmmQrVAVQUwQqopK+//trjtsmTJ7sdPvfmm29yoTTgh3r16lVt16Cg+rzyyitOX4eGhrr0StRWmzdv1osvvuiy/qKLLtKHH36oevXqqbCwUE8++aTL/0erVq3Sm2++qXHjxvmkltatW+u2227T5Zdfrk6dOjnWr127VrfddpvbiUTeeOMN/fOf/6xQuGvWrJnWrl3rdZ0XXHCBGjVqpCNHjjjWzZgxQ1OmTFFERITX5wfsGAoI+Injx4/rpZde0uWXX66kpCTFxcUpPDxczZs314ABA/T4449r//79FTrXX3/9pccee0wDBgxQixYtFB0drdDQUDVp0kQnn3yyzj33XI0fP17vvvuutm/f7nSs/WLgG2+80e25A+XC/m+//Vbjxo1Tjx491LhxY4WFhalevXpq3769rrrqKr355pvKysqq0LmWL1+u22+/XX369FGjRo0UERGhiIgItWjRQt27d9dFF12kBx98UF988UWZF0V7875U1rJly9y+V/ahQAsXLtTIkSPVunVrRUREqEmTJho8eLD++9//Vvg1CgoK9PHHH2vMmDE6+eST1aBBA4WGhqpRo0bq2bOn7r77brcfrE5U1kxzW7Zs0YQJE9SpUyfFxsb61c/b5MmTXepOTEyUJBUVFemtt97S+eefr6ZNmyoiIkKtW7fWqFGjtGrVqgq/xqFDh/Tvf/9bF198sRITExUbG6vw8HA1a9ZMZ5xxhu69995Kf/BMTU3Va6+9phEjRqhDhw6qX7++wsLC1LRpU3Xv3l3Dhw/Xyy+/rL1791bqvEePHtWUKVN06qmnKj4+XtHR0Tr55JM1ceJEl94lb/zyyy/asmWL07pBgwapQYMGXp97586dbn9v7OH7+++/19VXX602bdo4Zpur6WD++uuvq6ioyGlddHS03n//fdWrV0+SFBISosmTJ+uMM85wOd4Xs+I1bdpUb775pnbs2KGHHnrIKVRJUu/evbVo0SI1btzY5diDBw9qx44dXtdQGSEhIS7BOzU1VV9++WWN1oE6wADgM5MmTTIkuSxLly71eExRUZExdepUIzo62u2xpZfw8HBj0qRJRlFRkcfzPfbYY0ZwcHC55yq9lFaZ4+zLpEmTqtRes2bNcnu+WbNmVel8hmEY69evN0455ZQK1Z2QkGDMnDnT47kyMjKMSy65pFJt0b9/f7fn8vZ9qaylS5e6PefWrVuN66+/vszXHTRokJGRkVHm+efOnWu0bNmyQt/H8OHDjdTUVI/natOmjdufqTfffNMIDw/32c9bZd6vinD3+96mTRtjz549Rs+ePT22h81mMx566KEyz11QUGA89NBDbr9/d8uFF15o7Nu3r9xzTpo0yYiKiqrQOUePHu1yDk/v1TfffGM0atTI47kaN25sbNq0qcptXdrdd9/tcv4XXnihzGNGjx5dofc+OTnZbf2LFy82/vGPf7jdVta/775WXFxs1K9f36WGK6+80u3+L7/8stuaN27cWCP1jh071u3r//zzz27379+/v8vvk698/vnnFW43oKoYCghYqKioSFdeeaW++uqrCu2fl5enKVOmaPPmzZozZ47LUIr33ntPjz/+eHWUGhC++eYbXXHFFRW+OPr48eO65ZZbtGnTJr388ssu2ydMmFDm0M+K8qf3ZfTo0frll1/K3GfhwoUaOnSolixZ4na4zrPPPqv777+/wq/56aefatOmTVq5cqXH6xNPNHfuXP36668yDKPCr+MPMjMzdd5555U5vbRhGHrqqacUHBysJ554wmV7fn6+LrroIi1evLjCr/vdd9+pR48e+uGHH1x6DyRzsochQ4Zo+fLlFT5nRS1cuFBTp05VQUGBx30OHz6sESNGaNOmTQoNDfXq9dxdW3T66ad7dc7yPPDAAxXqGZw3b57PelR79eqlN99802ndX3/95fb6JU9TzPfu3dvt+lWrVumUU07xvshyxMXFuV3frFmzCh2fkpKis88+W1u2bFFaWppiYmLUuHFj9erVSxdffLGuuuoqhYWFVehc7n5GFi5cqMLCQoWE8HEYvsFPEmChiRMnug1VwcHBatmypSIjI7Vz507l5uY6bf/ss880ZcoUl/Hzr776qtvXadasmRo1aqS8vDwdPnxYx48f91iT/T/oo0ePup1Byt1/4P5wYf9ff/2lkSNHug1V0dHRSkpKUkpKig4ePOiy/ZVXXtHJJ5+s2267zbEuNTVVH374ocu+9uFecXFxysrK0r59+5STk1Nmbb54X3zFHqqio6PVtm1bHTp0yO0wreXLl+uFF17Qvffe67T+q6++0gMPPOD23E2bNlWDBg20d+9epaWlOW3btm2bhg8fXuFhU+vXr3c8j42NVZs2bZSWlubzmbyWL18um81W5j5t2rSp8Gxq9mmuJalRo0Zq2rSpkpOTlZmZ6bLv1KlTNWzYMPXp08dp/YQJEzyGqsTEREVHR2vbtm0uQebIkSO6+OKL9dtvvykqKspp25gxYzyGqpCQELVr105hYWHat2+fx4kHPPn5558dz9u1ayfDMNwO9dqyZYu+/PJLr66FOnbsmMswwNDQUJ166qlVPmdFlA5VjRs3VpMmTdz+7qSkpFRo+GtFxMTEuKzbuHGj231bt27tdn3Lli3drvd0Hl9bvXq1y7omTZqoVatWFTo+KytLK1eudHydmpqq1NRUbdu2TR9//LEefPBBvfPOO7rgggvKPVfz5s3VsmVLpyGuGRkZ2rx5s3r06FGheoByWdxjBtQqlRkKuHXrViMkJMRl35tuusk4cOCAY7/09HTjrrvuctkvIiLCZejPiUN8YmJijF9++cXltQ8cOGB89tlnxrhx44zGjRu7/V48DdPzJV8OBRwxYoTbcz3wwANGTk6OY7+5c+caMTExLvs1bNjQSE9Pd+y3evVql326d+9u7N+/3+l1i4qKjG3bthlvv/22MXz4cGPIkCEutfnyfakoT0MBJRl33nmnkZ2dbRiGObRo9uzZboecNWnSxMjLy3OcMz8/32jbtq3LfqeffrrT0KKioiJj1qxZRmhoqMu+n3/+uUut7oaXSebQ1xkzZhj5+fmOffft21flYUye2qO8xdNwJE+/76GhocZ//vMfo7i42DAMw8jNzTUmTpzodt/LLrvM6ZybN282goKCXPZLSkoy1q1b59gvJSXFuOKKK9ye86mnnnI6p6efhfDwcGPatGkuwz43btxojB8/3rj11ltdvmdP71Xr1q2NtWvXOvb7z3/+43bo60033VSp9+xE7r6XTp06lXuct0MB7d/j4sWLnfbfuHGj07/Dnv5Nq8rirr7p06e73febb75x+31nZWW53X/kyJHltpm3lixZ4va1p0yZ4vGYE4cCVmQJCgoy5syZU6GaBg8e7HK8N0PPgRMRrAAfqkyweuCBB1z269u3r8dzu7tm48QPUCd+gO/UqZPjw50nhYWFbtcHUrBKTU11+yHu4osvdrv/zJkz3b7uBx984NjHXbAaO3ZsubW4a09fvi8V5enD9DnnnON2/8cff9zt/gsWLHDss2DBApftMTExxrFjx9ye85577nHZ/8ILL3TZz9OH9XfeecerNjhRVT/gVjZYPfbYY273P++881z2DQ4Odgo29957r9tzrlmzxuV8ubm5boNu+/btnfa7+uqr3Z7zs88+K7O9cnNzXdZ5eq8WLVrksu+gQYNc9jv99NPLfM3yvP3225X6d9PO22AVHh5u/Pnnn+W+TnUHq6eeesrtvicGPrvCwkK3+7v7PfSlLVu2GE2bNnV53Y4dOxqZmZkejzsxWDVp0sTo1q2b0bp1a7d/cLAvERERxu7du8ut69prr63w7ytQFcwKCFhk0aJFLut27Nih3r17u13cDUU6cbjQicMZtmzZov79++uZZ57Rl19+qT///FP5+flO+wQHB3v9vVht+fLlLrNkSdItt9zidv/rr7/e7RS7S5YscTzv3Lmzy9j9mTNn6pprrtErr7yihQsXateuXS7XALlrT396X26++Wa368eMGeN2felhXu5+ZiVzKmN3P7OfffaZy74//PBDhW5o2qpVK40ePbrc/bwVExOjXr16lblU9lqUyrRxUVGR1qxZ4/i69M+gXY8ePdxeKxMeHq5Ro0a5rP/777+1Z88ex9fff/+9yz6nn366rrjiCrd1lj5/RXTr1k3nn3++y3p313p5O9zV3aybvpgNsDzDhw93+/2caMyYMTLMP1p7vVRmtsET/x0qb311Wrdunfr37+8y7LpRo0aaN2+eoqOjPR4bFxenG264QXPmzNHhw4d18OBBbdq0Sbt27VJmZqaef/55xcfHuxyXm5urp59+utza3P2s2IfuAr7ANVaARXbt2uWy7sCBA25vMFzRc9xzzz366aefnNatWLFCK1ascHwdHByszp0765xzztHVV1+tfv36VbJy/7N7926367t37+52fUREhDp27KhNmzY5rS/9YTQmJka33nqr0/VRxcXFmj17tmbPnu1YFxkZqZ49e+r888/XqFGj1L59e5fX86f3xVNIaNWqleLj412ujSrdJu5+ZjMzMyt1TUlOTo4OHz5c7nV5/fv3r5abmJ7I1/exqlevnsfrXTzd6LR0G7v7Wfb0c1zWtj179qhVq1bKyspy+8HxvPPO83jOyvJ0fYq7a4QqOrGMJ+6O93TzdV8699xzq/01KsJdqJDk8ocZO0/tbZ+W3dfmz5+vkSNHutzKonHjxlq8eLE6dOhQ5vFffvmlx9/7yMhI3X333TrttNN0zjnnuITGefPmlTuVvLvJNMq7RhaoDHqsAIukpqZ6fY4TPzBdeeWVeuONN8r8oFFUVKTNmzdr+vTpOuecczR06FBlZ2d7XYuVTgwDdmW1g7ttJ74nzz//vG677bYyP+Dn5ORo5cqVevzxx9WpUyc99thjLvv40/tS2TbJyMhwPPfFz6xUsb8Qe7ro3t+5CxN2ntq+dBu7+1mu7HsmlbxXnt6z+vXrezxnZbVo0cLt+uqYac1dL1p6errPX+dE/vLz6GlWTU+/U57WV3R2zsqYMWOGLr30UpdQlZSUpB9//FFdu3Yt9xwV+WPK2WefrTPPPNNl/e7du8sNSe5+vyIjI8t9TaCi6LECLFKvXr0ybyZbEe6Gv40dO1bXXHONPv/8cy1ZskQbNmzQ33//7fE/nPnz5+uBBx7QK6+84lUtVvL0V9yMjAyPw4RKf5i1O/GvuKGhoXr99df10EMP6dNPP9UPP/ygzZs3a9euXW6HsxUVFemJJ55Q9+7ddeWVVzpt85f3xd3sdHbu2qT0B3df/ZXb3c/tiSo6DM3fVLZ9Jec2jo+Pd/kw7Om4srbZ3ytP71llZ/4ri6f3qrzZFqvC3e+zL78XTyr681jd06176h301Gtfuje0IuepCsMw9Oijj2rq1Kku23r37q25c+eqadOmPns9yZyp88RRAJL5h4SygpK7oOnLPzIABCvAIm3atHEJVuPHj/fJB+m4uDiNGTPG6ZqOw4cP6/fff9drr73mcu3LBx98oJdeeqlGhl5VB09DrzZu3KjExESX9Tk5Odq2bZvLek9TALdu3Vr33HOP7rnnHklmMNi7d6/Wr1+vyZMnuwwpfO+991yCleQf78umTZvcDh/bs2eP27/mlm6TNm3auGzv2rWrfvvtN5/VF+hSU1Mdw/BO5KmdSu/bunVrlw9/ZU2N7Wmb/ZzR0dFq2LChy7817q7lCgRJSUku6/zpGpnqnm69ffv2ql+/vkuY9PSantb76r5f+fn5uummm9zemuKSSy7Rxx9/7DL1vy+4G5YslR+S3IVwdz9TQFUF5qcooBZwd7H3p59+qiNHjlTo+CVLlrh8ED5xCEZpjRs31rnnnqu33nrLZVtqaqrLBy9Pf6H1x2GD/fv3dzvZw8yZM93u/+GHH7rcG0xyve7EU3sGBwerTZs2uvzyy13uJSaZkwdU5DxS5d8Xb73zzjtu17/77rtu15911lmO5+5+Zjdv3ux0rVhZtmzZoj/++KNC+wayyrRxSEiI032s3F37tGHDBrc3p83Pz9f777/vsr59+/ZOYc3dPX5WrVpV7o3J3f2OWM3dNYLbt2/3+tqtQGGz2XTNNde4rP/uu+/choaPP/7YZV3Xrl3dXu83ZswY2Ww2p2XAgAEea0lNTdXgwYPdhqoJEyboiy++qFSoeuWVVzxOkFPajz/+6DSpjl27du3K7VncvHmzyzruYQVfIlgBFrnxxhtdwsDBgwc1cOBAfffddy4X5mZlZenHH3/UI488opNOOknnn3++ywxbl156qYYMGaI33nhDW7dudRlylZeX5/FmtSfOgJeQkOB2v7lz51bo+6tJ8fHxbmc4mz9/vh566CGnD4jz5s1z9DyV1qBBA11yySVO65o2barRo0frv//9r/bv3+9yzLFjxzRr1iyX9Se2pS/fF28tW7ZM9957r6NNDMPQf//7X/3rX/9y2bdJkyZOF+2ff/75bv+6e+mll+qdd95x+SBeUFCgTZs26fnnn1e/fv3UuXNntzcMrW2mTp2qDz/80PE7nJeXpwceeMBtL9GwYcOcZkkbM2aM2x7KESNG6Ndff3V8fezYMV177bVub8R70003OX09duxYt3VeffXVevHFF12C/59//ql77rlHd955ZxnfpTUaNmzoMkFMQUGBU9vUdrfddpvL/x1ZWVkaNWqU45q6wsJCTZo0yXFD8NJuv/12r2vYvXu3zj77bC1dutRpfVBQkJ5//nm9/PLLle5pX7dunS644AL16tVLr732msvPdm5url588UUNGzbM7WyHw4cPL/P8+/btc7nBeExMjMdJZYAqqaFp3YE6oTL3sTIMw7jzzjs93pcjKirK6NChg9G1a1ejRYsWhs1mc9knOTnZ6Xwn3gMkLCzMSEpKMrp372506tTJiI6Odvta7dq1c6lt7969HmtLTEw0evXq5VhK30S2Mjzd8+XE83taPvroI8e5tm7d6vH7i4mJMbp162Y0a9bM4/f02muvudR34j6xsbFGhw4djB49ehjt2rVze4NnScbNN99cbe9LRZV1g+DSbdKkSROP+0ybNs3lvJ9//rnH/UNDQ43WrVsb3bt3NxITE42wsDCXfdzdo8zdvZEmTZpU5e/dE0/tUJGftWuvvdblfJ5+3+1L48aNjW7duhmxsbFutwcFBRmrVq1yOe8//vEPj+dMSkoyunTp4rZt7dvd3SfI0w207e9bp06djG7duhkNGjRwrB89erTLeSrzXrlrH0/3BKuMCRMmuJz3pZdeKvMYb+9j5enfcKt4ut9ZZGSk0aVLF6N+/fput59++ulGUVGR23NWtI0MwzAuuOACt+ePjY2t0O/T3LlzK/T6DRo0MLp06WK0adOmzPtYNWrUyOP99Ow+++wzl+Muv/zySrc9UBausQIsNG3aNCUnJ+vrr7922Zadna2//vrLq/Pn5+crOTm53P0eeeQRl3UtWrTQWWed5fYC4Z07dzrdV6u4uNirOss7vyeHDh1yPO/YsaM+/vhjDR8+3GXq4czMzDKvAxo3bpz+7//+r9zXy8jIKHMiAcmcyt1dj1hp3rwv3ho6dKjmzZtXbpv0799fd911l8v6yy+/XP/+9791//33u2wrKCjQ7t27PV5I748qOl18Re69JZm9fK1atdLatWt1+PBhHT582OO+Dz/8sNMwQLtXX31Vf//9t9tp4Mv6uWnQoIHH+wS9++67OnTokJYvX+6yraCgQFu2bPF4Xn9z1VVXuVyLunjxYt1xxx0WVVTznnzySf3xxx9asGCB0/qcnBz9/vvvbo9JSkrS7NmzfXLNpqfp3TMyMir0+1TRIc5Hjx4t9xq6uLg4zZ071+MoCzt3wwyvuuqqCtUBVBRDAQELhYSE6IsvvtAzzzxTqXuxhIeH64orrnD5j6Syw8YiIiL03HPP6cYbb3S7/bXXXvM4454/GjZsmH766Sd16dKlQvvHx8fr9ddf1/Tp091uDw0NrdTrN2vWTPPmzdPJJ5/stN7X74s3XnrpJU2YMKHMfQYNGqR58+Z5vEnxxIkTNX/+fLeTWXhis9nUt2/fSt9sN9BERETo22+/LfPaFJvNpgcffFBPPPGE2+3h4eFauHCh7r///gr/7Jx//vnasGGDy8+eXWRkpBYtWqRJkyZVy2QCNenss892GQ747bffen3z4UASERGhL7/8UnfccUeFprUfPHiwVqxY4XYyH39x2mmnVXqGvgEDBmjNmjXlTsZRWFioTz75xGldvXr1dPnll1e6TqAs9FgBFgsKCtL999+vcePG6aOPPtLSpUu1fv16HTlyRBkZGYqIiFD9+vXVvn17nXLKKRowYIDOPfdct4FnwYIFWrNmjVauXKn169dr27Zt2r17t9LS0lRQUKCoqCg1btxYJ510ks477zxdd911atasmcfaevTooY0bN+rFF1/U4sWLlZycrKysLLfj2/1Fr1699Ntvv2nBggX66quv9Msvv2jfvn1KS0tTZGSkGjZsqFNPPVUDBw7UqFGjyrzv0PHjx7VixQr98ssv2rBhg7Zv3659+/YpMzNThmEoOjpaLVu2VNeuXTV48GCNHDnS7VS/vn5fvBEUFKSXX35Zw4cP1xtvvKGVK1fq0KFDiouLU8+ePTVmzBhdffXV5Z7noosu0vbt2/X1119rwYIFWrVqlfbv36+0tDQFBwcrPj5eiYmJ6tKli84++2xdcMEFfnMvoOrWoEEDLVmyRB988IHef/99bdq0ScePH1fjxo01YMAAjR8/vtwPgqGhoXrmmWd0991367333tOyZcv0+++/69ixYyooKFC9evWUmJiovn376uqrr3bb83WikJAQTZ48WXfddZc++OADLV++XBs2bFBKSooyMzNVv359NWnSRF26dNEFF1ygwYMH+6pJfMpms+mOO+5w6qHKz8/XJ598oltvvdXCympWWFiYXnrpJd1+++364IMPtHDhQu3cuVPHjh1TTEyMmjVrpv79+2vEiBFlBn1/cfvtt+vWW2/VihUrtGzZMq1fv15//fWXDh06pMzMTIWFhalevXrq0KGDTj/9dI0cOVK9evWq0LkXLlzo0kt2yy23KCIiojq+FdRhNsOfPyEBAKpk2bJlThNP2CUnJ/v1X60DyeTJk11mhWzTpk2FhrHCO9nZ2UpMTHSaRbVv37768ccfLawK/uqaa67R7NmzHV+Hh4fr77//rjN/7EHNYSggAAAIKFFRUS7XIK5cudLtNaGo25KTk12GAY4bN45QhWpBsAIAAAFn3LhxLtdaPfnkkxZVA3/1zDPPON3iIiEhoVomBgIkghUAAAhAYWFhevnll53WLViwQOvXr7eoIvib/fv3u9yY+4knnlDDhg2tKQi1HpNXAACAgDRkyBC/nkwH1mrevLnLjcuB6kSPFQAAAAB4iVkBAQAAAMBLDAU8QXFxsfbv36/Y2FjZbDarywEAAABgEcMwlJGRoebNmysoqOzBfgSrE+zfv1+tWrWyugwAAAAAfmLPnj3lTtNPsDpBbGysJLPx4uLiLK4GAAAAgFXS09PVqlUrR0YoC8HqBPbhf3FxcQQrAAAAABW6RIhZAQEAAADASwQrAAAAAPASwQoAAAAAvESwAgAAAAAvEawAAAAAwEsEKwAAAADwEsEKAAAAALxEsAIAAAAALxGsAAAAAMBLBCsAAAAA8FKI1QUAAACgbjIMQwUFBSouLra6FNRCQUFBCg0Nlc1mq5HXI1gBAACgRhUVFSklJUUZGRkqKCiwuhzUYqGhoYqNjVXDhg0VHBxcra9FsAIAAECNKSoq0p49e5SXl6f4+HjFxMQoODi4xnoVUDcYhqGioiJlZmYqNTVVOTk5atWqVbWGK4KVP3vuOendd6Ubb5TuucfqagAAALyWkpKivLw8tW7dWpGRkVaXg1ouJiZG8fHx2r17t1JSUtSkSZNqey0mr/BnKSnS5s3Srl1WVwIAAOA1wzCUkZGh+Ph4QhVqTGRkpOLi4pSRkSHDMKrtdQhW/iw+3nxMS7O2DgAAAB8oKChQQUGBYmJirC4FdUxsbKzj56+6EKz8GcEKAADUIvbZ/6p7EgHgRPafueqcgZJg5c8IVgAAoBZiogrUtJr4mSNY+TOCFQAAABAQCFb+jGAFAAAABASClT8jWAEAAAABgWDlz0oHq2qcGhIAAACAdwhW/swerAoKpNxca2sBAABArfTuu+/KZrPJZrNp586dbveZP3++LrzwQjVs2FDBwcGy2WyqV69ejdbp70KsLgBliI2VbDaztyotTeJGegAAAKhh06dP1+233251GX6PYOXPgoLMcJWebgarpk2trggAAAB1SHZ2th5++GFJUqdOnfTkk0+qXbt2CgkJ4X5kJyBY+bv4+JJgBQAAANSgtWvXKu1/n0OnTZumiy++2OKK/BfXWPk7ZgYEAACARfbt2+d43rFjRwsr8X8EK39HsAIAAIBF8vLyHM9DQ0MtrMT/Eaz8HcEKAAAAXjh+/LgefPBBderUSZGRkWrcuLEGDhyoTz75xOMxAwYMkM1m04033uhYl5SU5Jg90GazadmyZS7HHTlyRI8//rj69u2rxo0bKzQ0VAkJCTr99NN1//33a9OmTS7H5Ofna+7cuRo/frxOO+00JSQkKDQ0VA0aNNDpp5+uyZMnKyUlxSdtUZ24xsrfEawAAABQRX/++acGDhyo/fv3O9bl5uZq8eLFWrx4sW688Uadc845PnmtDz/8UGPHjlVWVpbT+tTUVK1evVqrV6/WnDlzXKZ0v/XWW/Xee++5nO/YsWOO41599VV99dVX6tu3r09qrQ4EK39HsAIAAEAVpKen68ILL3SEqpEjR2r06NFq3Lixtm3bpueff16zZs3S5s2bXY6dNWuWsrKy9NVXX+nRRx+VJH333Xdq3ry5Y5+kpCTH8/fff1833HCDJCkiIkK33HKLhgwZoqZNmyozM1ObNm3S119/rb/++svltQoLC9W2bVtdfvnl6tOnj1q3bq2QkBDt2rVLixYt0jvvvKOjR4/q8ssv1+bNm9W4cWOftpOvEKz8nT1YpadbWwcAAAACyhNPPKE9e/ZIkqZOnaqHHnrIsa1Xr14aPny4hg4dqoULF7ocaw9Na9eudazr2LGjEhMTXfY9cOCAbrvtNklS48aNtXjxYnXt2tVpn379+un222931FPalClT1LZtW9lsNqf1vXv31pVXXqn/+7//01lnnaUjR47olVde0RNPPFHBFqhZBCt/R48VAACoawxDys62uorqFxUlnRAmfCU/P19vv/22JOmUU07Rgw8+6LJPaGio3n77bbVt21YFBQVVfq1XXnlF2f97v2bMmOESqkpr1aqVy7p27dqVef5u3brpH//4h1588UV9+eWXBCtUEcEKAADUNdnZUkyM1VVUv8xMKTq6Wk69bt06HT9+XJI0evRol94gu5YtW2rQoEGaP39+lV9r3rx5kqS2bdvqkksuqfJ57I4fP65jx44pNzdXhmFIkurVqydJ+uOPP1RQUOCXMxQSrPwdwQoAAACV9Ntvvzmen3baaWXu26dPnyoHq4KCAsc1WmeffbbHAFee3377TS+88IIWLFiggwcPetyvuLhYx48f98vrrAhW/o5gBQAA6pqoKLM3p7aLiqq2Ux87dszxvLwQ0qRJE69ex96r1KxZsyqd4+2339Ztt92mwsLCCu2fk5NTpdepbgQrf0ewAgAAdY3NVm1D5OqiqvYi1YQtW7Y4QlXjxo01ceJEnXfeeUpMTFRsbKxjyN8777yjm2++WZIcQc7fEKz8HcEKAAAAlZSQkOB4fujQIXXs2NHjvocOHary69SvX19BQUEqLi7WgQMHKn38u+++q8LCQgUHB2v58uXq1KmT2/1K98D5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CRMmaNCgQVq0aJFmz56tkSNHVvo1N27cqNtuu02SFBYWpri4OOXk5CgrK8uxT1JSkj777DM1tffo1FYMBQQAAAAs47NgdeTIEUlSy5Ytndbn5OTol19+kc1m06233uq07aabbtKiRYu0fv36Sr9e8+bN9cknn2jZsmVatWqV9u/fr5SUFAUHB6t169bq3r27Lr30Ul177bWKjIys+jcWKOzBkR4rAAAAoMb5LFilpqZKkoKCnEcX/vLLLyooKFBQUJAGDhzotC0pKUmSOfFFZYWFhWn48OEaPnx41QqubeixAgAAACzjs2usYmJiJEkHT+gxWbZsmSTp5JNPVkJCgtO20P/deykkxGf5ru4iWAEAAACW8Vmw6tSpkyTp22+/dVr/2WefyWazqX///i7H2ENYE3soQNUxFBAAAACwjM+6ii6++GL98ssvmjFjhjp37qx+/frp3Xff1R9//CGbzaYrrrjC5Rj7tVX2m/jCC/ZwmpYm5eZKERHW1gMAAADUIT4LVuPHj9f06dN14MABjR8/3mnbmWeeqXPPPdflmLlz58pms+m0007zVRl1V0KCFBoqFRRIhw9LrVtbXREAAABQZ/hsKGB8fLwWLVqknj17Om4CbBiG+vXrpzlz5rjsv3HjRq1Zs0aSdMEFF/iqjLrLZuNeVgAAAIBFfDprROfOnbV27VolJyfr4MGDatasmRITEz3uP2vWLEnm/a3gA02aSHv3MoEFAAAAUMOqZTq+pKQkx1TqnnTv3l3du3evjpevu+wTWBCsAAAAgBrls6GA8AMMBQQAAAAsUaM3kJo7d67mzJmjlJQUJSUl6R//+Id69uxZkyXUbtzLCgAAALCEz3qsli5dqsaNG6t169ZKTU112f7Pf/5Tl112mT766CMtXLhQb775ps444wy9//77vioBDAUEAAAALOGzYPXNN98oJSVFp512murVq+e0bdOmTZo6dapjpsB69erJMAwVFhZq7Nix2rlzp6/KqNsYCggAAABYwmfB6scff5TNZtPAgQNdtr3++usyDEMJCQlat26djh49qtWrV6t+/frKy8vTG2+84asy6jaGAgIAAACW8FmwOnDggCSpS5cuLtvmzZsnm82m8ePH69RTT5Uk9e7dW+PHj5dhGFq0aJGvyqjb7EMB6bECAAAAapTPgtWRI0ckyWUY4Pbt27Vv3z5J0uWX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F9ZYbbVdRESE43lRUZHjOe+J79xyyy3KysrS888/r0aNGpW5L+3unf/85z+SpKuuusrpZ7s8tLt32rZtK0nauHGjCgsLXbYXFBRow4YNkqTevXs71tPu1WPr1q3avXu3JM/tGhMTo379+klybdcff/xROTk5ZR6fmJiozp07uz0ennn6P1fy/n2DlJeXp5tuukmGYWjGjBkV+n+AdvcdgpWf+PPPP1VcXCxJ6tq1q8f97NsOHjyoY8eO1Uhttd2yZcscz7t16+Z4znviGzNnztTixYs1cOBA3XDDDeXuT7tXXV5entauXStJ6tWrl3bv3q1bb71VrVq1UlhYmJo0aaJhw4Zp/vz5LsfS7t4ZN26cJOnvv//WNddco7///tuxbevWrRoxYoR27Nihdu3a6e6773Zso92rx+bNmx3PK9Kuf/zxh1fH//7771Wqsy6y/58bFhamjh07Om3z9n2D9Pjjj+vPP//UzTffrP79+1foGNrddwhWfmL//v2O5y1atPC4X+ltpY9B1aSmpuqpp56SJPXr108nnXSSYxvviff27duniRMnKjIyUm+++WaFjqHdq27nzp2Oabl37Nihrl27aubMmTp8+LCio6N1+PBhzZs3T0OHDtUtt9ziNHUu7e6dYcOG6YUXXlBYWJg+/fRTdejQQVFRUYqKilKnTp20bNkyjRs3TqtXr1ZcXJzjONq9elS2XdPT05WZmelyfEJCgiIjI8s9nvekYpKTk/XGG29IkkaOHOn0uyB5/77Vdb/++qv+/e9/q0mTJnr22WcrfBzt7jsEKz+RkZHheB4VFeVxv9LbSh+DyisuLtaoUaN04MABRURE6NVXX3XaznvivbFjxyotLU2TJ092DJUqD+1edcePH3c8f/LJJxUaGqpPPvlEmZmZOn78uHbt2qWrrrpKkvTWW2/phRdecOxPu3vvrrvu0ueff67GjRtLknJychzDyfLz85WZmam0tDSnY2j36uFtu9qfl3Vs6e28J+XLycnRVVddpezsbDVs2FBPP/20yz78PlRdYWGhbrrpJhUWFurll19WvXr1Knws7e47BCvUWXfeeafmzZsnSXrttdd0yimnWFxR7fLBBx9o/vz56tGjh+655x6ry6kT7EPK7M/ffvttDR8+XKGhoZKk1q1ba/bs2erevbskaerUqW6vB0LlZWdna+TIkRo6dKhat26thQsX6siRIzpy5IgWLlyok08+We+//7769OmjTZs2WV0uUKMKCwt17bXXat26dQoNDdWHH36o5s2bW11WrfL0009rw4YNGjp0qEaMGGF1OXUWwcpPxMbGOp5nZ2d73K/0ttLHoHLuu+8+Rw/VCy+8oJtuusllH96Tqjt06JDuuusuBQcHa+bMmQoJCanwsbR71ZVuhw4dOuiyyy5z2ScoKEj33XefJOno0aNat26dy7G0e+VNnDhRc+bM0UknnaQVK1boggsuUMOGDdWwYUNdcMEF+uGHH9SxY0elpKTo9ttvdxxHu1cPb9vV/rysY0tv5z3xrKioSNddd52+/PJLhYSE6KOPPtKgQYPc7svvQ9X88ccfeuKJJxQTE6Pp06dX+nja3XcIVn6i9F9u9u3b53G/0tv4a0/V3H///XruueckSdOmTdNdd93ldj/ek6p78MEHdfToUd16663q1KmTMjMznRb7dUCSXNbR7lVXemx8p06dPO538sknO57v2rVLEu3ujYyMDM2YMUOSdPvtt7udhSsyMlLjx4+XZM44d/jwYUm0e3WpbLvGxcUpJibG5fjjx487hnOWdTzviXtFRUW6/vrrNWfOHAUHB+uDDz7Q8OHDPe7v7ftWV91+++3Kz8/XI488ooSEBJf/c+0jEwzDcKwrKChwHE+7+w7Byk907txZQUHm21F6dpYT2bc1bdpU9evXr5HaapOJEyc6Luj897//rXvvvdfjvrwnVZecnCxJev311xUbG+uy2CcMkeRYd//990ui3b1Rv379Mi88tis9aYXNZpNEu3tj27Ztjg8u7dq187hfhw4dHM/tvyO0e/UoPbNZRdq19B8bqnJ8ly5dqlRnbWbvqZo9e7YjVI0cObLMY7x93+oq+78nDz30kNv/cz/88ENJ0u7dux3rXnvtNcfxtLvvEKz8RFRUlPr27StJ+vbbb93uYxiGvvvuO0ny2I0Oz+677z5NmzZNkhmqJk6cWOb+vCfWoN29Y2+PP//80+M+pafKTUpKkkS7e8MejKSSHkB3Dh065HhuH0ZDu1ePjh07qnXr1pI8t2tWVpZWrFghybVdzz77bMdsgJ6O37Vrl+P3jPfFWVFRka699lr997//dYSqq6++utzjvH3fUDW0uw9ZdmtiuHjrrbcMSYbNZjN++eUXl+3//e9/HXcrX7RokQUVBq57773X0XbTpk2r8HG8J9Vj0qRJjnZzh3avuh9++MHRNl988YXL9qKiIuOUU04xJBktWrQwioqKHNto96rJzs42IiMjDUlGz549jYKCApd9CgsLjbPOOsuQZCQkJBiFhYWObbR75bRp08aQZEyaNKnM/R599FFDkhEVFWUkJye7bH/mmWcMSUZwcLCxdetWl+3XX3+9Iclo1qyZkZqa6rJ93LhxhiQjNjbWOHbsWFW/nYBR0XYvLCw0Ro4caUgyQkJCjNmzZ1fqdbx932qbirZ7WUaPHm1IMtq0aeNxH9rdNwhWfqSgoMDo1q2b4wOP/T/QoqIiY86cOUZcXJwhyRgyZIjFlQaWiRMnOj6UPP/885U6lvekepQXrGh37wwfPtyQZDRo0MD49NNPHR/0d+3aZYwYMcLR9u+++67TcbR71U2YMMHRroMHDzY2bdpkFBUVGUVFRcbGjRuNQYMGObZPmTLF6VjavWzHjh0zjhw54lhatWplSDImTpzotD4jI8PpuNTUVKNp06aGJOPkk0821q5daxiGYeTl5RnTp083wsLCDEnGuHHj3L7ujh07jOjoaEOS0a9fP2Pbtm2GYRhGZmamMWXKFMNmsxmSjGeeeaZ6G8AiVWn3wsJC4+qrr3aEqjlz5lT6db193wJdVX/ey1KRYFXX291XCFZ+Jjk52UhMTHT8BxwVFWVEREQ4vj711FPrxF/GfGXXrl2OtgsKCjKaNGlS5vLss8+6nIP3xPfKC1aGQbt7IzMz0zjnnHMcbRUeHm4kJCQ4vi7rr5+0e9VkZ2cbgwcPdmrj8PBwIzw83GndNddc49RbZUe7e2b/i315y+jRo12OXbt2rdGgQQPHPrGxsUZoaKjj60GDBhm5ubkeX3v+/PlGVFSUY//4+HgjODjY8fWNN95oFBcXV+N3b52qtPvy5csd60NDQ8v9P9dTb5a371sg8+bn3ZOKBCvDqNvt7itcY+VnEhMTtWnTJj322GPq2rWrbDabQkND1atXL02bNk2//PKLEhISrC4zYJx4X59Dhw6Vubi7kzjviTVo96qLjo7W0qVLNXPmTJ1zzjmKjo5WZmamWrRooauvvlorV67U5MmT3R5Lu1dNZGSkvvnmG33yySe69NJL1bJlS8ckIa1atdKVV16pefPm6aOPPlJwcLDL8bR79ejVq5d+//133X333erQoYMKCgoUHR2ts88+WzNnztSCBQsUHh7u8fiLLrpImzZt0i233KLExETl5uYqISFBF1xwgT799FO98847jglg4Px/bkFBQbn/53qacdHb9w1VQ7t7z2YYpaaHAgAAAABUGj1WAAAAAOAlghUAAAAAeIlgBQAAAABeIlgBAAAAgJcIVgAAAADgJYIVAAAAAHiJYAUAAAAAXiJYAQAAAICXCFYAAAAA4CWCFQAAAAB4iWAFAIDFBgwYIJvNpgEDBlhdCgCgighWAAAAAOAlghUAAAAAeIlgBQAAAABeIlgBAAAAgJcIVgAAAADgJYIVAMAvLF26VKNHj1bbtm0VFRWluLg4devWTRMnTtT+/fvdHjN58mTZbDbZbDZJUmpqqiZNmqQuXbooJiZG9evX17nnnquPP/64QjXs3LlTd999t7p06aLY2FhFRUWpQ4cOGjt2rH777bcKnSMjI0PPPfeczjvvPDVt2lRhYWGKi4vTqaeeqgkTJmjlypXlnmPfvn2655571L59e0VGRqpBgwa68MILtWDBggrVAACwgAEAgIVycnKMq6++2pDkcYmOjja+/vprl2MnTZrk2GfHjh1Gu3btPJ5jxIgRRkFBgcc63nvvPSM8PNzj8cHBwcbUqVPL/F6+//57o2HDhmV+L+7+6+3fv78hyejfv7/x448/lnmOZ599tvKNDACodvRYAQAsYxiGhg8frtmzZ0uShg0bpvfff18rV67Uzz//rJdeekmtW7dWVlaWhg8frrVr13o818iRI5WcnKzbbrtNixYt0po1a/T222+rY8eOkqQ5c+Zo4sSJbo+dP3++xowZo7y8PMXExGjSpElasWKFfv75Zz333HNq2LChioqK9PDDD+v11193e46lS5dqyJAhSklJUXBwsMaMGaMvvvhC69at08qVKzVz5kxdccUVCg0N9fg9HDhwQJdddpmCgoL09NNP68cff9Tq1av1/PPPq169epKkhx56SL///ntFmhcAUJOsTnYAgLprxowZhiQjNDTUWLBggdt9jh07ZnTp0sWQZPTt29dpW+keK0nGRx995HJ8enq60b17d0OSERQUZPz2229O2/Pz843mzZsbkoyYmBjj119/dTnHzp07jWbNmhmSjKioKOPIkSNO23NychzniIqKMpYuXerxe969e7fLOnuPlSSjTZs2xt69e132WbFihWGz2QxJxh133OHx/AAAa9BjBQCwhGEYeuaZZyRJd9xxhwYPHux2v4SEBD377LOSpJUrV+qvv/5yu9/QoUN1zTXXuKyPjY3VjBkzJEnFxcV64403nLZ/8cUXjmu4Hn30UfXo0cPlHG3atHHUkJ2drVmzZjlt/89//uM4x9SpUzVgwAC3NUpSq1atPG6TpFdeeUUtWrRwWX/22Wfr9NNPlyStWLGizHMAAGoewQoAYIk//vhD27dvlyQNHz68zH3POeccx/Off/7Z7T433nijx+P79OmjLl26SJIWLVrktM3+tc1m00033eTxHFdddZXi4+PdnmPevHmSpOjoaN1yyy0ez1GeevXq6eKLL/a4vVevXpKkHTt2VPk1AADVg2AFALBE6eulzjzzTMfsfu6WmJgYx74HDx50e77TTjutzNfr06ePJGnbtm3Kz893rN+8ebMkKSkpSY0aNfJ4fFhYmE499VSnY+x+/fVXSWbwiYqKKrOOsnTo0EFBQZ7/a65fv74kc+ZBAIB/IVgBACxx+PDhKh2XnZ3tdn3jxo3LPK5JkyaSzCGIx48fd6w/duxYhY6XpKZNmzodY5eSkiJJatasWbnnKEt5ocweuoqLi716HQCA74VYXQAAoG4qKipyPJ87d64SExMrdJynAGS/l1VVeXs8AKBuI1gBACzRoEEDx/N69eqpa9euXp3v0KFDZU4McejQIUlmgEpISHCstw+vs28vi30Yov0Yu4YNG2rv3r06cOBApesGANQODAUEAFjCfr2SZM725601a9ZUaHuHDh0UFhbmWG8PdMnJyTpy5IjH4wsKChzXUp0YAnv27CnJvG7M01BFAEDtRrACAFiiZ8+eatmypSRpxowZys3N9ep87733nsdta9ascUw4MXDgQKdt9q8Nw3CZRr20Tz/9VGlpaW7PMWzYMEnm9V/2qd0BAHULwQoAYImgoCA9/PDDkszpw2+44Qbl5eV53D89PV2vvvqqx+1ff/215syZ47I+MzNTY8eOdbym/bndZZddpubNm0uS/vWvf+m3335zOceePXt03333STInmDhxavfrr7/ece+pRx55RMuXL/dY5969ez1uAwAELq6xAgBY5rbbbtP333+vL774Qp988onWr1+vsWPHqk+fPoqPj1d6erq2bNmiZcuW6euvv1ZERITGjx/v9ly9e/fWtddeq+XLl2v48OGKi4vTpk2b9Mwzz2jr1q2SpNtvv12nnHKK03FhYWGaMWOGhg0bpvT0dPXt21cTJ07U+eefr+DgYP300096+umnHbMYTps2TQ0bNnQ6R0REhN5//30NGjRI2dnZGjhwoEaNGqXLLrtMLVu2VF5enrZs2aJvvvlGX3/9dZkBEgAQmGyGYRhWFwEAqLsKCgp055136o033lB5/yUlJSU53Rx38uTJmjJliiSz1+v8889XcnKy22OvvPJKzZ49WyEh7v+m+N5772ns2LEeQ09wcLCeeOIJPfTQQx7r++6773TNNdc4Tefuzonf54ABA7R8+XL1799fy5Yt83hc6e+X/74BwL8wFBAAYKnQ0FBNnz5dGzdu1IQJE9StWzfFx8crODhY8fHx6tGjh26++WZ9+umn+vPPPz2eJykpSevWrdPDDz+szp07KyoqSvHx8TrnnHP0wQcf6NNPP/UYqiRp9OjR2rJli+6880517txZ0dHRioyMVLt27XTLLbfo119/LTNUSdKFF16oHTt2aOrUqTrrrLPUoEEDBQcHKy4uTj179tRdd92l1atXV7mtAAD+ix4rAEDAogcHAOAv6LECAAAAAC8RrAAAAADASwQrAAAAAPASwQoAAAAAvESwAgAAAAAvMSsgAAAAAHiJHisAAAAA8BLBCgAAAAC8RLACAAAAAC8RrAAAAADASwQrAAAAAPASwQoAAAAAvESwAgAAAAAvEawAAAAAwEv/D6zDhvRElzTuAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 1000x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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KstUwyS7dGHQRkRERERkAJMCt9jYWABAq1at1MekAvcrPTn5iI2NDd544w0IIbBo0SJTLk1lGZcBICIiIiIyikmBW3p6OgCgatWq6mMuLi7q/eTkZK089f4/g+A///xjyqWprLp1C/jnH8DGBuje3dK1ISIiIiIqE0wK3Dw9PQEAWVlZ6mOVKlVS71+/fl0rjyqYe/jwoSmXprJK1dvWsiXg62vZuhARERERlREmBW61a9cGANy4cUN9zN3dHdWrVwcA7NixQyvPzp07AQBeXl6mXJrKKg6TJCIiIiIymkmBW8uWLQEAR48e1Tjes2dPCCHw9ddfY+/everja9aswffffw9JktC6dWtTLk1lUWoqoHo99O5t2boQEREREZUhJi0HsHfvXnTs2BFBQUG4efOmem22W7duISIiApmZmQAAHx8fZGVlISMjA0II2Nra4sCBA3j66afN8yjKkAq9HMDvvwP9+gFhYcC1a1x4m4iIiIgqtFJbDiAqKgrTp0/HqFGjEBcXpz5erVo1rF27Fp6enhBC4NGjR0hPT4cQAo6Ojvjll18qZNBW4al627p1Y9BGRERERGQEO1MyS5KE6dOn6zzXrVs3XLt2DevWrcOFCxegUCgQHh6OgQMHIjg42JTLUll17Jj8s8DyEUREREREVDSThkqS8SrsUMmsLMDDA8jNBW7cAEJDLV0jIiIiIiKLMiY2MKnHbfTo0QDk3rUBAwaYUhSVd6dPy0Fb5cpASIila0NEREREVKaYFLgtXboUADBo0CCzVIbKMdUwyaef5v1tRERERERGMmlyksqVKwMA/P39zVIZKsdUgVuLFpatBxERERFRGWRS4BYREQEAuHnzplkqQ+WYaq0/Bm5EREREREYzKXAbPnw4hBDqIZNEOiUkALGx8hDJZs0sXRsiIiIiojLHpMBt1KhR6NixI/7880/MmDEDnKCSdFINk6xbF/D0tGxdiIiIiIjKIJMmJzlw4ADeeecdPHjwAJ988gl+++03DBo0CA0aNIC3tzdsbW0Lzd+uXTtTLk9lBYdJEhERERGZxKTALSoqClKBGQKvXr2KTz75xKC8kiRBoVCYcnkqKwrOKElEREREREYzKXADwOGRVDilEjhxQt5njxsRERERUbGYFLjt3bvXXPWg8uryZSAlBXBxAerVs3RtiIiIiIjKJJMCt/bt25urHlRe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IEkS2rdvr3Vu0aJFAIBatWrhwoULWL9+Pc6fP4+6desCABYsWGDKpak0qe5v8/cHnJwsWxciIiIiogrIpMAtISEBAFCzZk2N40qlErt374YkSXj99dfh7u4OAPD09MRrr70GIQSOHDliyqWpNHGYJBERERGRRZkUuD18+BAA4OzsrHH8zJkzSElJAQD06NFD41z9+vUBALdv3zbl0lSaGLgREREREVmUSYGb6r42VQCnsn//fgDyvW3Vn1iwWdX7lpeXZ8qlqTQxcCMiIiIisiiTAjdVUHbs2DGN45s2bYIkSWjXrp1WnsTERABA5cqVTbk0lSZV4PZEEE5ERERERKXDpMCtQ4cOEELgxx9/xKVLlwAAGzduxL59+wAA3bt318pz/vx5AEBgYKApl6bSxMW3iYiIiIgsyqTA7fXXX4eDgwMSEhJQv359+Pr6om/fvhBCIDg4GP369dPKs2PHDkiShAYNGphyaSpNHCpJRERERGRRJgVu4eHhWL58OVxcXCCEQGJiIoQQ8PLywqpVq+Dg4KCR/t69e9i5cycA4JlnnjHl0lRasrOBe/fkfQZuREREREQWYWdqAQMGDED79u2xZcsW3Lt3D4GBgejduzd8fHy00p49exZDhw4FoHsYJVmhO3fkn87OgK+vZetCRERERFRBSUIIYelKVCQpKSnw9PREcnIyPDw8LF2dou3ZA3TsCNSqBVy5YunaEBERERGVG8bEBiYNlaQKIDZW/hkSYslaEBERERFVaCYPlSwoMzMTJ0+exL1795CRkYHnnnuubPQqkX4M3IiIiIiILM4sgdvt27fx/vvvY+3atcjNzVUfb9q0KSIiItS/L1y4EP/973/h6empnl2SrJwqcAsNtWg1iIiIiIgqMpOHSh47dgyNGjXCr7/+ipycHAghoO+2uV69euHs2bPYs2cPduzYYeqlqTSwx42IiIiIyOJMCtySkpLQp08fJCYmIiAgAHPnzsW5c+f0pvfz80O3bt0AAFu2bDHl0lRaYmLknwzciIiIiIgsxqShkj/88AMSEhLg6+uLI0eOoJoB63x16tQJf/75J44fP27Kpak05OQAcXHyPodKEhERERFZjEk9bps2bYIkSXjrrbcMCtoAoF69egCA69evm3JpKg23bwNCAE5OgJ+fpWtDRERERFRhmRS4/fvvvwCAdu3aGZzH29sbgLxmAVm5gsMkOZEMEREREZHFmBS4ZWVlAQDs7e0NzpOeng4AcHZ2NuXSVBo4oyQRERERkVUwKXDz+//wuRhVz4wBzpw5AwAICgoy5dJUGjijJBERERGRVTApcGvRogUAYOvWrQalF0Lgl19+gSRJaNu2rSmXptLAwI2IiIiIyCqYFLgNGzYMQgisXLlS3ZNWmLfffhv//PMPAGDkyJGmXJpKg6onlUMliYiIiIgsyqTArU+fPujQoQMUCgU6duyIefPmISEhQX1eoVAgPj4ea9euRdu2bfH9999DkiQ8//zzaNWqlcmVpxLGHjciIiIiIqsgCSGEKQUkJSWhY8eOOH36NKQiZh4UQuDpp5/Gzp074erqasply6yUlBR4enoiOTkZHh4elq6OftnZ8jIAAJCQAFSubNn6EBERERGVM8bEBib1uAGAl5cXjhw5gqlTp8LDwwNCCJ2bs7MzpkyZgn379lXYoK1MuXlT/unqCvj6WrYuREREREQVnMk9bgWlp6fj77//RnR0NBISEpCXl4dKlSqhUaNG6NSpEzw9Pc11qTKrzPS47dgBdOkC1KsHnD9v6doQEREREZU7xsQGdua8sKurK7p3747u3bubs1iyBN7fRkRERERkNUwK3Pbv3w8AaNasmcELamdlZeH48eMAgHbt2plyeSpJqhklGbgREREREVmcSYFbVFQUbGxscPbsWURERBiUJy4uTp1PoVCYcnkqSaoeNy4FQERERERkcSZPTlLcW+TMeGsdlQQOlSQiIiIishomB27GUiqVAABbW9vSvjQZg4EbEREREZHVKPXA7eb/p5nnDJNWLDMTuHdP3udQSSIiIiIiizPqHrdbt27pPH737l24ubkVmjc7OxvXr1/HRx99BEmSUK9ePWMuTaVJtYabuzvg7W3ZuhARERERkXGBW6iO3hchBDp37mz0hUeMGGF0HiolBYdJSpIla0JERERERDAycNM3oYgxE404OTnhjTfewOjRo425NJUm1VIAHCZJRERERGQVjArcFi9erPH7qFGjIEkSPvnkEwQHB+vNJ0kSnJycEBgYiEaNGhU5rJIsjBOTEBERERFZFaMCt5EjR2r8PmrUKADAc889Z/A6blQGMHAjIiIiIrIqJi3AvXfvXgC6732jMoyLbxMRERERWRWTArf27dubqx5kTVT3uLHHjYiIiIjIKpT6Om5k5dLTgQcP5H0GbkREREREVoGBG2lSreHm6Ql4eVm0KkREREREJGPgRpq4FAARERERkdVh4EaaOKMkEREREZHVYeBGmhi4ERERERFZHQZupIlLARARERERWR0GbqSJSwEQEREREVkdBm6kiUMliYiIiIisDgM3yqdQAI8eyfuBgZatCxERERERqTFwo3xJSfn7XMONiIiIiMhqMHCjfI8fyz/d3AB7e8vWhYiIiIiI1Bi4UT5V4Obtbdl6EBERERGRBgZulE8VuPn4WLYeRERERESkgYEb5WOPGxERERGRVWLgRvkYuBERERERWSUGbpSPgRsRERERkVVi4Eb5GLgREREREVklBm6Uj4EbEREREZFVYuBG+RIT5Z8M3IiIiIiIrAoDN8rHHjciIiIiIqvEwI3yMXAjIiIiIrJKZT5wS01NxYwZMxAZGQk3Nzd4enqiWbNmmD17NnJycopVZlxcHObOnYsBAwagZs2acHZ2hrOzM0JDQzFkyBDs2bPHzI/CSjBwIyIiIiKySpIQQli6EsV18+ZNREVFITY2FgDg4uKCvLw8ZGdnAwAaNWqE3bt3w9uIQOT27duoXr06CjaLi4sLhBDIzMxUHxs9ejR+/vln2NraGlXnlJQUeHp6Ijk5GR4eHkblLXEeHkBqKnDlClCrlqVrQ0RERERUrhkTG5TZHjeFQoFevXohNjYWgYGB2LlzJ9LT05GRkYHVq1fD3d0dp0+fxvDhw40qNy8vD0IIdOzYEUuXLkVcXBzS09ORlpaGCxcuoE+fPgCARYsWYcaMGSXwyCxEoZCDNgDw8bFsXYiIiIiISEOZ7XFbuHAhXn75ZQDA4cOH0bJlS43zq1atwtChQwEAu3btQseOHQ0qNzk5GdevX0fjxo11nhdCoHv37ti2bRvc3Nzw4MEDODk5GVxvq+1xe/gQqFxZ3s/NBezsLFsfIiIiIqJyrkL0uC1duhQA0KFDB62gDQAGDx6M0NBQAMCyZcsMLtfT01Nv0AYAkiRh9OjRAIC0tDRcunTJmGpbL9X9be7uDNqIiIiIiKxMmQzcMjIycOjQIQBAt27ddKaRJAldu3YFAOzYscOs1y/Yw5aXl2fWsi2GE5MQEREREVmtMhm4Xbp0CUqlEgBQv359velU5+7du4dE1eLSZrBv3z4AgIODA2qVl0k8uPg2EREREZHVKpNj4uLj49X7wcHBetMVPBcfHw8fM0y6ERMTg/nz5wMABg0aVORY1OzsbPUsl4A8jtUqsceNiIiIiMhqlcket1TV7IeQp+rXp+C5gnmKKzMzEwMGDEBGRgZ8fX3xxRdfFJnn888/h6enp3qrWrWqyfUoEQzciIiIiIisVpkM3CxBoVBg6NChOHnyJOzt7bFy5UoEBQUVmW/q1KlITk5Wb7dv3y6F2hYDAzciIiIiIqtVJodKuru7q/czMjL0pit4rmAeY+Xl5WHYsGH4448/YGdnh19//RWdO3c2KK+joyMcHR2Lfe1Sw8CNiIiIyhkhBHJzc9VzIxCZk42NDezt7SFJUqlcr0wGbgV7uuLi4tCgQQOd6eLi4nTmMUZeXh6GDx+ONWvWwNbWFitWrED//v2LVZZVY+BGRERE5UReXh4ePnyI1NRU5ObmWro6VI7Z29vD3d0dvr6+sLW1LdFrlcnArW7durCxsYFSqcT58+f1Lglw/vx5AEBAQECxJiZR9bT99ttv6qBt0KBBJtXdaqkCNzNM4EJERERkKXl5ebh9+zays7Ph6ekJNzc32NrallqvCFUMQgjk5eUhLS0NSUlJyMzMRNWqVUs0eCuTgZuLiwtat26NAwcOYNu2bZg8ebJWGiEEtm/fDgAGD2ssKC8vD0OHDtXoaRs8eLDJdbda7HEjIiKicuDhw4fIzs5GtWrV4OzsbOnqUDnn5uYGT09P3Lp1Cw8fPoS/v3+JXavMTk4ycuRIAMDevXtx7NgxrfNr167FjRs3AAAjRowwqmxVT9uaNWtgZ2eHlStXlu+gDWDgRkRERGWeEAKpqanw9PRk0EalxtnZGR4eHkhNTYUQosSuU6YDt8jISAgh0K9fP+zevRsAoFQqsXbtWowZMwYA0K1bN3Ts2FEj74wZMyBJEiRJQmxsrMY51T1tv/32m3oiknI7PLIgLsBNREREZVxubi5yc3Ph5uZm6apQBePu7q5+/ZWUMjlUEgDs7OywceNGdOjQAbGxsejUqRNcXFygVCqRlZUFAGjUqBFWrlxpVLmHDh3C6tWrAQCSJOH111/H66+/rjf9999/Xz4CO/a4ERERURmnmj2ypCeJIHqS6jVXkjOYltnADQBCQkJw9uxZzJo1C7///jtiYmJgb2+PevXqYciQIXj99dfh4OBgVJkFGzs3Nxf3798vNH1mZmax6m5VcnOBtDR5n4EbERERlXGciIRKW2m85iRRkgMxSUtKSgo8PT2RnJwMDw8PS1dH9uAB4Ocn7+fmAnZlOp4nIiKiCiorKwsxMTEIDQ2Fk5OTpatDFUhxX3vGxAZl9h43MiPVMEl3dwZtRERERERWiIEb8f42IiIiIiIrx8CNGLgREREREVk5Bm7EwI2IiIiISsySJUv0LsWlsmXLFnTp0gW+vr6wtbWFJEnw8vIq1XpaO97QRPmBm4+PZetBRERERBXO3LlzMWHCBEtXw+oxcCP2uBERERGRRWRkZOD9998HANSpUweffvopwsLCYGdnx/X4nsDAjYDERPknAzciIiIiKkXR0dFITk4GAMyaNQs9evSwcI2sF+9xI/a4EREREZFFxMXFqfdr1aplwZpYPwZuxMCNiIiIiCwiOztbvW9vb2/Bmlg/Bm7EwI2IiIiIiu3x48d47733UKdOHTg7O8PPzw+dOnXC2rVr9eaJioqCJEkYNWqU+lhoaKh69klJkrBv3z6tfA8ePMDMmTPRunVr+Pn5wd7eHt7e3mjRogWmTJmCs2fPauXJycnBpk2b8Nprr6FZs2bw9vaGvb09KlWqhBYtWmDGjBl4+PChWdqiJPEeN2LgRkRERETFcunSJXTq1Anx8fHqY1lZWdi9ezd2796NUaNGoV27dma51sqVKzFu3Dikp6drHE9KSsLx48dx/PhxrFmzRmvJgbFjx2Lp0qVa5SUmJqrz/fTTT/jzzz/RunVrs9S1JDBwIwZuRERERGS0lJQUdOnSRR20DRo0CCNHjoSfnx+uXr2Kb775BosXL8b58+e18i5evBjp6en4888/8eGHHwIAtm/fjqCgIHWa0NBQ9f7y5csxYsQIAICTkxPGjBmDbt26ISAgAGlpaTh79iw2btyIa9euaV1LoVCgRo0a6Nu3L5o3b45q1arBzs4ON2/exK5du7Bo0SI8evQIffv2xfnz5+Hn52fWdjIXSQghLF2JiiQlJQWenp5ITk6Gh4eHpasjc3cH0tKAq1eB8HBL14aIiIioWLKyshATE4PQ0FA4OTlZujrl3uTJkzFr1iwAwGeffYapU6dqnM/NzUXPnj2xY8cO9bGYmBiEhISof1+yZIl6uOST51Tu3r2LmjVrIiMjA35+fti9ezfq16+vs063b99G1apVNY5dv34dNWrUgCRJOvOcO3cOrVq1QlpaGj788EN88sknRT72JxX3tWdMbMAet4ouN1cO2gD2uBEREVHFIASQkWHpWpQ8FxdAT7BiqpycHCxcuBAA0KBBA7z33ntaaezt7bFw4ULUqFEDubm5xb7Wjz/+iIz/P18///yz3qANgFbQBgBhYWGFlh8ZGYmXX34Z3333Hf74449iBW6lgYFbRZeUlL/v5WWpWhARERGVnowMwM3N0rUoeWlpgKtriRR98uRJPP7/7TYjR47U25tVpUoVdO7cGVu2bCn2tTZv3gwAqFGjBnr37l3sclQeP36MxMREZGVlQTX40Ov/n4MvXryI3Nxcq5zhkoFbRadafNvDA7Djy4GIiIiIinbu3Dn1frNmzQpN27x582IHbrm5uep75Nq0aaM3QCzKuXPn8O2332Lr1q24d++e3nRKpRKPHz+2yvvc+Em9ouPEJERERFTRuLjk3ypSnrm4lFjRiaov/4Eigxx/f3+TrqPqFQsMDCxWGQsXLsQrr7wChUJhUPrMzMxiXaekMXCr6Bi4ERERUUUjSSU2hLAiKm4vWGm4fPmyOmjz8/PD5MmT8cwzzyAkJATu7u7qIZGLFi3CSy+9BACw1rkbGbhVdAzciIiIiMhI3gU+O96/fx+1atXSm/b+/fvFvo6Pjw9sbGygVCpx9+5do/MvWbIECoUCtra2+Pvvv1GnTh2d6Qr2IForG0tXgCyMgRsRERERGSkyMlK9f+LEiULTFnW+MPb29upZJA8cOGB0b9iFCxcAAA0bNtQbtAFAdHR0setYWhi4VXQM3IiIiIjISE2aNFH3ui1fvlxvQBUXF6exjltx9OrVC4C8ztuff/5pVF7VfW3p6el609y9excbN24sfgVLCQO3io6BGxEREREZydHRUb1w9pkzZ/D1119rpVEoFBgzZgxycnJMutZrr70G1//fkzhu3Dj1LJO63LlzR+P38PBwAMC1a9dw+PBhrfQZGRkYOnSo1U5IUhADt4qOgRsRERERFcO0adNQpUoVAMC7776LoUOHYtu2bTh16hRWr16NVq1aYevWrWjatKlJ1wkICMC8efMAAAkJCWjevDnefPNNbNu2DWfOnMHBgwcxf/58dO/eHe3bt9fI+8ILLwCQp/nv0aMHPvvsM+zfvx/Hjx/HvHnz8NRTT2Hfvn1o3bq1SXUsDZycpKJj4EZERERExeDp6Ylt27ahU6dOuHfvHlatWoVVq1ZppHnxxRfRvn17de9ccb3wwgtQKpUYP348MjMz8cMPP+CHH37QSle9enWN35s1a4aPP/4Y06dPR1JSEj744AOtPG+//Tbq16+PQ4cOmVTHksYet4pONYMOAzciIiIiMlK9evVw4cIFTJkyBeHh4XB0dISvry86dOiAX3/9FYsXLzbbtUaOHInr16/jgw8+QJMmTeDl5QVbW1t4e3vj6aefxvvvv49t27Zp5Zs2bRq2bNmCzp07w9vbGw4ODqhSpQqef/557NixA7NmzTJbHUuSJKx1oYJyKiUlBZ6enkhOToaHh4elqwM0aACcOwds3w507mzp2hAREREVW1ZWFmJiYhAaGgonJydLV4cqkOK+9oyJDdjjVtFxqCQRERERkdVj4FbRMXAjIiIiIrJ6DNwqstxcQLWmBQM3IiIiIiKrxcCtIlP1tgGAl5fFqkFERERERIVj4FaRqQI3Dw/A1taydSEiIiIiIr0YuFVkvL+NiIiIiKhMYOBWkTFwIyIiIiIqExi4VWRcfJuIiIiIqExg4FaRsceNiIiIiKhMYOBWkakCNx8fy9aDiIiIiIgKxcCtImOPGxEREZVDQghLV4EqmNJ4zTFwq8gYuBEREVE5YmMjf7RVKpUWrglVNKrXnOo1WBIYuFVkDNyIiIioHLGzs4ONjQ2ysrIsXRWqYLKysmBjYwM7O7sSuwYDt4rsiy+A7duB7t0tXRMiIiIik9nY2MDFxQVpaWmWrgpVMGlpaXBxcWGPG5WQOnWAzp2BatUsXRMiIiIis/Dw8EBGRgYeq0YWEZWwx48fIyMjAx4eHiV6nZLryyMiIiIiKmWenp7IzMzEvXv3kJ6eDk9PT9jZ2UGSJEtXjcoRIQQUCgWSk5ORmpoKb29veHp6lug1GbgRERERUbni7+8PBwcHJCUl4c6dO5auDpVjjo6O8Pf3h3cpzBnBwI2IiIiIyhVJkuDj4wNvb28oFArk5eVZukpUDtna2pZqby4DNyIiIiIqlyRJgr29Pezt7S1dFSKTcXISIiIiIiIiK8fAjYiIiIiIyMoxcCMiIiIiIrJyDNyIiIiIiIisHAM3IiIiIiIiK8fAjYiIiIiIyMoxcCMiIiIiIrJyDNyIiIiIiIisHAM3IiIiIiIiK8fAjYiIiIiIyMrZWboCFY0QAgCQkpJi4ZoQEREREZElqWICVYxQGAZupSw1NRUAULVqVQvXhIiIiIiIrEFqaio8PT0LTSMJQ8I7MhulUon4+Hi4u7tDkiSL1iUlJQVVq1bF7du34eHhYdG6VCRsd8tgu1sG290y2O6WwXa3DLa7ZbDdzUMIgdTUVAQFBcHGpvC72NjjVspsbGxQpUoVS1dDg4eHB99wFsB2twy2u2Ww3S2D7W4ZbHfLYLtbBtvddEX1tKlwchIiIiIiIiIrx8CNiIiIiIjIyjFwq8AcHR0xffp0ODo6WroqFQrb3TLY7pbBdrcMtrtlsN0tg+1uGWz30sfJSYiIiIiIiKwce9yIiIiIiIisHAM3IiIiIiIiK8fAjYiIiIiIyMoxcCMiIiIiIrJyDNwqoNTUVMyYMQORkZFwc3ODp6cnmjVrhtmzZyMnJ8fS1StzHj16hMWLF2P48OGIiIiAq6srHB0dUaVKFTz33HPYsGFDkWXwOTGfL774ApIkqbfCsN1Nk5KSgi+//BKtWrVC5cqV1a/7Dh06YMaMGUhKStKZj+1efDt37sTAgQNRvXp1ODk5wdnZGTVq1MCwYcPw999/F5qX7a4tIyMDW7duxaeffornn38e1atXV//tmDFjhkFl3L9/H2+//TZq164NZ2dn+Pj4oG3btliwYAEMmf/t+vXrGDduHEJDQ+Hk5ITKlSujS5cuWL9+vYmPznqZ0u5xcXGYO3cuBgwYgJo1a8LZ2RnOzs4IDQ3FkCFDsGfPHoPqYOrzVhaZ4/X+pFdeeUVdRkhISJHpK2K7m5WgCiU2NlaEhIQIAAKAcHFxEY6OjurfGzVqJBITEy1dzTLFzs5O3X4AhJOTk3B1ddU41q1bN5Genq4zP58T87l8+bJwcnLSaHt92O6m2bNnj/D391e3l4ODg/Dy8tJo+9OnT2vlY7sXj1KpFOPGjdNoX2dnZ+Hs7KxxbNKkSTrzs91127t3r0b7FdymT59eZP7o6GhRqVIldR43NzeN/wldunQR2dnZevNv2bJFuLi4qNN7eHgIGxsb9e+jRo0SSqXSjI/YOhS33W/duiUkSdJI7+LiovU+GD16tFAoFHrLMfV5K6tMfb0/ac+ePRrPR/Xq1QtNX1Hb3ZwYuFUgubm5IjIyUgAQgYGBYufOnUIIIfLy8sTq1auFu7u7ACC6d+9u4ZqWLQBE8+bNxdy5c8X169fVx2NiYsRLL72k/oM0fPhwrbx8TswnLy9PtGrVSgAQLVu2LDRwY7ub5uDBg+oPSs8//7w4ceKE+sNlenq6OH78uPjggw/EjRs3NPKx3Ytv0aJF6td0//79xdWrV9XnLl++LPr06aM+//vvv2vkZbvrt3fvXuHt7S06duwoJk+eLFatWiUCAgIM+iCblJSkTlunTh1x4sQJIYQQ2dnZ4qeffhL29vYCgBg/frzO/Ddu3FB/yde6dWtx5coVIYQQqampYtq0aern88svvzTrY7YGxW33mJgYAUB07NhRLF26VMTFxQkh5NfyhQsXNN4HH374oc4yTH3eyjJTXu9PSk9PF2FhYcLe3l40bdq0yMCtIre7OTFwq0AWLFig/oN2+PBhrfO//vqr+vyuXbssUMOyac+ePYWeL/gt+a1btzTO8Tkxn++++04AEMOGDRPTp08vNHBjuxdfenq6qFGjhgAgXn/9daPyst2LLyoqSgAQNWvWFLm5uVrnc3Jy1M/L4MGDNc6x3fXT1StTvXp1gz7Ifvjhh+qezye/pBBCiM8++0wAELa2tuqgrKDhw4cLACIgIEA8fvxY6/zYsWPVvXDlrTe0uO2elJQkTp48qfe8UqkUXbt2VffmZGZmaqUx9Xkry0x5vT9p4sSJAoD44IMPxMiRI4sM3Cpyu5sTA7cKpG3btgKA6NChg87zSqVShIaGCgBixIgRpVy78uv48eN6vwnnc2Ieqm+uK1WqJBISEooM3NjuxTd//nz1h01dH4oKw3Yvvtq1awsAol+/fnrTPP/88wKA6Nmzp8ZxtrtxDP0gW61aNfVwRl1SU1OFm5ubACCmTZumcS4tLU3da/3xxx/rzK/qXQIgFi1aVKzHUpYUN4B40po1a9TtdurUKa3zpjxv5VFx2v3IkSPCxsZG1KpVS2RmZhoUuLHdzYOTk1QQGRkZOHToEACgW7duOtNIkoSuXbsCAHbs2FFqdSvvnJyc1Pt5eXnqfT4n5jNmzBikp6fjm2++QeXKlQtNy3Y3zbJlywAAAwYM0HhtF4XtbpoaNWoAAP755x8oFAqt87m5uThz5gwAoGnTpurjbPeSceXKFdy6dQuA/nZ1c3ND27ZtAWi368GDB5GZmVlo/pCQENStW1dnftJP3/9cwPTnjYDs7GyMHj0aQgj8/PPPBv0fYLubDwO3CuLSpUtQKpUAgPr16+tNpzp37949JCYmlkrdyrt9+/ap9yMjI9X7fE7M45dffsHu3bvRqVMnjBgxosj0bPfiy87ORnR0NACgSZMmuHXrFsaOHYuqVavCwcEB/v7+6NWrF7Zs2aKVl+1umvHjxwMA/v33XwwZMgT//vuv+tyVK1cwcOBA3LhxA2FhYZg0aZL6HNu9ZJw/f169b0i7Xrx40aT8Fy5cKFY9KyLV/1wHBwfUqlVL45ypzxsBM2fOxKVLl/DSSy+hffv2BuVhu5sPA7cKIj4+Xr0fHBysN13BcwXzUPEkJSXh888/BwC0bdsWtWvXVp/jc2K6uLg4TJ48Gc7Ozvjvf/9rUB62e/HFxsaqp42/ceMG6tevj19++QUJCQlwdXVFQkICNm/ejJ49e2LMmDEaUzuz3U3Tq1cvfPvtt3BwcMC6desQHh4OFxcXuLi4oE6dOti3bx/Gjx+P48ePw8PDQ52P7V4yjG3XlJQUpKWlaeX39vaGs7Nzkfn5nBgmJiYG8+fPBwAMGjRI470AmP68VXSnT5/GV199BX9/f3z99dcG52O7mw8DtwoiNTVVve/i4qI3XcFzBfOQ8ZRKJV544QXcvXsXTk5O+OmnnzTO8zkx3bhx45CcnIwZM2aoh5IVhe1efI8fP1bvf/rpp7C3t8fatWuRlpaGx48f4+bNmxgwYAAAYMGCBfj222/V6dnupps4cSJ+//13+Pn5AQAyMzPVw+1ycnKQlpaG5ORkjTxs95Jharuq9gvLW/A8n5OiZWZmYsCAAcjIyICvry+++OILrTR8PxSfQqHA6NGjoVAo8MMPP8DLy8vgvGx382HgRlRC3nzzTWzevBkAMGfOHDRo0MDCNSpfVqxYgS1btuCpp57CW2+9ZenqVAiqIXeq/YULF6J///6wt7cHAFSrVg2rV69Gw4YNAQCfffaZzvuxyHgZGRkYNGgQevbsiWrVqmHHjh148OABHjx4gB07diAiIgLLly9H8+bNcfbsWUtXl6hUKRQKDB06FCdPnoS9vT1WrlyJoKAgS1erXPniiy9w5swZ9OzZEwMHDrR0dSosBm4VhLu7u3o/IyNDb7qC5wrmIeO888476h62b7/9FqNHj9ZKw+ek+O7fv4+JEyfC1tYWv/zyC+zs7AzOy3YvvoLtEB4ejueee04rjY2NDd555x0AwKNHj3Dy5EmtvGx3402ePBlr1qxB7dq1ceDAATz77LPw9fWFr68vnn32Wezfvx+1atXCw4cPMWHCBHU+tnvJMLVdVfuF5S14ns+Jfnl5eRg2bBj++OMP2NnZ4ddff0Xnzp11puX7oXguXryITz75BG5ubpg7d67R+dnu5sPArYIo+M1TXFyc3nQFz/HbquKZMmUKZs+eDQCYNWsWJk6cqDMdn5Pie++99/Do0SOMHTsWderUQVpamsamug8LgNYxtnvxFbw3oU6dOnrTRUREqPdv3rwJgO1uitTUVPz8888AgAkTJuicxc3Z2RmvvfYaAHnGwoSEBABs95JibLt6eHjAzc1NK//jx4/Vw10Ly8/nRLe8vDwMHz4ca9asga2tLVasWIH+/fvrTW/q81ZRTZgwATk5Ofjggw/g7e2t9T9XNbJCCKE+lpubq87PdjcfBm4VRN26dWFjIz/dBWf3eZLqXEBAAHx8fEqlbuXJ5MmT1TfsfvXVV3j77bf1puVzUnwxMTEAgHnz5sHd3V1rU00IA0B9bMqUKQDY7qbw8fEp9MZylYKTkkiSBIDtboqrV6+qPxiFhYXpTRceHq7eV71H2O4lo+DMeIa0a8EvM4qTv169esWqZ3mm6mlbvXq1OmgbNGhQoXlMfd4qKtXfk6lTp+r8n7ty5UoAwK1bt9TH5syZo87PdjcfBm4VhIuLC1q3bg0A2LZtm840Qghs374dAPQOMyD93nnnHcyaNQuAHLRNnjy50PR8TiyD7W4aVXtcunRJb5qCUzmHhoYCYLubQhV4Afk9mLrcv39fva8aZsR2Lxm1atVCtWrVAOhv1/T0dBw4cACAdru2adNGPZukvvw3b95Uv8/4vGjKy8vD0KFD8dtvv6mDtsGDBxeZz9TnjYqH7W5GFlv6m0rdggULBAAhSZI4evSo1vnffvtNABAAxK5duyxQw7Lr7bffVrfdrFmzDM7H56RkTJ8+Xd1uurDdi2///v3qttmwYYPW+by8PNGgQQMBQAQHB4u8vDz1ObZ78WRkZAhnZ2cBQDRu3Fjk5uZqpVEoFKJVq1YCgPD29hYKhUJ9ju1unOrVqwsAYvr06YWm+/DDDwUA4eLiImJiYrTOf/nllwKAsLW1FVeuXNE6P3z4cAFABAYGiqSkJK3z48ePFwCEu7u7SExMLO7DKTMMbXeFQiEGDRokAAg7OzuxevVqo65j6vNW3hja7oUZOXKkACCqV6+uNw3b3TwYuFUgubm5IjIyUv2BSvUPOi8vT6xZs0Z4eHgIAKJbt24WrmnZMnnyZPWHnm+++caovHxOSkZRgRvb3TT9+/cXAESlSpXEunXr1IHEzZs3xcCBA9Vtv2TJEo18bPfie/3119Xt2rVrV3H27FmRl5cn8vLyxD///CM6d+6sPv/xxx9r5GW7Fy4xMVE8ePBAvVWtWlUAEJMnT9Y4npqaqpEvKSlJBAQECAAiIiJCREdHCyGEyM7OFnPnzhUODg4CgBg/frzO6964cUO4uroKAKJt27bi6tWrQggh0tLSxMcffywkSRIAxJdfflmyDWAhxWl3hUIhBg8erA7a1qxZY/R1TX3eyrrivt4LY0jgVtHb3VwYuFUwMTExIiQkRP0P3sXFRTg5Oal/b9SoUYX4Zs9cbt68qW47Gxsb4e/vX+j29ddfa5XB58T8igrchGC7myItLU20a9dO3VaOjo7C29tb/Xth396y3YsnIyNDdO3aVaONHR0dhaOjo8axIUOGaPS2qbDd9VP1OBS1jRw5UitvdHS0qFSpkjqNu7u7sLe3V//euXNnkZWVpffaW7ZsES4uLur0np6ewtbWVv37qFGjhFKpLMFHbznFafe///5bfdze3r7I/7n6euNMfd7KMlNe7/oYErgJUbHb3Vx4j1sFExISgrNnz2LatGmoX78+JEmCvb09mjRpglmzZuHo0aPw9va2dDXLjCfXtbp//36hW1pamlYZfE4sg+1efK6urti7dy9++eUXtGvXDq6urkhLS0NwcDAGDx6MQ4cOYcaMGTrzst2Lx9nZGX/99RfWrl2LPn36oEqVKupJYKpWrYp+/fph8+bN+PXXX2Fra6uVn+1eMpo0aYILFy5g0qRJCA8PR25uLlxdXdGmTRv88ssv2Lp1KxwdHfXm7969O86ePYsxY8YgJCQEWVlZ8Pb2xrPPPot169Zh0aJF6gl+SPN/bm5ubpH/c/XN2Gnq80bFw3Y3nSREgem/iIiIiIiIyOqwx42IiIiIiMjKMXAjIiIiIiKycgzciIiIiIiIrBwDNyIiIiIiIivHwI2IiIiIiMjKMXAjIiIiIiKycgzciIiIiIiIrBwDNyIiIiIiIivHwI2IiIiIiMjKMXAjIiIiIiKycgzciIiIyrmoqChIkoSoqChLV4WIiIqJgRsREREREZGVY+BGRERERERk5Ri4ERERERERWTkGbkRERERERFaOgRsREREREZGVY+BGREQVwt69ezFy5EjUqFEDLi4u8PDwQGRkJCZPnoz4+HideWbMmAFJkiBJEgAgKSkJ06dPR7169eDm5gYfHx906NABq1atMqgOsbGxmDRpEurVqwd3d3e4uLggPDwc48aNw7lz5wwqIzU1FbNnz8YzzzyDgIAAODg4wMPDA40aNcLrr7+OQ4cOFVlGXFwc3nrrLdSsWRPOzs6oVKkSunTpgq1btxpUByIiKn2SEEJYuhJEREQlJSsrC6NGjcLq1av1pnF1dcWqVavQq1cvjeMzZszAxx9/DAC4ceMGnn32WVy/fl1nGQMHDsTKlSthZ2en8/yyZcswduxYZGdn6zxva2uLTz75BFOnTtVbz127dmHIkCF4+PCh3jQA8OS/9qioKPz9999o3749/vOf/+C5557TW8bXX3+Nd955p9DyiYio9LHHjYiIyi0hBPr3768O2nr16oXly5fj0KFDOHLkCL7//ntUq1YN6enp6N+/P6Kjo/WWNWjQIMTExOCVV17Brl27cOLECSxcuBC1atUCAKxZswaTJ0/WmXfLli148cUXkZ2dDTc3N0yfPh0HDhzAkSNHMHv2bPj6+iIvLw/vv/8+5s2bp7OMvXv3olu3bnj48CFsbW3x4osvYsOGDTh58iQOHTqEX375Bc8//zzs7e31Poa7d+/iueeeg42NDb744gscPHgQx48fxzfffAMvLy8AwNSpU3HhwgVDmpeIiEqTICIiKqd+/vlnAUDY29uLrVu36kyTmJgo6tWrJwCI1q1ba5ybPn26AKDefv31V638KSkpomHDhgKAsLGxEefOndM4n5OTI4KCggQA4ebmJk6fPq1VRmxsrAgMDBQAhIuLi3jw4IHG+czMTHUZLi4uYu/evXof861bt7SOtW/fXv0YqlevLu7cuaOV5sCBA0KSJAFAvPHGG3rLJyIiy2CPGxERlUtCCHz55ZcAgDfeeANdu3bVmc7b2xtff/01AODQoUO4du2aznQ9e/bEkCFDtI67u7vj559/BgAolUrMnz9f4/yGDRvU99B9+OGHeOqpp7TKqF69uroOGRkZWLx4scb5ZcuWqcv47LPPEBUVpbOOAFC1alW95wDgxx9/RHBwsNbxNm3aoEWLFgCAAwcOFFoGERGVPgZuRERULl28eFF9P1r//v0LTduuXTv1/pEjR3SmGTVqlN78zZs3R7169QDI96EVpPpdkiSMHj1abxkDBgyAp6enzjI2b94MQL4Xb8yYMXrLKIqXlxf+1979hES1xmEcf66Tg1o4+a9/uHAQF4JGTSlYUIGiCxGE3Ciai5AJUnRhC3VTSFLgUiTcSS2iBoQRhGjjbFwoKmbg6EIXCWpC0SCiic5dDOfg5Jyxm/dyT9P3A8Lxfef3njNuxmfOed+3urrasv/atWuSIvP5AAD2QnADACSkw/PVysrKzNUhY/2cOXPGfO36+nrM8UpKSuKer7S0VJK0tLSk79+/m+0fP36UJLndbuXk5FjWO51OXb16NarGMDs7KykSrNLS0uJeRzwFBQVKSrL+6M/MzJQUWbkSAGAvBDcAQEL6/PnzL9Vtb2/HbD937lzcuvPnz0uKPKL59etXs/3Lly8/VS9JFy5ciKoxGCtAXrx48dgx4jku9Bmh7uDg4ETnAQD8+2KvWQwAwG9uf3/fPB4dHVVeXt5P1VkFLGMvt1910noAwJ+N4AYASEhZWVnm8dmzZ1VUVHSi8TY2NuIu/LGxsSEpEtAyMjLMduPxQ6M/HuMxTaPGkJ2drdXVVa2trf3j6wYAJAYelQQAJCRjvpgUWS3ypKampn6qv6CgQE6n02w3AuPKyoo2Nzct6/f29sy5bD+GTI/HIykyb8/qUU4AQGIjuAEAEpLH41Fubq4kaWhoSDs7Oycab3h42LJvamrKXFCkoqIiqs/4PRwOH1nm/zCfz6dv377FHKOmpkZSZP6dsfUAAODPQnADACSkpKQkdXd3S4osb3/v3j3t7u5avj4UCmlgYMCy3+/3682bN0fat7a25PV6zXMax4ba2lpdunRJkvT06VPNz88fGePTp0/q7OyUFFlA5MetBxobG82913p6ehQIBCyvc3V11bIPAPD7Yo4bACBhPXjwQO/fv9fIyIjevn2rmZkZeb1elZaWyuVyKRQKKRgManx8XH6/XykpKWptbY051vXr19XQ0KBAIKC6ujqlp6frw4cPev78uRYXFyVJDx8+1OXLl6PqnE6nhoaGVFNTo1AopJs3b+rRo0cqLy+Xw+HQxMSEnj17Zq6C2d/fr+zs7KgxUlJS9PLlS1VWVmp7e1sVFRVqampSbW2tcnNztbu7q2AwqLGxMfn9/rgBFQDwe/orHA6H/++LAADgv7K3t6f29na9ePFCx33kud3uqM2nHz9+rCdPnkiK3LUrLy/XyspKzNq7d+/q9evXOnUq9neiw8PD8nq9lqHK4XCot7dXXV1dltf37t071dfXR203EMuP7/POnTsKBAK6ffu2xsfHLesOv1/+PQAAe+FRSQBAQktOTtbg4KDm5ubU1tam4uJiuVwuORwOuVwuXblyRffv35fP59PCwoLlOG63W9PT0+ru7lZhYaHS0tLkcrl069YtvXr1Sj6fzzK0SVJzc7OCwaDa29tVWFio06dPKzU1Vfn5+WppadHs7Gzc0CZJVVVVWl5eVl9fn27cuKGsrCw5HA6lp6fL4/Goo6NDk5OTv/y3AgDYF3fcAACwwB0oAIBdcMcNAAAAAGyO4AYAAAAANkdwAwAAAACbI7gBAAAAgM0R3AAAAADA5lhVEgAAAABsjjtuAAAAAGBzBDcAAAAAsDmCGwAAAADYHMENAAAAAGyO4AYAAAAANkdwAwAAAACbI7gBAAAAgM0R3AAAAADA5v4G5q5Fyqu6TN4AAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 1000x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA24AAAJyCAYAAAC8MpMzAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjMsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvZiW1igAAAAlwSFlzAAAPYQAAD2EBqD+naQAAZVlJREFUeJzt3Xl0FFXexvGnshOSNAGEBAgQEEQ2BQRFREAYFgVFZEZFBEURHUVwFMdtIL6uIzguI6AoIijKAOLIjoCgiAuyyaooJCwhQRHISvZ6/+hJm5CFJJ2kqtPfzzl9Uqm6devXVELzcKtuGaZpmgIAAAAA2JaP1QUAAAAAAEpHcAMAAAAAmyO4AQAAAIDNEdwAAAAAwOYIbgAAAABgcwQ3AAAAALA5ghsAAAAA2BzBDQAAAABszs/qArxNXl6ejh8/rtDQUBmGYXU5AAAAACximqZSUlLUqFEj+fiUPqZGcKtmx48fV1RUlNVlAAAAALCJo0ePqkmTJqW2IbhVs9DQUEnOkxMWFmZxNQAAAACskpycrKioKFdGKA3BrZrlXx4ZFhZGcAMAAABQpluomJwEAAAAAGyO4AYAAAAANkdwAwAAAACbI7gBAAAAgM0R3AAAAADA5ghuAAAAAGBzBDcAAAAAsDmCGwAAAADYHMENAAAAAGyO4AYAAAAANkdwAwAAAACbI7gBAAAAgM0R3AAAAADA5ghuAAAAAGBzBDcAAAAAsDmCGwAAAADYHMENAAAAAGyO4AYAAAAANkdwAwAAAACbI7gBAAAAgM0R3AAAAADA5ghuAAAAAGBzBDcAAAAAsDmCGwAAAADYHMENAAAAAGyO4AYAAAAANkdwAwAAAACbI7gBAAAAgM0R3AAAAADA5ghuAAAAAGBzBDcAAAAAsDmCGwAAAADYHMENAAAAAGyO4AYAAAAANkdwAwAAAACbI7gBAAAAgM0R3AAAAADA5jw2uKWnp2vVqlV69tlnNWzYMDVr1kyGYcgwDMXExFTKMU6cOKGHH35YF110kWrVqqW6deuqZ8+eeuedd2SaZqUcAwAAAADOx8/qAipqy5Ytuvbaa6us/23btmnAgAH6/fffJUkhISFKSUnRV199pa+++kqLFy/W0qVLFRAQUGU1AAAAAIDkwSNukhQeHq6+fftq0qRJ+uijjxQREVEp/SYlJWnw4MH6/fff1aZNG33//fdKSUlRWlqa3njjDfn7+2vNmjWaOHFipRwPAAAAAErjsSNuPXv21KlTpwqte+yxxyql72nTpikxMVG1atXSypUrFR0dLUkKCAjQ/fffr+TkZD3xxBOaNWuWJk6cqNatW1fKcQEAAACgOB4b3Hx9faus73nz5kmSbrnlFldoK2j8+PF6/vnnlZqaqvnz5+vpp5+uslqAcsnNlTZtkhISpMhIqWdPqbJ+V6qy76run9qt6Z/aremf2q3pn9qt6Z/aq7/vqu7fk2uvamYN0qxZM1OSOWXKlAr38eOPP5qSTEnmwoULS2w3aNAgU5J5xRVXlKv/pKQkU5KZlJRU4RqBYn38sWk2aWKa0h+vJk2c6+3cd1X3T+3W9E/t1vRP7db0T+3W9E/t1d93VffvybVXUHmyAcHtHIsXL3YFt3379pXYbtKkSaYkMywsrFz9E9xQJT7+2DQNo/BfRJJznWG49xdSVfZN7dRut/6pndrt1De1U7ud+qb2KlGebOCxl0pWlePHj7uWGzduXGK7/G3JyclKTU1VSEhIldcGFCs3V5owwfnXz7ny191zj7NdeS8FyM2V7ruvavqu6v6p3Zr+qd2a/qndmv6p3Zr+qb36+67q/q2u3TCkiROlG26w9WWThmkW9w48U/PmzXX48GFNmTKlws9ye/755/Xkk09KkrKzs+XnV3y2ffvtt3XPPfdIcoa9yMjIYttlZmYqMzPT9X1ycrKioqKUlJSksLCwCtUIFLJxo9Snj9VVAAAAeLYNG6Tevav1kMnJyXI4HGXKBoy4VbEXXniByUtQtRISytaudWvpggvK1/dvv0kHDlRN31XdP7Vb0z+1W9M/tVvTP7Vb0z+1V3/fVd2/XWov67+prFLlF25Wo8q4x+311183JZ33WtNXX33V1S4lJaXEdhkZGWZSUpLrdfTo0TJfxwqUyfz5Ra/XLu61YUP5+96woer6rur+qZ3a7dQ3tVM7tVO7J/dN7VWGyUmYnATe4ssvTbNevdL/EjIM04yKMs2cnPL3n5PjnG2puJt53e27qvundmq3U9/UTu3UTu2e3De1V5nyZAMfS4b5bKx9+/au5T179pTYLn9b27Ztq7wmoFhz5kh9+0q//y5FRztvrDWMwm3yv3/11YrdbOvrK732WuG+Kqvvqu6f2q3pn9qt6Z/aremf2q3pn9qrv++q7t+Ta69O1RAkq01ljLjl5eWZTZs2NSWZY8aMKbZNamqqGRISYkoyJ0+eXK7+GXGD23JyTPORR/74X6Lhw00zLa34Z5NERVXdc1Uqq++q7p/aremf2q3pn9qt6Z/aremf2qu/76ru35Nrr6DyZANmlSzGP/7xDz377LMKDg7W3r171bx580LbX3rpJf3973+Xr6+v9u3bp9atW5e57/LMHAMUkZIijRghLV/u/P4f/5BiYiSf/w2e5+ZKmzY5b66NjJR69qy8/z2qyr6run9qt6Z/aremf2q3pn9qt6Z/aq/+vqu6f0+uvQLKkw08OridPn1aubm5ru87d+6so0ePatKkSXr00Udd64OCggo9Zy0mJsY102NsbGyRYJaUlKQ2bdooMTFRbdu21bx589SlSxdlZWVp9uzZmjhxorKysnTfffdpxowZ5aqZ4IYKi4uThgyR9uyRAgOdl0reeqvVVQEAAKCCypMNPPoet06dOumCCy5wvY4ePSpJmjp1aqH1DzzwQLn6dTgcWr58uerVq6d9+/bpsssuU1hYmEJCQvTXv/5VWVlZ6t+/v1555ZWqeFtAUV99JXXr5gxtERHSl18S2gAAALyIRwe3qtSlSxft3btXDz30kFq1aqXs7GzVrl1bV111ld5++22tWrVKgYGBVpcJbzB3rnMSkt9+kzp1kr7/3hniAAAA4DU8+lJJT8Slkiiz3FzpiSekl15yfj9smDRvnlS7trV1AQAAoFJ4zaWSQI2VkuIMavmh7cknpUWLCG0AAABeys/qAgCc4/Bh5yQku3c7JyF5913nTJIAAADwWgQ3wE6+/lq68Ubp11+lhg2lTz+VLr/c6qoAAABgMS6VBOzi/felPn2coe2SS5yTkBDaAAAAIEbcgOpV3EMfDcN5D9uLLzrbDB3qDHEFnj0IAAAA70ZwA6rLkiXShAnSsWN/rGvcWGrUyDm6JjlnkXzmGcmHwXAAAAD8geAGVIclS6Thw6Vzn74RH+98+flJc+ZII0daUx8AAABsjf/WB6pabq5zpK20RybWrSvdemv11QQAAACPQnADqtqmTYUvjyzOr7862wEAAADFILgBVS0hoXLbAQAAwOsQ3ICqFhlZue0AAADgdQhuQFXr2VNq0qTk7YYhRUU52wEAAADFILgBVc3XV5o0qfhthuH8+uqrznYAAABAMQhuQFXLyZE++MC5HBhYeFuTJtLixdKwYdVfFwAAADwGz3EDqtoLLzgfsF2njvTDD9KhQ86JSCIjnZdHMtIGAACA8yC4AVVp2zbp//7PuTx9utS0qfMFAAAAlAOXSgJVJSNDGjXKeank8OE8YBsAAAAVRnADqso//iHt2yc1bCjNnPnHRCQAAABAORHcgKrw5ZfSyy87l99+W6pf39p6AAAA4NEIbkBlS0mR7rhDMk1pzBhpyBCrKwIAAICHI7gBle2RR6TYWKlZM+mVV6yuBgAAADUAwQ2oTKtWSbNmOZfnzJHCwqytBwAAADUCwQ2oLKdOSXfd5VyeOFHq08fScgAAAFBzENyAynL//c4Ha7dpIz3/vNXVAAAAoAYhuAGVYeFCacECyddXmjdPqlXL6ooAAABQgxDcAHclJEj33edcfvJJqWtXa+sBAABAjUNwA9xhmtLddzvvb+vcWXrqKasrAgAAQA1EcAPcMXu2tHKlFBjovETS39/qigAAAFADEdyAioqNlR56yLn87LNSu3bW1gMAAIAai+AGVERennTHHVJqqtSz5x8BDgAAAKgCBDegIl59VfryS6l2bem995yzSQIAAABVhOAGlNe+fdITTziX//UvqUULa+sBAABAjUdwA8ojO1saNUrKzJQGDZLGjrW6IgAAAHgBghtQHs89J23bJoWHS++8IxmG1RUBAADACxDcgLLautU5e6QkzZghNWpkbT0AAADwGgQ3oCzOnnVeIpmbK918s3TLLVZXBAAAAC9CcAPK4qmnpP37pYgIafp0q6sBAACAlyG4AefzxRfSK684l2fPlurVs7YeAAAAeB2CG1CalBTng7ZNU7r7bunaa62uCAAAAF7Iz+oCANvJzZU2bZISEqQPPpDi4qTmzZ3PbAMAAAAsQHADClqyRJowQTp2rPD6u+6SQkOtqQkAAABej0slgXxLlkjDhxcNbZI0ebJzOwAAAGABghsgOS+PnDDBeS9bSSZOdLYDAAAAqhnBDZCc97QVN9KWzzSlo0ed7QAAAIBqRnADJOdEJJXZDgAAAKhEBDdAkiIjK7cdAAAAUIkIboAk9ewpNWkiGUbx2w1DiopytgMAAACqGcENkCRfX+m114qfnCQ/zL36qrMdAAAAUM0IbkC+YcOkSy8tur5JE2nxYud2AAAAwAI8gBvIl5oq7dvnXH7vPSkgwHlPW8+ejLQBAADAUgQ3IN/atVJWltSypTRqVMn3uwEAAADVjEslgXzLljm/Dh5MaAMAAICtENwAScrLk1ascC4PGWJtLQAAAMA5CG6AJH3/vfTrr1JYGFP+AwAAwHYIboD0x2WSAwY4JyUBAAAAbITgBkjS8uXOr1wmCQAAABsiuAFHjkg//CD5+EiDBlldDQAAAFAEwQ3IH23r3l2qX9/aWgAAAIBiENwALpMEAACAzRHc4N3S0qTPP3cuE9wAAABgUwQ3eLe1a6XMTCk6Wrr4YqurAQAAAIpFcIN3y38MwJAhkmFYWwsAAABQAoIbvFdenrRihXOZyyQBAABgYwQ3eK+tW6UTJ6TQUOnqq62uBgAAACgRwQ3eK/8yyQEDpIAAa2sBAAAASkFwg/fiMQAAAADwEAQ3eKejR6WdO50Tklx7rdXVAAAAAKUiuME75Y+2de8u1a9vbS0AAADAeRDc4J24TBIAAAAehOAG75OWJq1f71wmuAEAAMADENzgfdatkzIzpebNpbZtra4GAAAAOC+CG7xPwcskDcPaWgAAAIAyILjBu+TlcX8bAAAAPA7BDd5l2zYpMVEKCZGuvtrqagAAAIAyIbjBu+SPtg0YIAUGWlsLAAAAUEYEN3iXZcucX7lMEgAAAB6E4AbvceyYtGOHc0KSQYOsrgYAAAAoM4IbvMeKFc6vV1whNWhgbS0AAABAORDc4D24TBIAAAAeiuAG75CeLq1f71wePNjaWgAAAIBy8vjglpKSopiYGHXo0EEhISFyOBzq2rWrXn75ZWVlZbnV9+LFizVkyBA1atRIAQEBql27ti666CKNHTtWO3furJw3gOqxfr2UkSE1aya1b291NQAAAEC5GKZpmlYXUVGHDx9W7969FRcXJ0kKDg5Wbm6uMjMzJUmdOnXS+vXrFR4eXq5+MzMz9ec//1nL8i+tkxQSEqKsrCxXGPTx8dG0adP00EMPlavv5ORkORwOJSUlKSwsrFz7wg333CO9/bb0wAPSv/9tdTUAAABAubKBx4645eTkaMiQIYqLi1NkZKTWrl2rtLQ0paena8GCBQoNDdWOHTs0cuTIcvf9/PPPu0LbX//6Vx07dkwpKSk6e/astm7dqquuukp5eXl6+OGHtW3btsp+a6hseXl/PL+N+9sAAADggTw2uM2dO1e7d++WJH388cfq16+fJOdI2M0336y33npLkrRy5Uqtz7+3qYzmzZsnSerVq5emT5+uxo0bu/ru0qWLli9frpCQEJmmqcWLF1fWW0JV2bFDSkiQQkKkXr2srgYAAAAoN48ObpLUp08fde/evcj2W265RdHR0ZL+CGJllZCQIEm67LLLit3ucDjUunVrSVJqamq5+oYF8i957d9fCgy0thYAAACgAjwyuKWnp2vz5s2SpEElPEjZMAwNHDhQkvTZZ5+Vq/8WLVpIUomXQSYlJenAgQOSSg53sBEeAwAAAAAP55HBbf/+/crLy5MktS9lhsD8bYmJiTp16lSZ+7/vvvskSRs3btT999+v+Ph4SZJpmtq+fbsGDx6s1NRUde/evUL30KEaxcdL27dLhiFde63V1QAAAAAV4pHB7fjx467l/PvPilNwW8F9zuf+++/Xo48+Kh8fH82YMUNNmjRRaGiogoKC1KVLF/3yyy967LHHtH79evn6+pbaV2ZmppKTkwu9UI1WrHB+vfxyqUEDa2sBAAAAKsgjg1tKSoprOTg4uMR2BbcV3Od8fHx89MILL+jdd99VSEiIJOe9bPmPAsjIyFBSUpLS0tLO29cLL7wgh8PhekVFRZW5DlQCLpMEAABADeCRwa2qnTx5Un379tUdd9yh7t2766uvvtKZM2eUkJCgJUuW6IILLtDMmTN1+eWXuy6jLMnjjz+upKQk1+vo0aPV9C6g9HRp3Trn8uDB1tYCAAAAuMHP6gIqIjQ01LWcnp5eYruC2wrucz6jR4/Wxo0b1atXL61Zs0aGYUhyziZ54403qkePHmrXrp0OHTqkxx57TO+//36JfQUGBiqQmQyt8fnnUkaG1LSp1KGD1dUAAAAAFeaRI26NGjVyLZc24lVwW8F9SrN//36tXLlSkvTwww+7QltBDRo00KhRoyRJS5YskWmaZeob1azgZZLFnEcAAADAU3hkcLv44ovl4+Msfc+ePSW2y98WERGhunXrlqnvffv2uZZbtmxZYrtWrVpJco7q/frrr2XqG9XINKXly53LXCYJAAAAD+eRwS04OFg9evSQJK1evbrYNqZpas2aNZKk/v37l7nv/EAoSYcPHy6x3YkTJ1zL+ROYwEZ27JCOH5dq15Z697a6GgAAAMAtHhncJOd9aJK0YcMGfffdd0W2L1q0SIcOHZIk12WNZdG5c2fX8syZM4ttk5aWpnnz5kmSOnbsqNq1a5e5f1ST/Msk+/eXgoKsrQUAAABwk0cHtw4dOsg0Td10001av369JCkvL0+LFi3S2LFjJUmDBg1S3759C+0bExMjwzBkGIbi4uIKbWvWrJmG/G/q+GXLlun222/XwYMHZZqmsrOz9fXXX6t3796uUPjwww9X8TtFheQHNy6TBAAAQA3gkbNKSpKfn5+WLl2qPn36KC4uTv369VNwcLDy8vKUkZEhSerUqZPmz59f7r7fffddDRw4UNu2bdMHH3ygDz74QMHBwcrKylJOTo6r3aRJk8o1modqcvy4tG2bc0KS666zuhoAAADAbR474iZJzZs3165duzR58mS1b99ehmHI399fXbp00bRp0/Ttt98qPDy83P3Wr19f3377rd555x0NGDBADRs2VHZ2tvz8/NSiRQuNHDlSmzZt0ksvvVQF7wpuW7HC+bVbN6lhQ2trAQAAACqBYTKXfbVKTk6Ww+FQUlKSwsLCrC6nZrr+euelks88Iz31lNXVAAAAAMUqTzbw6BE3oIizZ6V165zL/7tXEQAAAPB0BDfULJ9/7gxvUVFSx45WVwMAAABUCoIbapb82SSHDHFOTgIAAADUAAQ31BymKS1f7lzmMQAAAACoQQhuqDl27pTi46XataU+fayuBgAAAKg0BDfUHPmXSf7pT1JQkLW1AAAAAJWI4Iaag8skAQAAUEMR3FAzJCRI33/vXL7uOmtrAQAAACoZwQ01w4oVzq/dukkREdbWAgAAAFQyghtqBi6TBAAAQA1GcIPny8iQ1q51Lg8ZYm0tAAAAQBUguMHzff65lJ4uNWkiXXKJ1dUAAAAAlY7gBs9X8DJJw7C2FgAAAKAKENzg2Uzzj+DGZZIAAACooQhu8Gw//CAdPSoFB0vXXGN1NQAAAECVILjBsy1b5vzar58UFGRtLQAAAEAVIbjBs3GZJAAAALwAwQ2eKzFR2rLFuXzdddbWAgAAAFQhP6sLAMotN1fatEn68EPn95ddJkVGWlsTAAAAUIUYcYNnWbJEat5c6tNHevtt57oDB5zrAQAAgBqK4AbPsWSJNHy4dOxY4fUpKc71hDcAAADUUAQ3eIbcXGnCBOdz286Vv27iRGc7AAAAoIYhuMEzbNpUdKStINN0Ps9t06bqqwkAAACoJgQ3eIaEhMptBwAAAHgQghs8Q1lnjWR2SQAAANRABDd4hp49pSZNJMMofrthSFFRznYAAABADUNwg2fw9ZVee634yUnyw9yrrzrbAQAAADUMwQ2eY9gwqX37ouubNJEWL3ZuBwAAAGogP6sLAMps1y5pzx7Jx0f68EMpL895T1vPnoy0AQAAoEYjuMFzvP668+tNN0k332xtLQAAAEA14lJJeIbffpM++MC5PHGipaUAAAAA1Y3gBs8wa5aUmSl17Sp17251NQAAAEC1IrjB/rKypOnTncsTJpT8SAAAAACghiK4wf4WL5YSEpwTkfz5z1ZXAwAAAFQ7ghvszTSlV15xLv/1r1JAgLX1AAAAABYguMHevvlG2rpVCgyUxo2zuhoAAADAEgQ32Ntrrzm/3nabdMEF1tYCAAAAWITgBvs6elT6+GPn8oQJ1tYCAAAAWMjtB3AfOXJEktSwYUMFBgaW2jYjI0O//vqrJKlp06buHho13fTpUm6u1KeP1LGj1dUAAAAAlnFrxO2zzz5TdHS0OnTooPT09PO2T09PV7t27dSiRQtt3LjRnUOjpktLcz67TeKB2wAAAPB6bgW3RYsWyTRNDR06VOHh4edtX7duXd10003Ky8vTf/7zH3cOjZrugw+k06elFi2k666zuhoAAADAUm4Ft2+++UaGYah///5l3mfAgAGufYFimeYfk5I8+KDk62ttPQAAAIDF3ApucXFxkqTWrVuXeZ8LL7xQkhQbG+vOoVGTrV0r7d8vhYZKd95pdTUAAACA5dwKbjk5OZIk33KMiOS3zcjIcOfQqMlefdX5dcwYKSzM0lIAAAAAO3AruNWvX1+SdOjQoTLvk9+2bt267hwaNdVPP0mrVkmGIY0fb3U1AAAAgC24FdwuvfRSSSrXRCMLFiyQJLVv396dQ6Omev1159chQ6SWLa2tBQAAALAJt4LbDTfcINM0tWTJEi1atOi87RcuXKglS5bIMAwNHTrUnUOjJjp9WnrvPecyjwAAAAAAXNwKbqNHj1bz5s1lmqZGjBihRx55REePHi3S7ujRo/rb3/6m2267TYZhKCoqSnfffbc7h0ZNNHu2lJ7ufNh2795WVwMAAADYhmGapulOBzt37tTVV1+t1NRUGYYhSWratKkiIyMlSQkJCTpy5IgkyTRNhYSE6IsvvlCnTp3cLN0zJScny+FwKCkpSWFMvPGHnBznpZFHjjgD3JgxVlcEAAAAVKnyZAO3Rtwk531u3333nTp16iTTNGWapg4fPqzvvvtO3333nQ4fPuxa36VLF23ZssVrQxtK8emnztBWv740YoTV1QAAAAC24lcZnVx88cXatm2b1q5dq+XLl2vHjh06efKkJOfMk507d9aQIUPUt2/fyjgcaqL8RwDce68UFGRpKQAAAIDduH2pJMqHSyWLsW2bdNllkp+fdPiw1KiR1RUBAAAAVa5aL5UE3Pbaa86vN99MaAMAAACKQXCDtRITpf89208TJlhbCwAAAGBTbgW33bt3q0WLFmrVqpXi4+PP2z4+Pl4XXnihWrZsqQMHDrhzaNQUM2dK2dnSlVdKXbtaXQ0AAABgS24Ftw8++EBxcXG68MIL1bhx4/O2b9y4sVq3bq24uDh98MEH7hwaNUFGhvTmm85lRtsAAACAErkV3L744gsZhqHrr7++zPvccMMNMk1T69evd+fQqAkWLJB+/VWKipKGDbO6GgAAAMC23Apu+Zc7duzYscz7tG/fXpL0008/uXNoeDrT/OMRAPff75xREgAAAECx3ApuqampkqSQkJAy75PfNjk52Z1Dw9N9+aX0ww9SrVrS2LFWVwMAAADYmlvBLTw8XJKUmJhY5n3y24aGhrpzaHi6/NG2UaOkunUtLQUAAACwO7eCW6tWrSRJq1evLvM+q1atkiS1bNnSnUPDkx06JH36qXP5wQetrQUAAADwAG4FtwEDBsg0Tc2aNUv79+8/b/u9e/fq7bfflmEYGjhwoDuHhid74w3nPW4DBkht21pdDQAAAGB7bgW3++67T7Vr11ZGRoauueYaLV++vMS2S5cuVb9+/XT27FnVqlVL999/vzuHhqdKSZFmz3Yu8wgAAAAAoEzcmsqvfv36evPNN3X77bfr119/1Q033KAWLVroqquuUmRkpCQpISFBmzZtUmxsrEzTlGEYmjlzpho2bFgpbwAe5r33pORk6aKLnCNuAAAAAM7L7TnYb7vtNuXl5em+++5Tenq6Dh48qEOHDhVqY5qmJKl27dqaOXOmRo4c6e5h4Yny8qTXX3cuP/ig5OPWgC8AAADgNSrlX8633367fvnlFz322GPq0KGDJGdYyx9h69ixo5588kn98ssvhDZvtnKl9MsvUp06ztkkAQAAAJSJYeYPh1WinJwcnTp1SpJUt25d+fFwZZfk5GQ5HA4lJSUpLCzM6nKq15/+JK1bJz3yiDR1qtXVAAAAAJYqTzaokkTl5+enBg0aVEXX8FR79jhDm4+P9MADVlcDAAAAeBRuMkL1eO0159cbb5SaNbO2FgAAAMDDENxQ9U6elD74wLk8caKlpQAAAACeqNIuldywYYP++9//6ocfftDJkyd19uxZlXb7nGEYOnjwYGUdHnY2a5aUkSF17iz16GF1NQAAAIDHcTu4/frrr7rlllv0xRdfSFKJYc0wjELbDMNw99DwBNnZ0vTpzuWJEyXOOwAAAFBubgW37OxsDRo0SDt37pRpmrr00kvVuHFjrVixQoZhaOTIkTp16pS2b9+uhIQEGYahzp07q3379pVVP+wqN1fatEn6+GPp+HGpQQPpL3+xuioAAADAI7l1j9t7772nHTt2SJLmzJmj7du368UXX3Rtnzt3rpYtW6b4+HgtWbJEkZGR2rdvnwYPHqw5c+a4Vznsa8kSqXlzqU8f6Y03nOsyMqQVKywtCwAAAPBUbgW3jz/+WJI0cOBAjR49utS2Q4cO1RdffKGAgADdcccd+vnnn905NOxqyRJp+HDp2LHC61NSnOuXLLGmLgAAAMCDuRXcfvjhB9clkcU59363li1basKECUpLS9Nr+dPDo+bIzZUmTJCKu88xf93Eic52AAAAAMrMreB26tQpSVJ0dLRrXUBAgGs5PT29yD59+/aVJK1du9adQ8OONm0qOtJWkGlKR4862wEAAAAoM7eCW35IKxjWwsLCXMvx8fFF9gkKCipxGzxcQkLltgMAAAAgyc3g1rRpU0nSiRMnXOsaNmyo0NBQSdJ3331XZJ89e/ZIqrzHAaSkpCgmJkYdOnRQSEiIHA6HunbtqpdffllZWVlu95+YmKh//OMf6tKli+rWratatWqpWbNmGjhwoF588UVlZ2dXwruoAZKSpIULy9Y2MrJqawEAAABqGLeCW+fOnSXJNbNkvquvvlqmaeq1115TZmama/2ZM2f0z3/+U4ZhqG3btu4cWpJ0+PBhdezYUU8//bT27Nkj0zSVmZmprVu36pFHHtEVV1yh06dPV7j///znP7rooov07LPPavv27Tp79qwCAgJ05MgRrVmzRo8//rjS0tLcfh8ezTSdU/63bSv997+ltzUMKSpK6tmzWkoDAAAAagq3glvfvn1lmqZWnDPN+7333ivJGeg6duyoSZMm6a9//as6dOigAwcOSJJGjRrlzqGVk5OjIUOGKC4uTpGRkVq7dq3S0tKUnp6uBQsWKDQ0VDt27Chx4pTzWbRokUaMGKHk5GTdc8892rt3r86ePaukpCQlJyfryy+/1EMPPSR/f3+33odHO3xYuv5652yRx49LrVpJMTHOgHbuiGr+96++Kvn6VnelAAAAgEczzHOnfiyHM2fO6NJLL5Vpmvr888/VsmVL17a7775b7777rvMg//tHe/6hBgwYoBUrVsjHp+K5cfbs2br77rslSV9//bW6d+9eaPtHH32kESNGSJLWrVvnmhSlLBISEtSuXTudPn1aL7/8sv72t79VuM5zJScny+FwKCkpqdD9gB4lJ0d67TVp8mQpPV3y95cee0x64gkpKMg55f+ECYUnKomKcoa2YcMsKxsAAACwk/JkA7eC2/nMnj1b77zzjvbu3aucnBy1atVKo0aN0oQJE+Tn5+dW31dffbU2bdqkPn366PPPPy+y3TRNtWzZUrGxsRo1apTmzp1b5r4ff/xxvfjii+rUqZO2bdtWaffjSTUguH3/vXTPPdLOnc7ve/aU3npLuvjiwu1yc52zRyYkOO9p69mTkTYAAACggPJkA/fS03ncdddduuuuuyq93/T0dG3evFmSNGjQoGLbGIahgQMHaubMmfrss8/K1f+8efMkSSNHjqzU0ObRkpOlp56S3njDeV9beLg0dap0551ScSOnvr5S797VXiYAAABQE7l1j5tV9u/fr7y8PElS+/btS2yXvy0xMdH1zLnziY2N1fHjxyVJXbp00e7duzVixAhFRkYqMDBQTZo00c033+wKjjWeaUqffOKcfOTf/3Z+P3Kk9OOP0l13FR/aAAAAAFQqj/xXd36wkqTGjRuX2K7gtoL7lCZ/8hRJ2rx5sy677DJ99NFHSkpKUlBQkOLj47Vw4UL17NlTzzzzTAWq9yBHjkhDhzrvS4uPl1q2lNauld5/X2rQwOrqAAAAAK/hkcEtJSXFtRwcHFxiu4LbCu5TmoKPD/jHP/6hRo0aae3atUpNTVVSUpL27t2r3r17yzRNTZ48WUuWLCm1v8zMTCUnJxd62V5OjvTKK85RtqVLnZOPPPmktHu31K+f1dUBAAAAXscjg1tVyr8EU3JOcPLxxx+rX79+rhkw27Ztq2XLlikiIkKS9PTTT5fa3wsvvCCHw+F6RUVFVV3x5ZGbK23cKH30kfNrbq5z/bZt0uWXS3/7m5SWJvXoIe3YIT37rFSrlpUVAwAAAF7LI4NbaGioazk9Pb3EdgW3FdynrH337dvX9ZDxgkJCQnT//fdLknbt2qUTJ06U2N/jjz+upKQk1+vo0aNlqqNKLVkiNW8u9ekjjRjh/Nq0qTR4sNStm7R9u1SnjvT229KXX0rt2lldMQAAAODVqnRWyarSqFEj13J8fLw6duxYbLv4+Phi9ylNwfviLj53ivsC2rZt61o+fPiwGjZsWGy7wMBABQYGlunY1WLJEucDs899CsTx486X5Axz//qXVMJ7AgAAAFC9PHLE7eKLL3Zdurhnz54S2+Vvi4iIUN26dcvUd9u2beVbhueNFXz8ncc8MiA31/lg7NIe3XfBBdK8eYQ2AAAAwEY8MrgFBwerR48ekqTVq1cX28Y0Ta1Zs0aS1L9//zL3HRQUpKuvvlqS87EDJdm3b58kZ2hr3rx5mfu31KZN0rFjpbf57TdnOwAAAAC24ZHBTZJGjx4tSdqwYYO+++67ItsXLVqkQ4cOSZJGjRpVrr7vvPNOSdL69eu1ffv2IttTU1M1Y8YMSdLll1+uCy64oFz9WyYhoXLbAQAAAKgWbgW3efPmad68ecUGp6o2evRodejQQaZp6qabbtL69eslOWeFXLRokcaOHStJGjRokPr27Vto35iYGBmGIcMwFBcXV6Tv2267Td26dSvUd/5sk/v379f111+vxMRE+fj46LnnnqvaN1qZIiMrtx0AAACAauHW5CR33HGHDMPQRx99pMsvv7yyaioTPz8/LV26VH369FFcXJz69eun4OBg5eXlKSMjQ5LUqVMnzZ8/v9x9+/j46NNPP1Xfvn21b98+V9/+/v5KSkqSJPn7+2v69Om65pprKvV9VamePaUmTZwP0y7uPjfDcG7v2bP6awMAAABQIrdG3BwOhySpVatWlVJMeTVv3ly7du3S5MmT1b59exmGIX9/f3Xp0kXTpk3Tt99+q/Dw8Ar1HRERoe3bt2vatGnq2rWr/P39dfbsWTVv3lxjxozR9u3bXaN6HsPXV3rtNefyuROq5H//6qvOdgAAAABswzDN0qYYLF3nzp31ww8/aO3atZ418mSh5ORkORwOJSUlKSwszJoilixxzi5ZcKKSqChnaBs2zJqaAAAAAC9Tnmzg1ojbjTfeKNM0tWzZMne6QXUbNkyKi5M2bJA+/ND5NTaW0AYAAADYlFsjbsnJybrkkkuUkJCgFStWFJkEBEXZYsQNAAAAgOWqbcQtLCxMa9euVZs2bTRw4EDdc8892rhxo06dOiU38iAAAAAAoAC3Rtx8C0xiYZqmjHMnvCjtwIahnJycih7aYzHiBgAAAEAqXzZw63EA52Y+RtkAAAAAoPK5FdymTJlSWXUAAAAAAErg1qWSKD8ulQQAAAAgVePkJAAAAACAqkdwAwAAAACbc+set3MdPHhQ33zzjRITE5Wenq6//vWvql+/fmUeAgAAAAC8TqUEt+3bt2vixInavHlzofXDhw8vFNymT5+up59+Wg6HQ/v27ZO/v39lHB4AAAAAajS3L5Vcvny5evTooc2bN8s0TderOKNGjdLZs2d16NAhLV++3N1DAwAAAIBXcCu4JSQk6NZbb1VmZqbatm2rVatWKSUlpcT2oaGhuv766yVJq1atcufQAAAAAOA13Apur7zyitLS0tSsWTNt2rRJAwYMUO3atUvdp3fv3jJNU9u2bXPn0AAAAADgNdwKbqtXr5ZhGHr44YdVp06dMu3Tpk0bSVJsbKw7hwYAAAAAr+FWcDt8+LAkqVu3bmXeJ//Bcqmpqe4cGgAAAAC8hlvBLScnR5KUl5dX5n2SkpIkSSEhIe4cGgAAAAC8hlvBLSIiQpJ06NChMu+zZcsWSVLTpk3dOTQAAAAAeA23glvPnj1lmqYWLVpUpvZZWVl66623ZBiGevfu7c6hAQAAAMBruBXc7rjjDknS0qVLtXbt2lLbZmVladSoUTp48KAMw9DYsWPdOTQAAAAAeA23glvv3r118803yzRNDRkyRH//+99dl0JKUlxcnL7++mtNnTpV7dq106JFi2QYhu699161a9fO7eIBAAAAwBsYpmma7nSQmZmpm266SStXrpRhGCW2yz/MsGHD9J///Ee+vr7uHNZjJScny+FwKCkpyTXDJgAAAADvU55s4NaImyQFBgZq+fLleuutt9SiRQuZplnsq0mTJpoxY4YWL17staENAAAAACrC7RG3c+3bt09bt27Vr7/+qtzcXNWrV0+dOnVS586dSx2R8xaMuAEAAACQypcN/Cr74G3btlXbtm0ru1sAAAAA8FpuBbd58+ZJkoYOHVrm0aPU1FQtWbJEkjRq1Ch3Dg8AAAAAXsGtSyV9fHxkGIZ2795d5lG2gwcPqlWrVvLx8VFOTk5FD+2xuFQSAAAAgFTNk5NUVCXfWgcAAAAANVa1B7fc3FxJkp9fpd9eBwAAAAA1UrUHt59++kmSVLdu3eo+NAAAAAB4pHINe3355ZfFrv/+++918uTJUvfNzMzUwYMHNW3aNBmGoUsvvbQ8hwYAAAAAr1Wu4Na7d+8iz2IzTVNjxowpcx+macowDI0bN648hwYAAAAAr1XuSyVN03S9ilt3vleTJk00ffp0DR06tDLfBwAAAADUWOUacduwYYNr2TRNXXPNNTIMQ7Nnz1Z0dHSJ+xmGoaCgIEVGRioqKqri1QIAAACAFypXcOvVq1ex67t161bm57gBAAAAAMrHrTn5Y2NjJUmNGzeulGIAAAAAAEW5FdyaNWtWWXUAAAAAAEpQ5U/BXrZsmRYuXKiTJ08qOjpad999tzp37lzVhwUAAACAGsOtB3Bv2LBBDRo0UNOmTXXmzJki2//xj39o6NCh+vDDD/XZZ5/prbfe0hVXXKH333/fncMCAAAAgFdxK7itXLlSJ0+eVNeuXVWnTp1C23bt2qXnn3/e9RiAOnXqyDRN5eTkaNy4cYqLi3Pn0AAAAADgNdwKbl999ZUMw1C/fv2KbJs5c6ZM01R4eLi2bdum33//XVu2bFHdunWVmZmpN998051DAwAAAIDXcCu4JSQkSJLatWtXZNvy5ctlGIYeeOABderUSZJ02WWX6YEHHpBpmlq3bp07hwYAAAAAr+FWcPvtt98kqchlkgcPHlR8fLwk6cYbbyy0rWfPnq42AAAAAIDzcyu4maYpSUpKSiq0ftOmTZIkh8OhSy+9tNC2evXqSZLS09PdOTQAAAAAeA23gltERIQkaf/+/YXWr1mzRpLUo0ePIvukpaVJksLDw905NAAAAAB4DbeC2xVXXCHTNDVz5kzXCNqhQ4f06aefyjAM/elPfyqyz4EDByT9EfoAAAAAAKVzK7jdfffdkpxT/7dv317Dhw/XFVdcoYyMDNWqVUsjRowoss+XX34pSWrdurU7hwYAAAAAr+FWcLvmmms0YcIEmaapuLg4ffLJJzp58qQkaerUqapfv36h9hkZGa7RuKuvvtqdQwMAAACA1/Bzt4NXXnlFffv21aJFi5SYmKjIyEiNGjVK11xzTZG2S5cuVVhYmBwOh4YMGeLuoQEAAADAKxhm/tSQqBbJyclyOBxKSkpSWFiY1eUAAAAAsEh5soFbl0oCAAAAAKoewQ0AAAAAbM6te9yOHDni1sGbNm3q1v4AAAAA4A3cCm7R0dEV3tcwDOXk5LhzeAAAAADwCm4FN+Y1AQAAAICq51ZwmzNnznnbpKWl6cCBA/r4448VHx+vHj16uB7cDQAAAAA4v2p7HEB2drYeeughzZw5U5MmTdKLL75YHYe1HR4HAAAAAECy6eMA/P399cYbb6h3796aOnWq1qxZU12HBgAAAACPVu2PAxg3bpxM09S///3v6j40AAAAAHikag9urVq1kiRt3bq1ug8NAAAAAB6p2oNbUlJSoa8AAAAAgNJVe3CbO3euJCkyMrK6Dw0AAAAAHqnagtvPP/+se++9V3PnzpVhGLr22mur69AAAAAA4NHceo5bixYtztsmLy9PZ86cUUpKimtdgwYN9OSTT7pzaAAAAADwGm4Ft7i4uHLv0717d7377rtcKgkAAAAAZeRWcBs9evR52/j4+Cg0NFTR0dHq1auXLr30UncOCQAAAABex63gNmfOnMqqAwAAAABQgmqfVRIAAAAAUD4ENwAAAACwOYIbAAAAANhcme5xmzdvXpUcfNSoUVXSLwAAAADUJIZpmub5Gvn4+MgwjMo9sGEoJyenUvv0BMnJyXI4HEpKSlJYWJjV5QAAAACwSHmyQZlnlSxDvgMAAAAAVIEyBbfY2NiqrgMAAAAAUIIyBbdmzZpVdR0AAAAAgBIwqyQAAAAA2BzBDQAAAABsrsyTkxQnKSlJr732miRp7NixioyMLLV9QkKC3n77bUnSww8/rNq1a7tzeAAAAADwCm4Ft/nz5ysmJkatWrXS5MmTz9s+IiJC8+fP1y+//KLGjRvrrrvucufwAAAAAOAV3LpUctWqVTIMQ3/5y1/K1N4wDN1yyy0yTVPLli1z59AAAAAA4DXcCm47d+6UJF155ZVl3qd79+6F9nVXSkqKYmJi1KFDB4WEhMjhcKhr1656+eWXlZWVVSnHyHfvvffKMAwZhqHmzZtXat8AAAAAUBK3LpX89ddfJem897YVFBERIUk6ceKEO4eWJB0+fFi9e/dWXFycJCk4OFiZmZnaunWrtm7dqvnz52v9+vUKDw93+1gbNmzQrFmz3O4HAAAAAMrLrRG3oKAgSVJ6enqZ98lv6+vr686hlZOToyFDhiguLk6RkZFau3at0tLSlJ6ergULFig0NFQ7duzQyJEj3TpOfs1jx46Vn5+fLrvsMrf7AwAAAIDycCu45Y+0bd26tcz75LfNH3mrqLlz52r37t2SpI8//lj9+vWTJPn4+Ojmm2/WW2+9JUlauXKl1q9f79axnnzySR08eFCPPvqo2rVr51ZfAAAAAFBebgW3nj17yjRNzZgxQ9nZ2edtn52drRkzZsgwDF111VXuHFpz586VJPXp08d131xBt9xyi6KjoyVJ8+bNq/Bxvv32W73++utq3bq1nnrqqQr3AwAAAAAV5VZwu/POOyVJP//8s0aMGFHqJZPp6em69dZbdeDAgUL7VkR6ero2b94sSRo0aFCxbQzD0MCBAyVJn332WYWOk5mZqTFjxsg0Tc2aNct1aSgAAAAAVCe3Jie58sordcstt2jBggVasmSJtmzZorFjx6pnz56uyygTEhL05Zdf6p133tGxY8dkGIaGDx+uXr16Vfi4+/fvV15eniSpffv2JbbL35aYmKhTp06pbt265TrO//3f/2n//v26++673aoXAAAAANzhVnCTpHfffVcnT57UunXrdOzYMU2ZMqXYdqZpSpL+9Kc/uS5zrKjjx4+7lhs3blxiu4Lbjh8/Xq7gtmPHDr300ktq2LChpk6dWrFC5Ry1y8zMdH2fnJxc4b4AAAAAeCe3LpWUnDNLrlmzRq+++qoaN24s0zSLfUVFRen111/X6tWr3b7kMCUlxbUcHBxcYruC2wrucz45OTkaM2aMcnJy9Prrr6tOnToVqlOSXnjhBTkcDtcrKiqqwn0BAAAA8E5uj7hJzvvJHnzwQY0fP147d+7Ujh07dPLkSUlS/fr11blzZ11yySUyDKMyDlflXnzxRe3cuVODBw/WX/7yF7f6evzxx/W3v/3N9X1ycjLhDQAAAEC5VEpwy2cYhjp16qROnTpVZrdFhIaGupbPNyFKcfuUZt++fXrmmWcUEhKiGTNmVLzI/wkMDFRgYKDb/QAAAADwXm5fKmmFRo0auZbj4+NLbFdwW8F9SnP//fcrKytLTz75pMLDw5WamlrolZOTI8l5z17+urI8CgEAAAAAKsojg9vFF18sHx9n6Xv27CmxXf62iIiIMk9MEhsbK8l5iWNoaGiR1/z58yVJR44cca2bPn26O28HAAAAAErlkcEtODhYPXr0kCStXr262DamaWrNmjWSpP79+1dbbQAAAABQ2TwyuEnS6NGjJUkbNmzQd999V2T7okWLdOjQIUnSqFGjytxvXFxciTNjmqbpOm6zZs1c6yZOnOj+GwIAAACAEnh0cOvQoYNM09RNN92k9evXS5Ly8vK0aNEijR07VpI0aNAg9e3bt9C+MTExMgxDhmEoLi6uuksHAAAAgHKp1Fklq5Ofn5+WLl2qPn36KC4uTv369VNwcLDy8vKUkZEhSerUqZPrnjQAAAAA8FQeO+ImSc2bN9euXbs0efJktW/fXoZhyN/fX126dNG0adP07bffKjw83OoyAQAAAMAthmmaptVFeJPk5GQ5HA4lJSUpLCzM6nIAAAAAWKQ82cCjR9wAAAAAwBsQ3AAAAADA5ghuAAAAAGBzBDcAAAAAsDmCGwAAAADYHMENAAAAAGyO4AYAAAAANkdwAwAAAACbI7gBAAAAgM0R3AAAAADA5ghuAAAAAGBzBDcAAAAAsDmCGwAAAADYHMENAAAAAGyO4AYAAAAANkdwAwAAAACbI7gBAAAAgM0R3AAAAADA5ghuAAAAAGBzBDcAAAAAsDmCGwAAAADYHMENAAAAAGyO4AYAAAAANkdwAwAAAACbI7gBAAAAgM0R3AAAAADA5ghuAAAAAGBzBDcAAAAAsDmCGwAAAADYHMENAAAAAGyO4AYAAAAANkdwAwAAAACbI7gBAAAAgM0R3AAAAADA5ghuAAAAAGBzBDcAAAAAsDmCGwAAAADYHMENAAAAAGyO4AYAAAAANkdwAwAAAACbI7gBAAAAgM0R3AAAAADA5ghuAAAAAGBzBDcAAAAAsDmCGwAAAADYHMENAAAAAGyO4AYAAAAANkdwAwAAAACbI7gBAAAAgM0R3AAAAADA5ghuAAAAAGBzBDcAAAAAsDmCGwAAAADYHMENAAAAAGyO4AYAAAAANkdwAwAAAACbI7gBAAAAgM0R3AAAAADA5ghuAAAAAGBzBDcAAAAAsDmCGwAAAADYHMENAAAAAGyO4AYAAAAANkdwAwAAAACbI7gBAAAAgM0R3AAAAADA5ghuAAAAAGBzBDcAAAAAsDmCGwAAAADYHMENAAAAAGyO4AYAAAAANkdwAwAAAACbI7gBAAAAgM0R3AAAAADA5ghuAAAAAGBzBDcAAAAAsDmCGwAAAADYHMENAAAAAGyO4AYAAAAANufxwS0lJUUxMTHq0KGDQkJC5HA41LVrV7388svKysqqUJ/x8fGaMWOG/vznP+vCCy9UrVq1VKtWLUVHR+vWW2/V559/XsnvAgAAAABKZpimaVpdREUdPnxYvXv3VlxcnCQpODhYubm5yszMlCR16tRJ69evV3h4eJn7PHr0qJo1a6aCfyzBwcEyTVNnz551rRszZoxmzZolX1/fctWcnJwsh8OhpKQkhYWFlWtfAAAAADVHebKBx4645eTkaMiQIYqLi1NkZKTWrl2rtLQ0paena8GCBQoNDdWOHTs0cuTIcvWbm5sr0zTVt29fzZ07V/Hx8UpLS1Nqaqr27t2rG264QZL07rvvKiYmpgreGQAAAAAU5rEjbrNnz9bdd98tSfr666/VvXv3Qts/+ugjjRgxQpK0bt069e3bt0z9JiUl6eDBg+rcuXOx203T1LXXXqvVq1crJCREv/32m4KCgspcNyNuAAAAACQvGXGbO3euJKlPnz5FQpsk3XLLLYqOjpYkzZs3r8z9OhyOEkObJBmGoTFjxkiSUlNTtX///vKUDQAAAADl5pHBLT09XZs3b5YkDRo0qNg2hmFo4MCBkqTPPvusUo9fcIQtNze3UvsGAAAAgHN5ZHDbv3+/8vLyJEnt27cvsV3+tsTERJ06darSjr9x40ZJUkBAgFq3bl1p/QIAAABAcfysLqAijh8/7lpu3Lhxie0Kbjt+/Ljq1q3r9rFjY2P15ptvSpJuvvnm816LmpmZ6ZrlUnJexwoAAAAA5eGRI24pKSmu5eDg4BLbFdxWcJ+KOnv2rP785z8rPT1d9evX14svvnjefV544QU5HA7XKyoqyu06AAAAAHgXjwxuVsjJydGIESO0bds2+fv7a/78+WrUqNF593v88ceVlJTkeh09erQaqgUAAABQk3jkpZKhoaGu5fT09BLbFdxWcJ/yys3N1W233ab//ve/8vPz04cffqj+/fuXad/AwEAFBgZW+NgAAAAA4JEjbgVHuuLj40tsV3BbWUbHipObm6uRI0dq4cKF8vX11QcffKDhw4dXqC8AAAAAqAiPDG4XX3yxfHycpe/Zs6fEdvnbIiIiKjQxSf5I24IFC1yh7eabb65Y0QAAAABQQR4Z3IKDg9WjRw9J0urVq4ttY5qm1qxZI0llvqyxoNzcXI0YMUL/+c9/XKHtlltuqXjRAAAAAFBBHhncJGn06NGSpA0bNui7774rsn3RokU6dOiQJGnUqFHl6jt/pG3hwoXy8/PT/PnzCW0AAAAALOPRwa1Dhw4yTVM33XST1q9fL0nKy8vTokWLNHbsWEnSoEGD1Ldv30L7xsTEyDAMGYahuLi4Qtvy72n7z3/+45qIhMsjAQAAAFjJI2eVlCQ/Pz8tXbpUffr0UVxcnPr166fg4GDl5eUpIyNDktSpUyfNnz+/XP1u3rxZCxYskCQZhqHx48dr/PjxJbZ/7bXXCHYAAAAAqpTHBjdJat68uXbt2qVp06ZpyZIlio2Nlb+/v9q1a6dbb71V48ePV0BAQLn6zMvLcy1nZ2frxIkTpbY/e/ZshWoHAAAAgLIyTNM0rS7CmyQnJ8vhcCgpKUlhYWFWlwMAAADAIuXJBh57jxsAAAAAeAuCGwAAAADYHMENAAAAAGyO4AYAAAAANkdwAwAAAACbI7gBAAAAgM0R3AAAAADA5ghuAAAAAGBzBDcAAAAAsDmCGwAAAADYHMENAAAAAGyO4AYAAAAANkdwAwAAAACbI7gBAAAAgM0R3AAAAADA5ghuAAAAAGBzBDcAAAAAsDmCGwAAAADYHMENAAAAAGyO4AYAAAAANkdwAwAAAACbI7gBAAAAgM35WV0AKi4vL085OTnKy8uzuhTUMD4+PvLz85OPD/+3AwAAYAcENw+UlJSk5ORkpaenE9pQZXx8fBQcHKywsDA5HA6rywEAAPBqBDcPYpqmTpw4odOnTys4OFj169dXUFCQfHx8ZBiG1eWhhjBNU3l5ecrIyFBqaqqOHz+us2fPqmHDhvycAQAAWITg5kFOnz6t06dPKyIiQuHh4VaXgxqudu3aqlevnk6fPq3ExEQFBASobt26VpcFAADglbiBxUOYpqkzZ84oNDSU0IZqFR4ertDQUJ05c0amaVpdDgAAgFciuHmInJwcZWZmcq8RLOFwOJSZmamcnByrSwEAAPBKBDcPkZubK0ny8+PqVlS//J+7/J9DAAAAVC+Cm4dhcghYgZ87AAAAaxHcAAAAAMDmCG4AAAAAYHMENwAAAACwOYIbAAAAANgcwQ1ww3vvvSfDMGQYhuLi4opts2LFCg0YMED169eXr6+vDMNQnTp1qrVOAAAAeDbmlgeq0IwZM3T//fdbXQYAAAA8HMENqCLp6el64oknJElt2rTRs88+q5YtW8rPz0++vr4WVwcAAABPQnADqsjWrVuVlJQkSZo2bZquu+46iysCAACAp+IeN6CKxMfHu5Zbt25tYSUAAADwdAQ3oIpkZma6lv39/S2sBAAAAJ6O4AaU4vTp03rsscfUpk0b1apVSw0aNFC/fv20aNGiEvfp3bu3DMPQnXfe6VoXHR3tmn3SMAxt3LixyH6//fab/u///k89evRQgwYN5O/vr/DwcF1++eV69NFHtWvXriL7ZGVladmyZXrggQfUtWtXhYeHy9/fX/Xq1dPll1+umJgYnTx5slL+LAAAAGAd7nGDe3JzpU2bpIQEKTJS6tlTqiETb+zfv1/9+vXT8ePHXesyMjK0fv16rV+/XnfeeaeuvvrqSjnW/PnzNW7cOKWlpRVaf+bMGW3ZskVbtmzRwoULizxy4J577tHcuXOL9Hfq1CnXfm+88YY+/fRT9ejRo1JqBQAAQPUjuKHiliyRJkyQjh37Y12TJtJrr0nDhllXVyVITk7WgAEDXKHt5ptv1ujRo9WgQQMdOHBA//rXvzRnzhzt2bOnyL5z5sxRWlqaPv30Uz311FOSpDVr1qhRo0auNtHR0a7l999/X6NGjZIkBQUFaezYsRo0aJAiIiKUmpqqXbt2aenSpfr555+LHCsnJ0ctWrTQjTfeqG7duqlp06by8/PT4cOHtW7dOr377rv6/fffdeONN2rPnj1q0KBBpf45AQAAoHoYpmmaVhfhTZKTk+VwOJSUlKSwsLAy75eRkaHY2FhFR0crKCioCissoyVLpOHDpXN/fAzD+XXxYo8Ob5MmTdK0adMkSc8//7wef/zxQtuzs7M1ePBgffbZZ651sbGxat68uev79957z3W55Lnb8iUkJOjCCy9Uenq6GjRooPXr16t9+/bF1nT06FFFRUUVWnfw4EG1aNFCRv6f+zl2796tK6+8UqmpqXrqqaf0zDPPnPe9F8d2P38AAAA1QHmyASNuNY1pSunpVXuM3FzpwQeLhrb84xuGcySuX7+qvWwyOPiPoFiJsrKyNHv2bElSx44d9dhjjxVp4+/vr9mzZ6tFixbKzs6u8LH+/e9/K/1/52vWrFklhjZJRUKbJLVs2bLU/jt06KC7775br776qv773/9WOLgBAADAWgS3miY9XQoJsbYG03RePulwVO1xUlOl2rUrvdtt27bp9OnTkqTRo0eXOJrVpEkT9e/fXytWrKjwsZYvXy5JatGiha6//voK95Pv9OnTOnXqlDIyMpQ/mF6nTh1J0r59+5Sdnc0MlwAAAB6I4AacY/fu3a7lrl27ltq2W7duFQ5u2dnZrnvkrrrqqhID4vns3r1br7zyilatWqXExMQS2+Xl5en06dPc5wYAAOCBCG41TXCwcySqKn35pXTttedvt3KlVEmzLhYrOLhKuj116pRr+Xwhp2HDhm4dJ39ULDIyskJ9zJ49W/fee69ycnLK1P7s2bMVOg4AAACsRXCraQyjSi4fLKR/f+fskfHxxd/nZhjO7f37e/yjASo6ClYdfvzxR1doa9CggSZNmqRrrrlGzZs3V2hoqOuSyHfffVd33XWXJIm5iAAAADwTwQ3l5+vrnPJ/+HBnSCsYBvKDzquvemxoCw8Pdy2fOHFCrVu3LrHtiRMnKnycunXrysfHR3l5eUpISCj3/u+9955ycnLk6+urL774Qm3atCm2XcERRAAAAHgmH6sLgIcaNsw55X/jxoXXN2ni8Y8C6NChg2v5+++/L7Xt+baXxt/f3zWL5KZNm8o9GrZ3715J0iWXXFJiaJOkrVu3VrhGAAAA2APBDRU3bJgUFydt2CB9+KHza2ysR4c2SerSpYtr1O39998vMVDFx8cXeo5bRQwZMkSS8zlvn376abn2zb+vLS0trcQ2CQkJWrp0acULBAAAgC0Q3OAeX1+pd2/p1ludXz308siCAgMDXQ/O3rlzp6ZOnVqkTU5OjsaOHausrCy3jvXAAw+o9v/uSRw3bpxrlsniHDt2rND3rVq1kiT9/PPP+vrrr4u0T09P14gRI5iQBAAAoAYguAHFmDx5spo0aSJJ+vvf/64RI0Zo9erV2r59uxYsWKArr7xSq1at0mWXXebWcSIiIjRz5kxJ0q+//qpu3bppwoQJWr16tXbu3KmvvvpKb775pq699lr16tWr0L633367JOc0/9ddd52ef/55ffnll9qyZYtmzpypSy+9VBs3blSPHj3cqhEAAADWY3ISoBgOh0OrV69Wv379lJiYqI8++kgfffRRoTZ33HGHevXq5Rqdq6jbb79deXl5uu+++3T27Fm9/vrrev3114u0a9asWaHvu3btqqefflpTpkzRmTNn9OSTTxbZ5+GHH1b79u21efNmt2oEAACAtRhxA0rQrl077d27V48++qhatWqlwMBA1a9fX3369NGHH36oOXPmVNqxRo8erYMHD+rJJ59Uly5dVKdOHfn6+io8PFxXXHGFnnjiCa1evbrIfpMnT9aKFSvUv39/hYeHKyAgQE2aNNGwYcP02Wefadq0aZVWIwAAAKxjmDzYqVolJyfL4XAoKSlJYWFhZd4vIyNDsbGxio6OVlBQUBVWCBTFzx8AAEDlK082YMQNAAAAAGyO4AYAAAAANkdwAwAAAACbI7gBAAAAgM0R3AAAAADA5ghuAAAAAGBzBDcAAAAAsDmCGwAAAADYHMENAAAAAGyO4AYAAAAANkdw8zCmaVpdArwQP3cAAADWIrh5CB8f56nKy8uzuBJ4o9zcXEl//BwCAACgevGvMA/h7+8vX19fpaWlWV0KvFB6erp8fX3l7+9vdSkAAABeieDmIQzDUGhoqJKTk7lsDdXKNE0lJycrNDRUhmFYXQ4AAIBXIrh5EIfDoezsbB0/fpzwhmphmqaOHz+u7OxsORwOq8sBAADwWn5WF4CyCw4OVpMmTXTs2DGdPXtWYWFhCg4Olq+vLyMhqDSmaSo3N1fp6elKTk5Wdna2mjRpouDgYKtLAwAA8FoENw8TGhqqZs2aKSkpSWfOnNHvv/9udUmooXx9fRUaGiqHw0FoAwAAsBjBzQMFBwcrODhYERERys7OZqZJVDofHx/5+/szkgsAAGATBDcPZhiGAgICrC4DAAAAQBVjchIAAAAAsDmCGwAAAADYnMcHt5SUFMXExKhDhw4KCQmRw+FQ165d9fLLLysrK8utvk+cOKGHH35YF110kWrVqqW6deuqZ8+eeuedd5iOHwAAAEC1MUwPTiCHDx9W7969FRcXJ8k5aUdubq4yMzMlSZ06ddL69esVHh5e7r63bdumAQMGuGZtDAkJUUZGhnJyciRJAwYM0NKlS8t9j1lycrIcDoeSkpIUFhZW7roAAAAA1AzlyQYeO+KWk5OjIUOGKC4uTpGRkVq7dq3S0tKUnp6uBQsWKDQ0VDt27NDIkSPL3XdSUpIGDx6s33//XW3atNH333+vlJQUpaWl6Y033pC/v7/WrFmjiRMnVv4bAwAAAIBzeGxwmzt3rnbv3i1J+vjjj9WvXz9JzmnMb775Zr311luSpJUrV2r9+vXl6nvatGlKTExUrVq1tHLlSl122WWSpICAAN1///16+umnJUmzZs3SgQMHKustAQAAAECxPDq4SVKfPn3UvXv3IttvueUWRUdHS5LmzZtXrr7z2xfso6Dx48crJCREubm5mj9/fnlLBwAAAIBy8cjglp6ers2bN0uSBg0aVGwbwzA0cOBASdJnn31W5r5/+uknHTlypNS+Q0JC1LNnz3L3DQAAAAAV4ZHBbf/+/crLy5MktW/fvsR2+dsSExN16tSpMvW9Z8+eIvuX1ve+ffvK1C8AAAAAVJRHBrfjx4+7lhs3blxiu4LbCu5TmX0nJycrNTW1TH0DAAAAQEX4WV1ARaSkpLiWg4ODS2xXcFvBfaqi75CQkGLbZWZmuh5PIDlnrJScgQ8AAACA98rPBGV5QptHBjdP8sILL7hmoSwoKirKgmoAAAAA2E1KSoocDkepbTwyuIWGhrqW09PTS2xXcFvBfcrTd0kPwitr348//rj+9re/ub7Py8vTqVOnVK9ePRmGUaaaqkpycrKioqJ09OhRHgZeg3Beax7Oac3Eea15OKc1E+e15rHTOTVNUykpKWrUqNF523pkcCv4xuLj49WxY8di28XHxxe7T3n6Lulk5vcdFhZW4mWSkhQYGKjAwMBC6+rUqVOmWqpLWFiY5T+0qHyc15qHc1ozcV5rHs5pzcR5rXnsck7PN9KWzyMnJ7n44ovl4+MsveAskOfK3xYREaG6deuWqe+CM0mWpe+2bduWqV8AAAAAqCiPDG7BwcHq0aOHJGn16tXFtjFNU2vWrJEk9e/fv8x9t27dWk2bNi2177S0NG3atKncfQMAAABARXhkcJOk0aNHS5I2bNig7777rsj2RYsW6dChQ5KkUaNGlblfwzBc7RcsWKC4uLgibaZPn67U1FT5+vrqtttuq0D19hAYGKgpU6YUuZQTno3zWvNwTmsmzmvNwzmtmTivNY+nnlPDLMvckzaUk5Ojzp07a/fu3WrcuLHmzp2rvn37Ki8vTx9//LHuvvtuJScna9CgQVq5cmWhfWNiYlwzPcbGxqp58+aFticlJalNmzZKTExU27ZtNW/ePHXp0kVZWVmaPXu2Jk6cqKysLN13332aMWNGdb1lAAAAAF7KIycnkSQ/Pz8tXbpUffr0UVxcnPr166fg4GDl5eUpIyNDktSpUyfNnz+/3H07HA4tX75cAwYM0L59+3TZZZcpNDRUGRkZys7OluS8RPKVV16p1PcEAAAAAMXx2EslJal58+batWuXJk+erPbt28swDPn7+6tLly6aNm2avv32W4WHh1eo7y5dumjv3r166KGH1KpVK2VnZ6t27dq66qqr9Pbbb2vVqlUeN7wKAAAAwDN57KWSAAAAAOAtPHrEDQAAAAC8AcHNC6WkpCgmJkYdOnRQSEiIHA6HunbtqpdffllZWVlWl4dyeu+992QYxnlf69ats7pU/E96erpWrVqlZ599VsOGDVOzZs1c5ykmJqZMfZw4cUIPP/ywLrroItWqVUt169ZVz5499c4774gLKazhznmNiYkp0+/xL7/8Uj1vBpKk33//XXPmzNHIkSPVtm1b1a5dW4GBgWrSpImGDh2qTz755Lx98JlrP+6cVz5z7Wn79u16+umndf3116tNmzaqV6+e/P39Va9ePfXo0UPPPfecTp06VWofnvC56rGTk6BiDh8+rN69e7secxAcHKzMzExt3bpVW7du1fz587V+/foK3xsI6/j4+OiCCy4ocTv3ZNrHli1bdO2111Z4/23btmnAgAH6/fffJUkhISFKSUnRV199pa+++kqLFy/W0qVLFRAQUFklowzcPa+S5O/vr7p165a43c+Pj+3qFBERoZycHNf3QUFB8vf3V3x8vOLj4/Xpp59q0KBBWrx4sYKDg4vsz2euPbl7XiU+c+3m3Xff1fTp013fBwUFqVatWjp16pS+/vprff3113r11Ve1dOlSde/evcj+nvK5yoibF8nJydGQIUMUFxenyMhIrV27VmlpaUpPT9eCBQsUGhqqHTt2aOTIkVaXigqIiopSYmJiia+ePXtaXSIKCA8PV9++fTVp0iR99NFHioiIKNN+SUlJGjx4sH7//Xe1adNG33//vVJSUpSWlqY33nhD/v7+WrNmjSZOnFi1bwDFquh5zXfllVeW+nt87uNrULVycnLUrVs3zZgxQwcPHtTZs2eVmpqq2NhY3XXXXZKkVatWady4ccXuy2euPblzXvPxmWsv3bp109SpU/XNN9/o9OnTOnv2rJKTk5WSkqK5c+fqggsu0MmTJzV06FAlJSUV2tejPldNeI133nnHlGRKMr/++usi2z/88EPX9nXr1llQISpizpw5piSzWbNmVpeCMsrJySmyrlmzZqYkc8qUKaXu+9RTT5mSzFq1apmHDh0qsv355583JZm+vr7mTz/9VFklowzcOa9TpkwxJZm9evWq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",
      "text/plain": [
       "<Figure size 1000x700 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "r_dfca = {}\n",
    "\n",
    "r_dfca['test_loss'] = []\n",
    "r_dfca['test_acc'] = []\n",
    "r_dfca['cl_acc'] = []\n",
    "for i in range(len(learning_rates)):\n",
    "    r_dfca['test_loss'].append(dfca[i][0])\n",
    "    r_dfca['test_acc'].append(dfca[i][1])\n",
    "    r_dfca['cl_acc'].append(dfca[i][2])\n",
    "\n",
    "os.makedirs('graphs', exist_ok=True)\n",
    "\n",
    "avg_test_loss = np.mean([loss[-1] for loss in r_dfca['test_loss']])\n",
    "avg_test_acc = np.mean([acc[-1] for acc in r_dfca['test_acc']])\n",
    "avg_cl_acc = np.mean([cl_acc[-1] for cl_acc in r_dfca['cl_acc']])\n",
    "std_test_acc = np.std([acc[-1] for acc in r_dfca['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_dfca['test_loss'][l], label='dfca', 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_dfca['test_acc'][l], label='dfca', 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_dfca['cl_acc'][l][:31], label='dfca', 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
}
