{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-21T13:14:32.675078Z",
     "iopub.status.busy": "2025-09-21T13:14:32.674603Z",
     "iopub.status.idle": "2025-09-21T13:14:39.854079Z",
     "shell.execute_reply": "2025-09-21T13:14:39.853332Z"
    },
    "id": "OHJWesKs-tqd"
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-09-21 15:14:36.896812: 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:1758460476.924609 4028755 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:1758460476.932793 4028755 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:1758460476.954916 4028755 computation_placer.cc:177] computation placer already registered. Please check linkage and avoid linking the same target more than once.\n",
      "W0000 00:00:1758460476.954957 4028755 computation_placer.cc:177] computation placer already registered. Please check linkage and avoid linking the same target more than once.\n",
      "W0000 00:00:1758460476.954959 4028755 computation_placer.cc:177] computation placer already registered. Please check linkage and avoid linking the same target more than once.\n",
      "W0000 00:00:1758460476.954962 4028755 computation_placer.cc:177] computation placer already registered. Please check linkage and avoid linking the same target more than once.\n",
      "2025-09-21 15:14:36.961848: 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 dec_ifca as dfca\n",
    "import dfca as DFCA\n",
    "import ifca as IFCA\n",
    "\n",
    "import numpy as np\n",
    "\n",
    "from util import *"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "QAghP_o0-tqe"
   },
   "source": [
    "Reads Config file and prepares the arguments you can choose in the config_dfca.json/config_ifca.json"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-21T13:14:39.857178Z",
     "iopub.status.busy": "2025-09-21T13:14:39.856609Z",
     "iopub.status.idle": "2025-09-21T13:14:39.860917Z",
     "shell.execute_reply": "2025-09-21T13:14:39.860110Z"
    }
   },
   "outputs": [],
   "source": [
    "learning_rates = [0.25]\n",
    "\n",
    "dfca = []"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-21T13:14:39.863163Z",
     "iopub.status.busy": "2025-09-21T13:14:39.862912Z",
     "iopub.status.idle": "2025-09-21T13:14:39.867231Z",
     "shell.execute_reply": "2025-09-21T13:14:39.866601Z"
    }
   },
   "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": 4,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 1000
    },
    "execution": {
     "iopub.execute_input": "2025-09-21T13:14:39.869652Z",
     "iopub.status.busy": "2025-09-21T13:14:39.869402Z",
     "iopub.status.idle": "2025-09-23T06:09:37.308029Z",
     "shell.execute_reply": "2025-09-23T06:09:37.306217Z"
    },
    "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': 50, 'm_test': 10, 'p': 2, 'n': 2000, 'local_model_init': False, 'participation_rate': 1, 'Gp': 0.25, 'graph': 'er', 'agg': 'seq', 'num_epochs': 150, 'batch_size': 50, 'tau': 10, 'lr': 0.25, 'data_seed': 1824, 'train_seed': 1824, 'project_dir': 'output'}\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Using device: cuda:2\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:1758460486.508466 4028755 gpu_device.cc:2019] Created device /job:localhost/replica:0/task:0/device:GPU:0 with 33884 MB memory:  -> device: 2, name: NVIDIA A100-SXM4-40GB, pci bus id: 0000:81:00.0, compute capability: 8.0\n",
      "WARNING: All log messages before absl::InitializeLog() is called are written to STDERR\n",
      "I0000 00:00:1758460486.583529 4028755 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-09-21 15:14:46.903444: 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:1758460488.049463 4029464 cuda_dnn.cc:529] Loaded cuDNN version 90501\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch -1 tr: l 4.670 a 0.102  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] cl_acc 0.500 7.638sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-09-21 15:14:54.647877: 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.097  clct[np.int64(0), np.int64(50)] ans[np.int64(25), np.int64(25)] cl_acc 0.500 7.268sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-09-21 15:15:02.088286: 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.679 a 0.104  clct[np.int64(19), np.int64(31)] ans[np.int64(25), np.int64(25)] cl_acc 0.520 7.010sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-09-21 15:15:09.260404: 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(50), np.int64(0)] ans[np.int64(25), np.int64(25)] cl_acc 0.500 6.787sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-09-21 15:15:16.220101: 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.126  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] cl_acc 0.500 5.974sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-09-21 15:15:22.365455: 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(49), np.int64(1)] ans[np.int64(25), np.int64(25)] cl_acc 0.520 5.771sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-09-21 15:15:28.273228: 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.103  clct[np.int64(31), np.int64(19)] ans[np.int64(25), np.int64(25)] cl_acc 0.760 6.622sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-09-21 15:15:35.029118: 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.678 a 0.105  clct[np.int64(28), np.int64(22)] ans[np.int64(25), np.int64(25)] cl_acc 0.820 5.532sec\n",
      "found good initializer\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch -1 tr: l 4.679 a 0.104  clct[np.int64(31), np.int64(19)] ans[np.int64(25), np.int64(25)] cl_acc 0.760 5.468sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch -1 tst: l 4.678 a 0.105  clct[np.int64(6), np.int64(4)] ans[np.int64(5), np.int64(5)] cl_acc 0.900 1.084sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0 tr: l 3.214 a 0.278  clct[np.int64(31), np.int64(19)] ans[np.int64(25), np.int64(25)] lr 0.250000 cl_acc 0.760 162.813sec(train) 4.915sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0 tst: l 3.293 a 0.220  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 0.600 0.930sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1 tr: l 2.394 a 0.371  clct[np.int64(31), np.int64(19)] ans[np.int64(25), np.int64(25)] lr 0.247500 cl_acc 0.760 195.888sec(train) 6.154sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1 tst: l 2.474 a 0.323  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 0.600 1.251sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2 tr: l 1.892 a 0.467  clct[np.int64(29), np.int64(21)] ans[np.int64(25), np.int64(25)] lr 0.245025 cl_acc 0.800 203.423sec(train) 6.359sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2 tst: l 1.966 a 0.440  clct[np.int64(6), np.int64(4)] ans[np.int64(5), np.int64(5)] cl_acc 0.700 1.216sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3 tr: l 1.616 a 0.530  clct[np.int64(29), np.int64(21)] ans[np.int64(25), np.int64(25)] lr 0.242575 cl_acc 0.920 202.792sec(train) 5.289sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3 tst: l 1.656 a 0.515  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 0.800 1.043sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4 tr: l 1.333 a 0.615  clct[np.int64(26), np.int64(24)] ans[np.int64(25), np.int64(25)] lr 0.240149 cl_acc 0.980 165.630sec(train) 5.838sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4 tst: l 1.432 a 0.579  clct[np.int64(6), np.int64(4)] ans[np.int64(5), np.int64(5)] cl_acc 0.900 1.181sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5 tr: l 1.188 a 0.657  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.237748 cl_acc 1.000 172.658sec(train) 6.413sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5 tst: l 1.251 a 0.641  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.261sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6 tr: l 1.154 a 0.669  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.235370 cl_acc 1.000 173.756sec(train) 6.319sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6 tst: l 1.160 a 0.661  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.194sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7 tr: l 1.081 a 0.697  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.233016 cl_acc 1.000 172.337sec(train) 5.334sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7 tst: l 1.120 a 0.683  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.112sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8 tr: l 1.036 a 0.718  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.230686 cl_acc 1.000 159.880sec(train) 6.614sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8 tst: l 1.110 a 0.684  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.208sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9 tr: l 0.982 a 0.738  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.228379 cl_acc 1.000 184.150sec(train) 7.664sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9 tst: l 1.094 a 0.699  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.525sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10 tr: l 0.980 a 0.741  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.226096 cl_acc 1.000 219.202sec(train) 7.844sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10 tst: l 1.070 a 0.705  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.883sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11 tr: l 0.946 a 0.757  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.223835 cl_acc 1.000 217.512sec(train) 6.297sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11 tst: l 1.061 a 0.714  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.259sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12 tr: l 0.911 a 0.770  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.221596 cl_acc 1.000 168.242sec(train) 6.020sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12 tst: l 1.048 a 0.717  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.187sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13 tr: l 0.925 a 0.764  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.219380 cl_acc 1.000 171.985sec(train) 6.065sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13 tst: l 1.060 a 0.717  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.143sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14 tr: l 0.885 a 0.779  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.217186 cl_acc 1.000 170.948sec(train) 6.514sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14 tst: l 1.049 a 0.722  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.111sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15 tr: l 0.893 a 0.776  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.215015 cl_acc 1.000 174.134sec(train) 6.082sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15 tst: l 1.052 a 0.723  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.168sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16 tr: l 0.888 a 0.777  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.212864 cl_acc 1.000 181.392sec(train) 6.124sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16 tst: l 1.021 a 0.731  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.057sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17 tr: l 0.837 a 0.798  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.210736 cl_acc 1.000 199.104sec(train) 6.480sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17 tst: l 1.046 a 0.731  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.163sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18 tr: l 0.853 a 0.792  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.208628 cl_acc 1.000 221.865sec(train) 7.613sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18 tst: l 1.012 a 0.738  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.568sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19 tr: l 0.816 a 0.806  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.206542 cl_acc 1.000 208.162sec(train) 5.013sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19 tst: l 1.013 a 0.739  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.020sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20 tr: l 0.817 a 0.807  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.204477 cl_acc 1.000 169.087sec(train) 5.779sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20 tst: l 1.014 a 0.740  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.232sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21 tr: l 0.818 a 0.805  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.202432 cl_acc 1.000 166.434sec(train) 5.813sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21 tst: l 1.009 a 0.740  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.048sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22 tr: l 0.782 a 0.818  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.200408 cl_acc 1.000 170.715sec(train) 5.170sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22 tst: l 0.996 a 0.743  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.996sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23 tr: l 0.793 a 0.814  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.198404 cl_acc 1.000 168.908sec(train) 5.513sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23 tst: l 1.000 a 0.744  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.030sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24 tr: l 0.791 a 0.815  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.196420 cl_acc 1.000 162.799sec(train) 4.841sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24 tst: l 0.993 a 0.747  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.021sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25 tr: l 0.789 a 0.816  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.194455 cl_acc 1.000 162.845sec(train) 5.064sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25 tst: l 0.968 a 0.751  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.967sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 26 tr: l 0.784 a 0.817  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.192511 cl_acc 1.000 210.675sec(train) 8.827sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 26 tst: l 0.962 a 0.754  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.745sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 27 tr: l 0.776 a 0.820  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.190586 cl_acc 1.000 234.222sec(train) 8.909sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 27 tst: l 0.960 a 0.754  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.709sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 28 tr: l 0.737 a 0.834  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.188680 cl_acc 1.000 193.271sec(train) 6.734sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 28 tst: l 0.979 a 0.752  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.207sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 29 tr: l 0.739 a 0.834  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.186793 cl_acc 1.000 180.287sec(train) 5.917sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 29 tst: l 0.971 a 0.754  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.065sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 30 tr: l 0.765 a 0.822  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.184925 cl_acc 1.000 168.530sec(train) 5.488sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 30 tst: l 0.947 a 0.760  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.080sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 31 tr: l 0.734 a 0.832  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.183076 cl_acc 1.000 170.000sec(train) 5.166sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 31 tst: l 0.945 a 0.760  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.018sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 32 tr: l 0.731 a 0.836  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.181245 cl_acc 1.000 169.093sec(train) 5.188sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 32 tst: l 0.963 a 0.757  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.007sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 33 tr: l 0.729 a 0.834  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.179433 cl_acc 1.000 174.256sec(train) 5.417sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 33 tst: l 0.952 a 0.761  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.059sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 34 tr: l 0.705 a 0.841  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.177638 cl_acc 1.000 215.046sec(train) 8.995sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 34 tst: l 0.932 a 0.765  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.770sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 35 tr: l 0.706 a 0.842  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.175862 cl_acc 1.000 221.846sec(train) 8.941sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 35 tst: l 0.937 a 0.765  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.430sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 36 tr: l 0.705 a 0.840  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.174103 cl_acc 1.000 203.221sec(train) 6.742sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 36 tst: l 0.935 a 0.766  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.297sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 37 tr: l 0.680 a 0.851  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.172362 cl_acc 1.000 221.283sec(train) 6.983sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 37 tst: l 0.954 a 0.760  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.432sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 38 tr: l 0.714 a 0.836  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.170639 cl_acc 1.000 219.225sec(train) 6.770sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 38 tst: l 0.946 a 0.765  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.499sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 39 tr: l 0.731 a 0.833  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.168932 cl_acc 1.000 213.956sec(train) 7.190sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 39 tst: l 0.932 a 0.766  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.371sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 40 tr: l 0.675 a 0.851  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.167243 cl_acc 1.000 174.331sec(train) 5.932sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 40 tst: l 0.927 a 0.768  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.151sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 41 tr: l 0.659 a 0.859  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.165571 cl_acc 1.000 184.624sec(train) 6.302sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 41 tst: l 0.936 a 0.764  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.221sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 42 tr: l 0.663 a 0.854  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.163915 cl_acc 1.000 201.549sec(train) 6.177sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 42 tst: l 0.922 a 0.769  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.152sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 43 tr: l 0.706 a 0.838  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.162276 cl_acc 1.000 205.683sec(train) 6.066sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 43 tst: l 0.915 a 0.770  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.200sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 44 tr: l 0.665 a 0.853  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.160653 cl_acc 1.000 207.832sec(train) 5.766sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 44 tst: l 0.926 a 0.771  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.207sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 45 tr: l 0.660 a 0.854  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.159046 cl_acc 1.000 209.217sec(train) 6.178sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 45 tst: l 0.906 a 0.775  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.097sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 46 tr: l 0.645 a 0.859  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.157456 cl_acc 1.000 206.853sec(train) 6.144sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 46 tst: l 0.900 a 0.775  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.298sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 47 tr: l 0.633 a 0.863  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.155881 cl_acc 1.000 210.731sec(train) 7.924sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 47 tst: l 0.911 a 0.772  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.479sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 48 tr: l 0.643 a 0.859  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.154323 cl_acc 1.000 211.637sec(train) 6.598sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 48 tst: l 0.919 a 0.773  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.287sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 49 tr: l 0.646 a 0.858  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.152779 cl_acc 1.000 212.358sec(train) 6.239sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 49 tst: l 0.894 a 0.778  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.525sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 50 tr: l 0.652 a 0.855  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.151252 cl_acc 1.000 212.092sec(train) 6.983sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 50 tst: l 0.914 a 0.773  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.442sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 51 tr: l 0.629 a 0.864  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.149739 cl_acc 1.000 210.000sec(train) 6.315sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 51 tst: l 0.896 a 0.777  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.333sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 52 tr: l 0.611 a 0.870  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.148242 cl_acc 1.000 201.557sec(train) 6.419sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 52 tst: l 0.884 a 0.777  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.177sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 53 tr: l 0.617 a 0.865  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.146759 cl_acc 1.000 199.089sec(train) 5.950sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 53 tst: l 0.894 a 0.779  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.238sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 54 tr: l 0.608 a 0.869  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.145292 cl_acc 1.000 191.251sec(train) 7.278sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 54 tst: l 0.887 a 0.781  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.392sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 55 tr: l 0.577 a 0.881  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.143839 cl_acc 1.000 218.579sec(train) 7.695sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 55 tst: l 0.900 a 0.778  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.350sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 56 tr: l 0.630 a 0.861  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.142400 cl_acc 1.000 236.507sec(train) 6.432sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 56 tst: l 0.889 a 0.778  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.251sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 57 tr: l 0.624 a 0.863  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.140976 cl_acc 1.000 232.374sec(train) 6.946sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 57 tst: l 0.886 a 0.780  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.459sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 58 tr: l 0.596 a 0.873  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.139567 cl_acc 1.000 256.555sec(train) 7.375sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 58 tst: l 0.886 a 0.780  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.525sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 59 tr: l 0.619 a 0.862  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.138171 cl_acc 1.000 255.106sec(train) 6.316sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 59 tst: l 0.878 a 0.781  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.182sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 60 tr: l 0.620 a 0.863  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.136789 cl_acc 1.000 209.575sec(train) 7.207sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 60 tst: l 0.875 a 0.782  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.359sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 61 tr: l 0.614 a 0.861  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.135421 cl_acc 1.000 209.397sec(train) 6.957sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 61 tst: l 0.856 a 0.786  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.325sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 62 tr: l 0.587 a 0.874  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.134067 cl_acc 1.000 211.842sec(train) 6.130sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 62 tst: l 0.872 a 0.785  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.250sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 63 tr: l 0.599 a 0.868  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.132726 cl_acc 1.000 213.090sec(train) 6.250sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 63 tst: l 0.860 a 0.786  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.250sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 64 tr: l 0.610 a 0.864  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.131399 cl_acc 1.000 220.097sec(train) 6.095sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 64 tst: l 0.853 a 0.785  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.271sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 65 tr: l 0.570 a 0.876  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.130085 cl_acc 1.000 244.725sec(train) 7.924sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 65 tst: l 0.864 a 0.786  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.429sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 66 tr: l 0.585 a 0.872  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.128784 cl_acc 1.000 265.238sec(train) 8.059sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 66 tst: l 0.851 a 0.790  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.549sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 67 tr: l 0.574 a 0.876  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.127496 cl_acc 1.000 227.410sec(train) 6.019sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 67 tst: l 0.859 a 0.787  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.182sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 68 tr: l 0.573 a 0.876  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.126221 cl_acc 1.000 209.002sec(train) 5.972sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 68 tst: l 0.865 a 0.786  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.153sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 69 tr: l 0.593 a 0.869  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.124959 cl_acc 1.000 213.470sec(train) 6.242sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 69 tst: l 0.845 a 0.789  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.283sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 70 tr: l 0.580 a 0.873  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.123710 cl_acc 1.000 217.351sec(train) 6.372sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 70 tst: l 0.845 a 0.792  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.336sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 71 tr: l 0.578 a 0.874  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.122473 cl_acc 1.000 221.336sec(train) 6.581sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 71 tst: l 0.850 a 0.788  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.187sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 72 tr: l 0.586 a 0.870  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.121248 cl_acc 1.000 228.424sec(train) 7.103sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 72 tst: l 0.857 a 0.788  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.623sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 73 tr: l 0.547 a 0.882  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.120035 cl_acc 1.000 231.477sec(train) 5.569sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 73 tst: l 0.857 a 0.789  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.099sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 74 tr: l 0.536 a 0.886  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.118835 cl_acc 1.000 188.417sec(train) 6.182sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 74 tst: l 0.844 a 0.791  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.214sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 75 tr: l 0.513 a 0.895  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.117647 cl_acc 1.000 190.878sec(train) 5.602sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 75 tst: l 0.840 a 0.791  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.119sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 76 tr: l 0.566 a 0.877  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.116470 cl_acc 1.000 190.224sec(train) 5.691sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 76 tst: l 0.852 a 0.792  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.042sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 77 tr: l 0.558 a 0.879  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.115305 cl_acc 1.000 191.013sec(train) 5.835sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 77 tst: l 0.836 a 0.792  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.177sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 78 tr: l 0.553 a 0.880  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.114152 cl_acc 1.000 189.312sec(train) 5.855sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 78 tst: l 0.830 a 0.794  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.141sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 79 tr: l 0.547 a 0.882  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.113011 cl_acc 1.000 186.199sec(train) 5.567sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 79 tst: l 0.850 a 0.790  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.174sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 80 tr: l 0.531 a 0.886  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.111881 cl_acc 1.000 180.106sec(train) 5.511sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 80 tst: l 0.834 a 0.795  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.018sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 81 tr: l 0.525 a 0.888  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.110762 cl_acc 1.000 176.137sec(train) 7.139sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 81 tst: l 0.824 a 0.794  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.409sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 82 tr: l 0.526 a 0.887  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.109654 cl_acc 1.000 242.370sec(train) 5.147sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 82 tst: l 0.824 a 0.794  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.042sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 83 tr: l 0.513 a 0.893  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.108558 cl_acc 1.000 199.994sec(train) 5.756sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 83 tst: l 0.814 a 0.798  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.114sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 84 tr: l 0.521 a 0.889  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.107472 cl_acc 1.000 199.927sec(train) 5.186sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 84 tst: l 0.820 a 0.797  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.997sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 85 tr: l 0.523 a 0.887  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.106398 cl_acc 1.000 199.060sec(train) 5.475sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 85 tst: l 0.822 a 0.795  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.024sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 86 tr: l 0.511 a 0.892  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.105334 cl_acc 1.000 201.813sec(train) 5.514sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 86 tst: l 0.806 a 0.799  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.185sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 87 tr: l 0.508 a 0.891  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.104280 cl_acc 1.000 204.692sec(train) 5.971sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 87 tst: l 0.816 a 0.796  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.031sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 88 tr: l 0.477 a 0.904  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.103237 cl_acc 1.000 219.557sec(train) 8.003sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 88 tst: l 0.818 a 0.797  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.679sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 89 tr: l 0.508 a 0.891  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.102205 cl_acc 1.000 251.113sec(train) 7.363sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 89 tst: l 0.813 a 0.799  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.277sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 90 tr: l 0.510 a 0.891  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.101183 cl_acc 1.000 228.982sec(train) 5.885sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 90 tst: l 0.831 a 0.796  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.145sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 91 tr: l 0.494 a 0.896  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.100171 cl_acc 1.000 190.909sec(train) 5.309sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 91 tst: l 0.815 a 0.797  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.046sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 92 tr: l 0.500 a 0.893  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.099169 cl_acc 1.000 188.297sec(train) 5.286sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 92 tst: l 0.807 a 0.797  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.068sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 93 tr: l 0.492 a 0.896  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.098178 cl_acc 1.000 183.101sec(train) 5.574sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 93 tst: l 0.812 a 0.798  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.080sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 94 tr: l 0.483 a 0.899  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.097196 cl_acc 1.000 184.560sec(train) 5.087sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 94 tst: l 0.807 a 0.800  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.014sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 95 tr: l 0.487 a 0.897  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.096224 cl_acc 1.000 192.943sec(train) 6.020sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 95 tst: l 0.808 a 0.801  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.136sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 96 tr: l 0.510 a 0.888  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.095262 cl_acc 1.000 180.399sec(train) 5.565sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 96 tst: l 0.803 a 0.801  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.024sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 97 tr: l 0.483 a 0.898  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.094309 cl_acc 1.000 217.724sec(train) 6.894sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 97 tst: l 0.809 a 0.801  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.379sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 98 tr: l 0.492 a 0.895  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.093366 cl_acc 1.000 236.563sec(train) 6.976sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 98 tst: l 0.801 a 0.800  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.390sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 99 tr: l 0.487 a 0.897  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.092432 cl_acc 1.000 197.604sec(train) 5.485sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 99 tst: l 0.812 a 0.800  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.090sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 100 tr: l 0.477 a 0.899  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.091508 cl_acc 1.000 182.814sec(train) 5.305sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 100 tst: l 0.817 a 0.798  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.199sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 101 tr: l 0.467 a 0.903  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.090593 cl_acc 1.000 179.246sec(train) 5.252sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 101 tst: l 0.787 a 0.802  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.133sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 102 tr: l 0.483 a 0.895  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.089687 cl_acc 1.000 176.628sec(train) 5.426sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 102 tst: l 0.791 a 0.805  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.143sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 103 tr: l 0.490 a 0.893  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.088790 cl_acc 1.000 178.144sec(train) 5.919sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 103 tst: l 0.794 a 0.805  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.176sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 104 tr: l 0.458 a 0.905  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.087902 cl_acc 1.000 180.022sec(train) 5.557sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 104 tst: l 0.791 a 0.802  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.093sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 105 tr: l 0.479 a 0.896  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.087023 cl_acc 1.000 181.882sec(train) 6.179sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 105 tst: l 0.799 a 0.803  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.255sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 106 tr: l 0.468 a 0.900  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.086153 cl_acc 1.000 233.666sec(train) 7.676sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 106 tst: l 0.795 a 0.804  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.453sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 107 tr: l 0.467 a 0.901  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.085292 cl_acc 1.000 232.587sec(train) 7.845sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 107 tst: l 0.784 a 0.803  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.218sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 108 tr: l 0.503 a 0.889  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.084439 cl_acc 1.000 178.309sec(train) 6.777sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 108 tst: l 0.781 a 0.804  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.260sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 109 tr: l 0.460 a 0.903  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.083594 cl_acc 1.000 199.500sec(train) 6.921sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 109 tst: l 0.783 a 0.806  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.270sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 110 tr: l 0.464 a 0.900  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.082758 cl_acc 1.000 203.525sec(train) 6.911sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 110 tst: l 0.791 a 0.805  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.150sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 111 tr: l 0.453 a 0.904  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.081931 cl_acc 1.000 208.171sec(train) 5.997sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 111 tst: l 0.779 a 0.806  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.244sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 112 tr: l 0.445 a 0.908  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.081111 cl_acc 1.000 208.106sec(train) 6.314sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 112 tst: l 0.778 a 0.806  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.304sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 113 tr: l 0.436 a 0.910  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.080300 cl_acc 1.000 202.913sec(train) 6.175sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 113 tst: l 0.776 a 0.807  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.197sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 114 tr: l 0.451 a 0.904  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.079497 cl_acc 1.000 209.853sec(train) 6.432sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 114 tst: l 0.775 a 0.807  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.245sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 115 tr: l 0.446 a 0.905  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.078702 cl_acc 1.000 200.988sec(train) 5.614sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 115 tst: l 0.774 a 0.806  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.070sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 116 tr: l 0.476 a 0.895  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.077915 cl_acc 1.000 203.749sec(train) 5.904sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 116 tst: l 0.774 a 0.806  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.075sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 117 tr: l 0.431 a 0.910  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.077136 cl_acc 1.000 196.934sec(train) 5.549sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 117 tst: l 0.776 a 0.807  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.958sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 118 tr: l 0.447 a 0.905  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.076365 cl_acc 1.000 192.388sec(train) 6.691sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 118 tst: l 0.771 a 0.808  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.447sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 119 tr: l 0.436 a 0.908  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.075601 cl_acc 1.000 185.203sec(train) 6.283sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 119 tst: l 0.771 a 0.809  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.160sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 120 tr: l 0.397 a 0.922  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.074845 cl_acc 1.000 195.009sec(train) 6.421sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 120 tst: l 0.769 a 0.810  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.100sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 121 tr: l 0.420 a 0.914  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.074097 cl_acc 1.000 188.293sec(train) 5.722sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 121 tst: l 0.778 a 0.808  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.324sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 122 tr: l 0.422 a 0.911  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.073356 cl_acc 1.000 214.025sec(train) 5.961sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 122 tst: l 0.769 a 0.810  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.087sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 123 tr: l 0.440 a 0.904  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.072622 cl_acc 1.000 221.203sec(train) 5.962sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 123 tst: l 0.760 a 0.812  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.093sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 124 tr: l 0.430 a 0.909  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.071896 cl_acc 1.000 225.809sec(train) 6.176sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 124 tst: l 0.763 a 0.810  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.230sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 125 tr: l 0.429 a 0.910  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.071177 cl_acc 1.000 233.739sec(train) 6.602sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 125 tst: l 0.778 a 0.807  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.306sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 126 tr: l 0.438 a 0.905  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.070465 cl_acc 1.000 255.327sec(train) 6.546sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 126 tst: l 0.774 a 0.810  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.317sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 127 tr: l 0.424 a 0.910  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.069761 cl_acc 1.000 242.944sec(train) 5.994sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 127 tst: l 0.770 a 0.810  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.124sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 128 tr: l 0.436 a 0.906  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.069063 cl_acc 1.000 212.854sec(train) 5.818sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 128 tst: l 0.765 a 0.811  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.056sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 129 tr: l 0.427 a 0.909  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.068372 cl_acc 1.000 206.329sec(train) 6.039sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 129 tst: l 0.755 a 0.811  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.181sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 130 tr: l 0.437 a 0.906  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.067689 cl_acc 1.000 208.973sec(train) 6.002sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 130 tst: l 0.756 a 0.812  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.282sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 131 tr: l 0.400 a 0.918  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.067012 cl_acc 1.000 207.887sec(train) 5.974sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 131 tst: l 0.761 a 0.811  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.175sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 132 tr: l 0.414 a 0.912  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.066342 cl_acc 1.000 205.663sec(train) 6.557sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 132 tst: l 0.765 a 0.811  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.345sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 133 tr: l 0.419 a 0.911  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.065678 cl_acc 1.000 236.793sec(train) 6.634sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 133 tst: l 0.759 a 0.812  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.385sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 134 tr: l 0.408 a 0.915  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.065021 cl_acc 1.000 240.963sec(train) 7.030sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 134 tst: l 0.756 a 0.814  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.394sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 135 tr: l 0.426 a 0.907  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.064371 cl_acc 1.000 210.727sec(train) 5.715sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 135 tst: l 0.758 a 0.812  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.124sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 136 tr: l 0.412 a 0.913  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.063727 cl_acc 1.000 201.983sec(train) 6.031sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 136 tst: l 0.748 a 0.813  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.236sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 137 tr: l 0.405 a 0.914  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.063090 cl_acc 1.000 205.640sec(train) 6.093sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 137 tst: l 0.753 a 0.815  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.109sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 138 tr: l 0.395 a 0.918  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.062459 cl_acc 1.000 196.637sec(train) 5.889sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 138 tst: l 0.751 a 0.813  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.229sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 139 tr: l 0.389 a 0.919  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.061835 cl_acc 1.000 202.455sec(train) 5.723sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 139 tst: l 0.755 a 0.814  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.026sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 140 tr: l 0.398 a 0.916  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.061216 cl_acc 1.000 216.770sec(train) 6.939sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 140 tst: l 0.747 a 0.813  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.354sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 141 tr: l 0.384 a 0.920  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.060604 cl_acc 1.000 230.300sec(train) 6.163sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 141 tst: l 0.757 a 0.815  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.143sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 142 tr: l 0.402 a 0.913  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.059998 cl_acc 1.000 226.297sec(train) 6.908sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 142 tst: l 0.749 a 0.813  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.346sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 143 tr: l 0.384 a 0.919  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.059398 cl_acc 1.000 236.434sec(train) 6.392sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 143 tst: l 0.751 a 0.812  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.341sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 144 tr: l 0.400 a 0.916  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.058804 cl_acc 1.000 222.598sec(train) 6.286sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 144 tst: l 0.742 a 0.814  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.228sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 145 tr: l 0.382 a 0.921  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.058216 cl_acc 1.000 218.578sec(train) 6.051sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 145 tst: l 0.736 a 0.818  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.166sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 146 tr: l 0.385 a 0.919  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.057634 cl_acc 1.000 218.041sec(train) 6.078sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 146 tst: l 0.740 a 0.814  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.218sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 147 tr: l 0.383 a 0.920  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.057058 cl_acc 1.000 218.066sec(train) 6.547sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 147 tst: l 0.731 a 0.816  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.267sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 148 tr: l 0.394 a 0.916  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.056487 cl_acc 1.000 215.506sec(train) 6.453sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 148 tst: l 0.742 a 0.814  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.179sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 149 tr: l 0.354 a 0.929  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.055922 cl_acc 1.000 210.140sec(train) 6.178sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 149 tst: l 0.738 a 0.817  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.272sec\n",
      "result written at output/results.pickle\n",
      "---train cluster Ended in 8.82 hour (31750.047 sec) \n",
      "---------------------------------DFCA, lr: 0.25, seed: 409---------------------------------\n",
      "config: {'m': 50, 'm_test': 10, 'p': 2, 'n': 2000, 'local_model_init': False, 'participation_rate': 1, 'Gp': 0.25, 'graph': 'er', 'agg': 'seq', 'num_epochs': 150, 'batch_size': 50, 'tau': 10, 'lr': 0.25, 'data_seed': 409, 'train_seed': 409, 'project_dir': 'output'}\n",
      "Using device: cuda:2\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "I0000 00:00:1758492236.274906 4028755 gpu_device.cc:2019] Created device /job:localhost/replica:0/task:0/device:GPU:0 with 33884 MB memory:  -> device: 2, name: NVIDIA A100-SXM4-40GB, pci bus id: 0000:81:00.0, compute capability: 8.0\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "finding good initializer from train data\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-09-22 00:03:56.508123: 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.091  clct[np.int64(2), np.int64(48)] ans[np.int64(25), np.int64(25)] cl_acc 0.540 7.473sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-09-22 00:04:04.113340: 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.112  clct[np.int64(0), np.int64(50)] ans[np.int64(25), np.int64(25)] cl_acc 0.500 6.122sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-09-22 00:04:10.350566: 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(14), np.int64(36)] ans[np.int64(25), np.int64(25)] cl_acc 0.700 6.089sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-09-22 00:04:16.556655: 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.099  clct[np.int64(42), np.int64(8)] ans[np.int64(25), np.int64(25)] cl_acc 0.540 6.240sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-09-22 00:04:22.912444: 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.102  clct[np.int64(14), np.int64(36)] ans[np.int64(25), np.int64(25)] cl_acc 0.660 6.603sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-09-22 00:04:29.646506: 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.097  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] cl_acc 0.500 6.088sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-09-22 00:04:35.955082: 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.093  clct[np.int64(47), np.int64(3)] ans[np.int64(25), np.int64(25)] cl_acc 0.560 6.339sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-09-22 00:04:42.424669: 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.104  clct[np.int64(0), np.int64(50)] ans[np.int64(25), np.int64(25)] cl_acc 0.500 6.448sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-09-22 00:04:49.023565: 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.098  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] cl_acc 0.500 6.584sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-09-22 00:04:55.746065: 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.099  clct[np.int64(0), np.int64(50)] ans[np.int64(25), np.int64(25)] cl_acc 0.500 6.640sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-09-22 00:05:02.560567: 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.096  clct[np.int64(0), np.int64(50)] ans[np.int64(25), np.int64(25)] cl_acc 0.500 6.616sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-09-22 00:05:09.311016: 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.100  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] cl_acc 0.500 6.455sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-09-22 00:05:15.944395: 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.113  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] cl_acc 0.500 6.675sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-09-22 00:05:22.747954: 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.110  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] cl_acc 0.500 6.353sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-09-22 00:05:29.261650: 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(22), np.int64(28)] ans[np.int64(25), np.int64(25)] cl_acc 0.660 6.397sec\n",
      "found good initializer\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch -1 tr: l 4.674 a 0.097  clct[np.int64(19), np.int64(31)] ans[np.int64(25), np.int64(25)] cl_acc 0.640 6.316sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch -1 tst: l 4.674 a 0.096  clct[np.int64(4), np.int64(6)] ans[np.int64(5), np.int64(5)] cl_acc 0.700 1.346sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0 tr: l 3.223 a 0.259  clct[np.int64(19), np.int64(31)] ans[np.int64(25), np.int64(25)] lr 0.250000 cl_acc 0.640 216.139sec(train) 6.562sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0 tst: l 3.294 a 0.209  clct[np.int64(3), np.int64(7)] ans[np.int64(5), np.int64(5)] cl_acc 0.600 1.180sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1 tr: l 2.426 a 0.367  clct[np.int64(19), np.int64(31)] ans[np.int64(25), np.int64(25)] lr 0.247500 cl_acc 0.640 214.864sec(train) 5.979sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1 tst: l 2.496 a 0.327  clct[np.int64(3), np.int64(7)] ans[np.int64(5), np.int64(5)] cl_acc 0.600 1.247sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2 tr: l 1.958 a 0.450  clct[np.int64(16), np.int64(34)] ans[np.int64(25), np.int64(25)] lr 0.245025 cl_acc 0.660 215.097sec(train) 6.244sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2 tst: l 2.004 a 0.427  clct[np.int64(1), np.int64(9)] ans[np.int64(5), np.int64(5)] cl_acc 0.600 1.244sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3 tr: l 1.691 a 0.496  clct[np.int64(15), np.int64(35)] ans[np.int64(25), np.int64(25)] lr 0.242575 cl_acc 0.680 214.215sec(train) 6.679sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3 tst: l 1.749 a 0.465  clct[np.int64(1), np.int64(9)] ans[np.int64(5), np.int64(5)] cl_acc 0.600 1.158sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4 tr: l 1.527 a 0.544  clct[np.int64(13), np.int64(37)] ans[np.int64(25), np.int64(25)] lr 0.240149 cl_acc 0.720 216.358sec(train) 6.911sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4 tst: l 1.574 a 0.527  clct[np.int64(2), np.int64(8)] ans[np.int64(5), np.int64(5)] cl_acc 0.700 1.324sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5 tr: l 1.388 a 0.590  clct[np.int64(17), np.int64(33)] ans[np.int64(25), np.int64(25)] lr 0.237748 cl_acc 0.840 222.598sec(train) 5.755sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5 tst: l 1.426 a 0.564  clct[np.int64(3), np.int64(7)] ans[np.int64(5), np.int64(5)] cl_acc 0.800 1.042sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6 tr: l 1.301 a 0.621  clct[np.int64(21), np.int64(29)] ans[np.int64(25), np.int64(25)] lr 0.235370 cl_acc 0.920 209.792sec(train) 6.370sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6 tst: l 1.355 a 0.614  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.243sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7 tr: l 1.207 a 0.658  clct[np.int64(24), np.int64(26)] ans[np.int64(25), np.int64(25)] lr 0.233016 cl_acc 0.980 211.428sec(train) 6.333sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7 tst: l 1.232 a 0.644  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.189sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8 tr: l 1.092 a 0.696  clct[np.int64(24), np.int64(26)] ans[np.int64(25), np.int64(25)] lr 0.230686 cl_acc 0.980 229.177sec(train) 6.476sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8 tst: l 1.152 a 0.663  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.295sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9 tr: l 1.072 a 0.704  clct[np.int64(24), np.int64(26)] ans[np.int64(25), np.int64(25)] lr 0.228379 cl_acc 0.980 238.571sec(train) 5.955sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9 tst: l 1.132 a 0.677  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.209sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10 tr: l 1.023 a 0.725  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.226096 cl_acc 1.000 222.679sec(train) 6.239sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10 tst: l 1.128 a 0.684  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.118sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11 tr: l 0.957 a 0.749  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.223835 cl_acc 1.000 224.227sec(train) 5.991sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11 tst: l 1.086 a 0.702  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.201sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12 tr: l 0.959 a 0.749  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.221596 cl_acc 1.000 246.778sec(train) 6.992sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12 tst: l 1.079 a 0.706  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.398sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13 tr: l 0.959 a 0.753  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.219380 cl_acc 1.000 243.260sec(train) 6.724sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13 tst: l 1.070 a 0.710  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.338sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14 tr: l 0.932 a 0.759  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.217186 cl_acc 1.000 238.629sec(train) 6.058sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14 tst: l 1.053 a 0.714  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.143sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15 tr: l 0.923 a 0.765  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.215015 cl_acc 1.000 208.483sec(train) 6.068sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15 tst: l 1.063 a 0.718  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.244sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16 tr: l 0.889 a 0.777  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.212864 cl_acc 1.000 199.921sec(train) 5.467sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16 tst: l 1.051 a 0.722  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.141sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17 tr: l 0.873 a 0.785  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.210736 cl_acc 1.000 201.144sec(train) 5.796sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17 tst: l 1.056 a 0.724  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.154sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18 tr: l 0.870 a 0.787  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.208628 cl_acc 1.000 197.269sec(train) 5.634sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18 tst: l 1.046 a 0.728  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.033sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19 tr: l 0.886 a 0.783  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.206542 cl_acc 1.000 190.916sec(train) 5.579sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19 tst: l 1.064 a 0.725  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.151sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20 tr: l 0.877 a 0.785  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.204477 cl_acc 1.000 234.211sec(train) 6.935sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20 tst: l 1.022 a 0.732  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.361sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21 tr: l 0.823 a 0.806  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.202432 cl_acc 1.000 237.403sec(train) 7.365sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21 tst: l 1.019 a 0.738  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.438sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22 tr: l 0.882 a 0.787  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.200408 cl_acc 1.000 216.480sec(train) 6.255sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22 tst: l 1.008 a 0.742  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.224sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23 tr: l 0.839 a 0.800  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.198404 cl_acc 1.000 211.895sec(train) 8.220sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23 tst: l 1.027 a 0.737  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.644sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24 tr: l 0.812 a 0.811  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.196420 cl_acc 1.000 206.147sec(train) 6.604sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24 tst: l 1.009 a 0.742  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.367sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25 tr: l 0.779 a 0.823  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.194455 cl_acc 1.000 223.721sec(train) 6.859sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25 tst: l 1.031 a 0.741  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.271sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 26 tr: l 0.796 a 0.813  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.192511 cl_acc 1.000 222.026sec(train) 6.619sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 26 tst: l 1.005 a 0.742  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.362sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 27 tr: l 0.777 a 0.823  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.190586 cl_acc 1.000 228.146sec(train) 6.452sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 27 tst: l 1.037 a 0.740  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.330sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 28 tr: l 0.800 a 0.812  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.188680 cl_acc 1.000 221.714sec(train) 6.784sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 28 tst: l 0.980 a 0.750  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.300sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 29 tr: l 0.805 a 0.808  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.186793 cl_acc 1.000 218.743sec(train) 6.252sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 29 tst: l 0.974 a 0.754  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.193sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 30 tr: l 0.787 a 0.816  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.184925 cl_acc 1.000 220.625sec(train) 6.504sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 30 tst: l 0.974 a 0.753  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.282sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 31 tr: l 0.765 a 0.824  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.183076 cl_acc 1.000 216.014sec(train) 6.541sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 31 tst: l 0.987 a 0.754  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.176sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 32 tr: l 0.743 a 0.832  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.181245 cl_acc 1.000 213.165sec(train) 6.234sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 32 tst: l 0.976 a 0.752  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.186sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 33 tr: l 0.758 a 0.826  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.179433 cl_acc 1.000 212.144sec(train) 6.247sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 33 tst: l 0.976 a 0.756  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.411sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 34 tr: l 0.740 a 0.832  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.177638 cl_acc 1.000 206.564sec(train) 6.439sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 34 tst: l 0.964 a 0.760  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.318sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 35 tr: l 0.755 a 0.827  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.175862 cl_acc 1.000 210.722sec(train) 6.124sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 35 tst: l 0.973 a 0.758  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.305sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 36 tr: l 0.725 a 0.835  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.174103 cl_acc 1.000 207.668sec(train) 6.416sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 36 tst: l 0.968 a 0.758  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.196sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 37 tr: l 0.723 a 0.837  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.172362 cl_acc 1.000 209.422sec(train) 5.763sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 37 tst: l 0.969 a 0.762  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.284sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 38 tr: l 0.702 a 0.845  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.170639 cl_acc 1.000 221.378sec(train) 6.174sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 38 tst: l 0.971 a 0.761  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.333sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 39 tr: l 0.702 a 0.843  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.168932 cl_acc 1.000 234.624sec(train) 6.389sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 39 tst: l 0.974 a 0.757  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.114sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 40 tr: l 0.705 a 0.842  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.167243 cl_acc 1.000 203.998sec(train) 6.279sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 40 tst: l 0.986 a 0.757  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] 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.715 a 0.837  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.165571 cl_acc 1.000 246.203sec(train) 6.639sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 41 tst: l 0.948 a 0.765  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.293sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 42 tr: l 0.682 a 0.850  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.163915 cl_acc 1.000 254.624sec(train) 6.539sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 42 tst: l 0.952 a 0.764  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.293sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 43 tr: l 0.692 a 0.847  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.162276 cl_acc 1.000 260.435sec(train) 7.018sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 43 tst: l 0.977 a 0.760  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.346sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 44 tr: l 0.696 a 0.842  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.160653 cl_acc 1.000 256.032sec(train) 6.114sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 44 tst: l 0.970 a 0.763  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.357sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 45 tr: l 0.679 a 0.848  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.159046 cl_acc 1.000 259.308sec(train) 6.915sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 45 tst: l 0.926 a 0.769  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.404sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 46 tr: l 0.661 a 0.853  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.157456 cl_acc 1.000 239.257sec(train) 6.284sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 46 tst: l 0.935 a 0.770  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.235sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 47 tr: l 0.640 a 0.863  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.155881 cl_acc 1.000 217.495sec(train) 5.850sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 47 tst: l 0.928 a 0.771  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.163sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 48 tr: l 0.663 a 0.854  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.154323 cl_acc 1.000 217.784sec(train) 6.307sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 48 tst: l 0.933 a 0.773  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 49 tr: l 0.678 a 0.848  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.152779 cl_acc 1.000 214.904sec(train) 6.082sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 49 tst: l 0.948 a 0.769  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.196sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 50 tr: l 0.650 a 0.856  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.151252 cl_acc 1.000 207.599sec(train) 6.928sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 50 tst: l 0.928 a 0.771  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.309sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 51 tr: l 0.650 a 0.857  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.149739 cl_acc 1.000 246.863sec(train) 7.425sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 51 tst: l 0.937 a 0.770  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.476sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 52 tr: l 0.653 a 0.854  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.148242 cl_acc 1.000 245.300sec(train) 7.163sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 52 tst: l 0.926 a 0.772  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.468sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 53 tr: l 0.627 a 0.864  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.146759 cl_acc 1.000 221.346sec(train) 6.633sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 53 tst: l 0.914 a 0.776  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.369sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 54 tr: l 0.629 a 0.864  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.145292 cl_acc 1.000 196.807sec(train) 6.217sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 54 tst: l 0.924 a 0.774  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.219sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 55 tr: l 0.639 a 0.860  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.143839 cl_acc 1.000 203.497sec(train) 6.571sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 55 tst: l 0.919 a 0.773  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.305sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 56 tr: l 0.644 a 0.859  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.142400 cl_acc 1.000 203.959sec(train) 6.914sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 56 tst: l 0.921 a 0.774  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.254sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 57 tr: l 0.626 a 0.864  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.140976 cl_acc 1.000 204.800sec(train) 6.626sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 57 tst: l 0.920 a 0.774  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.452sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 58 tr: l 0.590 a 0.875  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.139567 cl_acc 1.000 240.114sec(train) 6.677sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 58 tst: l 0.913 a 0.775  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.334sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 59 tr: l 0.635 a 0.859  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.138171 cl_acc 1.000 220.577sec(train) 5.974sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 59 tst: l 0.903 a 0.777  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.188sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 60 tr: l 0.612 a 0.868  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.136789 cl_acc 1.000 200.891sec(train) 5.557sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 60 tst: l 0.932 a 0.770  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.061sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 61 tr: l 0.601 a 0.871  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.135421 cl_acc 1.000 192.309sec(train) 5.873sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 61 tst: l 0.916 a 0.778  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.150sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 62 tr: l 0.617 a 0.864  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.134067 cl_acc 1.000 194.445sec(train) 7.070sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 62 tst: l 0.892 a 0.782  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.335sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 63 tr: l 0.574 a 0.880  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.132726 cl_acc 1.000 230.092sec(train) 6.696sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 63 tst: l 0.893 a 0.782  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.410sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 64 tr: l 0.596 a 0.870  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.131399 cl_acc 1.000 235.687sec(train) 6.139sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 64 tst: l 0.900 a 0.779  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.234sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 65 tr: l 0.602 a 0.869  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.130085 cl_acc 1.000 195.492sec(train) 6.142sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 65 tst: l 0.892 a 0.780  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.195sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 66 tr: l 0.585 a 0.874  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.128784 cl_acc 1.000 188.440sec(train) 6.139sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 66 tst: l 0.896 a 0.780  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.218sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 67 tr: l 0.557 a 0.883  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.127496 cl_acc 1.000 186.229sec(train) 5.708sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 67 tst: l 0.911 a 0.780  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 68 tr: l 0.586 a 0.872  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.126221 cl_acc 1.000 187.286sec(train) 5.979sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 68 tst: l 0.904 a 0.780  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.192sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 69 tr: l 0.596 a 0.868  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.124959 cl_acc 1.000 183.496sec(train) 5.631sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 69 tst: l 0.888 a 0.782  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.040sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 70 tr: l 0.580 a 0.873  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.123710 cl_acc 1.000 212.974sec(train) 6.760sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 70 tst: l 0.889 a 0.783  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.299sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 71 tr: l 0.586 a 0.871  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.122473 cl_acc 1.000 227.436sec(train) 6.915sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 71 tst: l 0.893 a 0.784  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.202sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 72 tr: l 0.545 a 0.887  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.121248 cl_acc 1.000 219.730sec(train) 6.048sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 72 tst: l 0.867 a 0.788  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.194sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 73 tr: l 0.551 a 0.885  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.120035 cl_acc 1.000 178.674sec(train) 5.699sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 73 tst: l 0.882 a 0.783  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.131sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 74 tr: l 0.564 a 0.877  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.118835 cl_acc 1.000 177.804sec(train) 5.567sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 74 tst: l 0.871 a 0.787  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.092sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 75 tr: l 0.541 a 0.886  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.117647 cl_acc 1.000 174.439sec(train) 5.013sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 75 tst: l 0.874 a 0.789  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.969sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 76 tr: l 0.570 a 0.876  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.116470 cl_acc 1.000 169.975sec(train) 5.881sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 76 tst: l 0.861 a 0.789  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.086sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 77 tr: l 0.543 a 0.885  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.115305 cl_acc 1.000 170.123sec(train) 5.117sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 77 tst: l 0.864 a 0.788  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.992sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 78 tr: l 0.540 a 0.887  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.114152 cl_acc 1.000 168.440sec(train) 5.066sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 78 tst: l 0.885 a 0.785  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.016sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 79 tr: l 0.557 a 0.880  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.113011 cl_acc 1.000 212.358sec(train) 6.808sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 79 tst: l 0.856 a 0.791  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.396sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 80 tr: l 0.538 a 0.885  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.111881 cl_acc 1.000 221.771sec(train) 6.088sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 80 tst: l 0.870 a 0.788  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.159sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 81 tr: l 0.551 a 0.881  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.110762 cl_acc 1.000 192.889sec(train) 5.024sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 81 tst: l 0.871 a 0.791  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.149sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 82 tr: l 0.529 a 0.888  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.109654 cl_acc 1.000 165.450sec(train) 5.112sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 82 tst: l 0.863 a 0.790  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.931sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 83 tr: l 0.527 a 0.889  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.108558 cl_acc 1.000 163.492sec(train) 4.904sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 83 tst: l 0.862 a 0.789  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.128sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 84 tr: l 0.556 a 0.878  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.107472 cl_acc 1.000 164.308sec(train) 5.379sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 84 tst: l 0.864 a 0.790  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.154sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 85 tr: l 0.538 a 0.884  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.106398 cl_acc 1.000 162.961sec(train) 5.030sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 85 tst: l 0.878 a 0.789  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.974sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 86 tr: l 0.537 a 0.883  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.105334 cl_acc 1.000 168.502sec(train) 5.054sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 86 tst: l 0.846 a 0.791  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.004sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 87 tr: l 0.528 a 0.885  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.104280 cl_acc 1.000 199.009sec(train) 5.961sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 87 tst: l 0.854 a 0.790  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.277sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 88 tr: l 0.506 a 0.894  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.103237 cl_acc 1.000 210.629sec(train) 6.437sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 88 tst: l 0.839 a 0.796  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.307sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 89 tr: l 0.518 a 0.890  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.102205 cl_acc 1.000 209.423sec(train) 4.973sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 89 tst: l 0.846 a 0.794  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.004sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 90 tr: l 0.521 a 0.887  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.101183 cl_acc 1.000 153.242sec(train) 4.883sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 90 tst: l 0.830 a 0.798  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.984sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 91 tr: l 0.501 a 0.893  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.100171 cl_acc 1.000 154.766sec(train) 5.023sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 91 tst: l 0.836 a 0.796  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.010sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 92 tr: l 0.539 a 0.880  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.099169 cl_acc 1.000 152.517sec(train) 5.030sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 92 tst: l 0.819 a 0.801  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.191sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 93 tr: l 0.504 a 0.894  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.098178 cl_acc 1.000 153.525sec(train) 5.279sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 93 tst: l 0.863 a 0.791  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.141sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 94 tr: l 0.483 a 0.900  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.097196 cl_acc 1.000 152.077sec(train) 5.421sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 94 tst: l 0.830 a 0.796  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.150sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 95 tr: l 0.497 a 0.893  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.096224 cl_acc 1.000 153.729sec(train) 5.279sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 95 tst: l 0.830 a 0.797  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.927sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 96 tr: l 0.517 a 0.887  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.095262 cl_acc 1.000 233.285sec(train) 6.922sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 96 tst: l 0.833 a 0.796  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.353sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 97 tr: l 0.517 a 0.887  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.094309 cl_acc 1.000 249.186sec(train) 6.197sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 97 tst: l 0.848 a 0.797  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.225sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 98 tr: l 0.485 a 0.897  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.093366 cl_acc 1.000 179.507sec(train) 5.115sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 98 tst: l 0.840 a 0.797  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.992sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 99 tr: l 0.495 a 0.894  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.092432 cl_acc 1.000 163.427sec(train) 5.002sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 99 tst: l 0.841 a 0.797  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.982sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 100 tr: l 0.497 a 0.893  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.091508 cl_acc 1.000 155.907sec(train) 4.894sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 100 tst: l 0.814 a 0.802  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.950sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 101 tr: l 0.514 a 0.887  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.090593 cl_acc 1.000 150.294sec(train) 4.934sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 101 tst: l 0.820 a 0.800  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.970sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 102 tr: l 0.474 a 0.900  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.089687 cl_acc 1.000 151.000sec(train) 4.917sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 102 tst: l 0.826 a 0.798  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.972sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 103 tr: l 0.497 a 0.892  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.088790 cl_acc 1.000 149.661sec(train) 4.457sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 103 tst: l 0.816 a 0.802  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.885sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 104 tr: l 0.502 a 0.890  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.087902 cl_acc 1.000 151.120sec(train) 4.792sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 104 tst: l 0.814 a 0.804  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.042sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 105 tr: l 0.508 a 0.889  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.087023 cl_acc 1.000 212.552sec(train) 5.993sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 105 tst: l 0.820 a 0.800  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.164sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 106 tr: l 0.492 a 0.892  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.086153 cl_acc 1.000 248.157sec(train) 6.965sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 106 tst: l 0.815 a 0.803  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.200sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 107 tr: l 0.487 a 0.895  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.085292 cl_acc 1.000 170.772sec(train) 4.632sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 107 tst: l 0.819 a 0.802  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.837sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 108 tr: l 0.463 a 0.903  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.084439 cl_acc 1.000 150.473sec(train) 4.970sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 108 tst: l 0.815 a 0.802  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.983sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 109 tr: l 0.481 a 0.896  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.083594 cl_acc 1.000 150.399sec(train) 4.737sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 109 tst: l 0.800 a 0.803  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.932sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 110 tr: l 0.473 a 0.899  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.082758 cl_acc 1.000 147.665sec(train) 4.551sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 110 tst: l 0.800 a 0.805  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.922sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 111 tr: l 0.463 a 0.903  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.081931 cl_acc 1.000 148.234sec(train) 4.862sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 111 tst: l 0.808 a 0.803  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.887sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 112 tr: l 0.458 a 0.903  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.081111 cl_acc 1.000 149.914sec(train) 4.833sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 112 tst: l 0.822 a 0.798  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.941sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 113 tr: l 0.453 a 0.905  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.080300 cl_acc 1.000 203.232sec(train) 7.880sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 113 tst: l 0.803 a 0.803  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.413sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 114 tr: l 0.462 a 0.903  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.079497 cl_acc 1.000 236.455sec(train) 5.926sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 114 tst: l 0.824 a 0.800  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.254sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 115 tr: l 0.484 a 0.893  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.078702 cl_acc 1.000 188.133sec(train) 4.889sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 115 tst: l 0.801 a 0.805  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.966sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 116 tr: l 0.479 a 0.896  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.077915 cl_acc 1.000 158.562sec(train) 5.577sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 116 tst: l 0.808 a 0.803  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.116sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 117 tr: l 0.443 a 0.906  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.077136 cl_acc 1.000 160.904sec(train) 5.165sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 117 tst: l 0.836 a 0.798  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.062sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 118 tr: l 0.455 a 0.902  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.076365 cl_acc 1.000 156.724sec(train) 5.069sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 118 tst: l 0.791 a 0.808  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.973sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 119 tr: l 0.456 a 0.901  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.075601 cl_acc 1.000 165.701sec(train) 5.088sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 119 tst: l 0.815 a 0.803  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.956sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 120 tr: l 0.460 a 0.900  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.074845 cl_acc 1.000 152.790sec(train) 4.925sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 120 tst: l 0.795 a 0.807  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.067sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 121 tr: l 0.437 a 0.908  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.074097 cl_acc 1.000 189.498sec(train) 6.746sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 121 tst: l 0.812 a 0.803  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.356sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 122 tr: l 0.463 a 0.898  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.073356 cl_acc 1.000 236.875sec(train) 6.949sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 122 tst: l 0.797 a 0.806  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.268sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 123 tr: l 0.440 a 0.907  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.072622 cl_acc 1.000 206.574sec(train) 4.955sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 123 tst: l 0.785 a 0.808  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.958sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 124 tr: l 0.430 a 0.908  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.071896 cl_acc 1.000 159.399sec(train) 4.899sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 124 tst: l 0.798 a 0.807  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.962sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 125 tr: l 0.439 a 0.906  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.071177 cl_acc 1.000 151.382sec(train) 5.137sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 125 tst: l 0.807 a 0.804  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.981sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 126 tr: l 0.448 a 0.904  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.070465 cl_acc 1.000 150.593sec(train) 4.871sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 126 tst: l 0.802 a 0.805  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.947sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 127 tr: l 0.425 a 0.911  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.069761 cl_acc 1.000 150.216sec(train) 5.601sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 127 tst: l 0.785 a 0.809  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.120sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 128 tr: l 0.437 a 0.907  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.069063 cl_acc 1.000 148.335sec(train) 4.598sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 128 tst: l 0.802 a 0.808  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.903sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 129 tr: l 0.424 a 0.911  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.068372 cl_acc 1.000 165.060sec(train) 6.784sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 129 tst: l 0.784 a 0.810  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.438sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 130 tr: l 0.455 a 0.899  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.067689 cl_acc 1.000 235.093sec(train) 6.608sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 130 tst: l 0.783 a 0.807  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.301sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 131 tr: l 0.431 a 0.907  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.067012 cl_acc 1.000 239.192sec(train) 4.888sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 131 tst: l 0.801 a 0.804  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.931sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 132 tr: l 0.420 a 0.911  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.066342 cl_acc 1.000 167.256sec(train) 4.898sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 132 tst: l 0.801 a 0.806  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.975sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 133 tr: l 0.422 a 0.909  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.065678 cl_acc 1.000 150.855sec(train) 5.183sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 133 tst: l 0.781 a 0.809  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.079sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 134 tr: l 0.409 a 0.915  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.065021 cl_acc 1.000 150.509sec(train) 5.051sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 134 tst: l 0.787 a 0.809  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.918sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 135 tr: l 0.412 a 0.913  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.064371 cl_acc 1.000 148.708sec(train) 5.001sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 135 tst: l 0.775 a 0.811  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.949sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 136 tr: l 0.402 a 0.916  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.063727 cl_acc 1.000 147.810sec(train) 4.759sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 136 tst: l 0.781 a 0.808  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.957sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 137 tr: l 0.425 a 0.908  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.063090 cl_acc 1.000 153.899sec(train) 6.235sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 137 tst: l 0.781 a 0.809  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.208sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 138 tr: l 0.414 a 0.912  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.062459 cl_acc 1.000 230.187sec(train) 6.230sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 138 tst: l 0.771 a 0.809  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.248sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 139 tr: l 0.404 a 0.915  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.061835 cl_acc 1.000 242.482sec(train) 6.751sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 139 tst: l 0.785 a 0.808  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.390sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 140 tr: l 0.385 a 0.919  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.061216 cl_acc 1.000 176.853sec(train) 5.058sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 140 tst: l 0.776 a 0.808  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.044sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 141 tr: l 0.413 a 0.911  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.060604 cl_acc 1.000 158.327sec(train) 5.362sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 141 tst: l 0.771 a 0.810  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.026sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 142 tr: l 0.421 a 0.907  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.059998 cl_acc 1.000 170.305sec(train) 4.733sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 142 tst: l 0.769 a 0.810  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.911sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 143 tr: l 0.409 a 0.911  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.059398 cl_acc 1.000 159.288sec(train) 4.937sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 143 tst: l 0.769 a 0.813  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.954sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 144 tr: l 0.394 a 0.917  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.058804 cl_acc 1.000 148.953sec(train) 4.478sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 144 tst: l 0.766 a 0.813  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.866sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 145 tr: l 0.399 a 0.915  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.058216 cl_acc 1.000 155.037sec(train) 4.731sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 145 tst: l 0.779 a 0.811  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.923sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 146 tr: l 0.385 a 0.919  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.057634 cl_acc 1.000 216.401sec(train) 6.995sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 146 tst: l 0.762 a 0.814  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.263sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 147 tr: l 0.418 a 0.908  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.057058 cl_acc 1.000 225.508sec(train) 5.725sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 147 tst: l 0.757 a 0.816  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.166sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 148 tr: l 0.387 a 0.917  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.056487 cl_acc 1.000 181.377sec(train) 5.111sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 148 tst: l 0.769 a 0.814  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.078sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 149 tr: l 0.396 a 0.915  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.055922 cl_acc 1.000 156.536sec(train) 5.094sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 149 tst: l 0.768 a 0.813  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.942sec\n",
      "result written at output/results.pickle\n",
      "---train cluster Ended in 8.53 hour (30706.925 sec) \n",
      "---------------------------------DFCA, lr: 0.25, seed: 4506---------------------------------\n",
      "config: {'m': 50, 'm_test': 10, 'p': 2, 'n': 2000, 'local_model_init': False, 'participation_rate': 1, 'Gp': 0.25, 'graph': 'er', 'agg': 'seq', 'num_epochs': 150, 'batch_size': 50, 'tau': 10, 'lr': 0.25, 'data_seed': 4506, 'train_seed': 4506, 'project_dir': 'output'}\n",
      "Using device: cuda:2\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "I0000 00:00:1758522942.560055 4028755 gpu_device.cc:2019] Created device /job:localhost/replica:0/task:0/device:GPU:0 with 33884 MB memory:  -> device: 2, name: NVIDIA A100-SXM4-40GB, pci bus id: 0000:81:00.0, compute capability: 8.0\n",
      "2025-09-22 08:35:42.669663: 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.672 a 0.097  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] cl_acc 0.500 6.246sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-09-22 08:35:49.000221: 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.085  clct[np.int64(43), np.int64(7)] ans[np.int64(25), np.int64(25)] cl_acc 0.640 5.270sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-09-22 08:35:54.374255: 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.117  clct[np.int64(0), np.int64(50)] ans[np.int64(25), np.int64(25)] cl_acc 0.500 5.423sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-09-22 08:35:59.891169: 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.100  clct[np.int64(4), np.int64(46)] ans[np.int64(25), np.int64(25)] cl_acc 0.500 5.387sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-09-22 08:36:05.383089: 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.679 a 0.098  clct[np.int64(14), np.int64(36)] ans[np.int64(25), np.int64(25)] cl_acc 0.740 5.212sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-09-22 08:36:10.701627: 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.094  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] cl_acc 0.500 5.617sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-09-22 08:36:16.429322: 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.105  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] cl_acc 0.500 5.639sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-09-22 08:36:22.170732: 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(50), np.int64(0)] ans[np.int64(25), np.int64(25)] cl_acc 0.500 5.397sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-09-22 08:36:27.657394: 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.680 a 0.104  clct[np.int64(14), np.int64(36)] ans[np.int64(25), np.int64(25)] cl_acc 0.780 6.225sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-09-22 08:36:33.978192: 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(0), np.int64(50)] ans[np.int64(25), np.int64(25)] cl_acc 0.500 5.678sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-09-22 08:36:39.746468: 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(50), np.int64(0)] ans[np.int64(25), np.int64(25)] cl_acc 0.500 5.501sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-09-22 08:36:45.350128: 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.097  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] cl_acc 0.500 5.836sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-09-22 08:36:51.281338: 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(43), np.int64(7)] ans[np.int64(25), np.int64(25)] cl_acc 0.520 5.496sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-09-22 08:36:56.886187: 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.091  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] cl_acc 0.500 6.159sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-09-22 08:37:03.195865: 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.108  clct[np.int64(0), np.int64(50)] ans[np.int64(25), np.int64(25)] cl_acc 0.500 5.638sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-09-22 08:37:08.949580: 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.095  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] cl_acc 0.500 5.377sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-09-22 08:37:14.425295: 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.071  clct[np.int64(0), np.int64(50)] ans[np.int64(25), np.int64(25)] cl_acc 0.500 5.372sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-09-22 08:37:19.900224: 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.105  clct[np.int64(22), np.int64(28)] ans[np.int64(25), np.int64(25)] cl_acc 0.700 5.370sec\n",
      "found good initializer\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch -1 tr: l 4.670 a 0.107  clct[np.int64(22), np.int64(28)] ans[np.int64(25), np.int64(25)] cl_acc 0.660 5.370sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch -1 tst: l 4.670 a 0.106  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 0.800 1.091sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0 tr: l 3.254 a 0.250  clct[np.int64(22), np.int64(28)] ans[np.int64(25), np.int64(25)] lr 0.250000 cl_acc 0.660 171.499sec(train) 4.952sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0 tst: l 3.255 a 0.252  clct[np.int64(4), np.int64(6)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.970sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1 tr: l 2.410 a 0.370  clct[np.int64(22), np.int64(28)] ans[np.int64(25), np.int64(25)] lr 0.247500 cl_acc 0.660 164.053sec(train) 5.147sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1 tst: l 2.401 a 0.368  clct[np.int64(4), np.int64(6)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 1.018sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2 tr: l 1.896 a 0.473  clct[np.int64(19), np.int64(31)] ans[np.int64(25), np.int64(25)] lr 0.245025 cl_acc 0.720 162.033sec(train) 5.544sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2 tst: l 1.912 a 0.495  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.048sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3 tr: l 1.643 a 0.514  clct[np.int64(17), np.int64(33)] ans[np.int64(25), np.int64(25)] lr 0.242575 cl_acc 0.760 187.638sec(train) 6.009sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3 tst: l 1.584 a 0.545  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.205sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4 tr: l 1.433 a 0.577  clct[np.int64(19), np.int64(31)] ans[np.int64(25), np.int64(25)] lr 0.240149 cl_acc 0.840 228.743sec(train) 6.416sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4 tst: l 1.387 a 0.597  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.296sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5 tr: l 1.279 a 0.629  clct[np.int64(21), np.int64(29)] ans[np.int64(25), np.int64(25)] lr 0.237748 cl_acc 0.920 218.678sec(train) 4.892sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5 tst: l 1.270 a 0.633  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.106sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6 tr: l 1.188 a 0.659  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.235370 cl_acc 1.000 156.366sec(train) 4.850sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6 tst: l 1.188 a 0.656  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.935sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7 tr: l 1.145 a 0.670  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.233016 cl_acc 1.000 159.269sec(train) 4.701sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7 tst: l 1.124 a 0.675  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.911sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8 tr: l 1.053 a 0.705  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.230686 cl_acc 1.000 162.501sec(train) 4.623sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8 tst: l 1.097 a 0.687  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.927sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9 tr: l 1.005 a 0.728  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.228379 cl_acc 1.000 155.168sec(train) 6.234sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9 tst: l 1.067 a 0.702  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.141sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10 tr: l 0.961 a 0.745  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.226096 cl_acc 1.000 148.844sec(train) 4.801sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10 tst: l 1.054 a 0.705  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.943sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11 tr: l 0.973 a 0.741  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.223835 cl_acc 1.000 150.673sec(train) 4.917sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11 tst: l 1.040 a 0.712  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.955sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12 tr: l 0.943 a 0.754  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.221596 cl_acc 1.000 153.973sec(train) 5.141sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12 tst: l 1.030 a 0.718  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.006sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13 tr: l 0.915 a 0.767  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.219380 cl_acc 1.000 226.854sec(train) 7.738sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13 tst: l 1.023 a 0.724  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.654sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14 tr: l 0.874 a 0.783  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.217186 cl_acc 1.000 242.054sec(train) 5.949sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14 tst: l 1.021 a 0.723  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.202sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15 tr: l 0.909 a 0.769  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.215015 cl_acc 1.000 170.690sec(train) 4.897sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15 tst: l 1.015 a 0.729  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.951sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16 tr: l 0.870 a 0.786  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.212864 cl_acc 1.000 152.539sec(train) 5.369sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16 tst: l 1.007 a 0.729  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.034sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17 tr: l 0.846 a 0.796  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.210736 cl_acc 1.000 153.805sec(train) 5.076sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17 tst: l 1.004 a 0.734  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.995sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18 tr: l 0.854 a 0.792  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.208628 cl_acc 1.000 153.541sec(train) 5.139sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18 tst: l 1.005 a 0.732  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.083sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19 tr: l 0.848 a 0.795  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.206542 cl_acc 1.000 159.500sec(train) 5.186sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19 tst: l 0.985 a 0.741  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.997sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20 tr: l 0.824 a 0.804  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.204477 cl_acc 1.000 148.303sec(train) 4.999sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20 tst: l 0.985 a 0.744  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.986sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21 tr: l 0.844 a 0.795  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.202432 cl_acc 1.000 152.456sec(train) 5.864sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21 tst: l 0.977 a 0.746  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.230sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22 tr: l 0.820 a 0.804  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.200408 cl_acc 1.000 220.543sec(train) 5.882sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22 tst: l 0.981 a 0.744  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.133sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23 tr: l 0.796 a 0.813  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.198404 cl_acc 1.000 244.258sec(train) 6.390sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23 tst: l 0.970 a 0.749  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.209sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24 tr: l 0.796 a 0.812  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.196420 cl_acc 1.000 163.095sec(train) 5.141sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24 tst: l 0.968 a 0.749  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.951sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25 tr: l 0.772 a 0.824  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.194455 cl_acc 1.000 155.001sec(train) 4.898sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25 tst: l 0.961 a 0.752  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.951sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 26 tr: l 0.807 a 0.809  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.192511 cl_acc 1.000 152.657sec(train) 4.826sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 26 tst: l 0.958 a 0.755  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.954sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 27 tr: l 0.783 a 0.816  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.190586 cl_acc 1.000 148.679sec(train) 4.393sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 27 tst: l 0.949 a 0.756  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.880sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 28 tr: l 0.747 a 0.829  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.188680 cl_acc 1.000 162.739sec(train) 4.612sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 28 tst: l 0.943 a 0.760  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.913sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 29 tr: l 0.746 a 0.827  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.186793 cl_acc 1.000 151.551sec(train) 4.902sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 29 tst: l 0.942 a 0.760  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.935sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 30 tr: l 0.760 a 0.824  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.184925 cl_acc 1.000 197.280sec(train) 5.732sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 30 tst: l 0.935 a 0.760  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.130sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 31 tr: l 0.745 a 0.831  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.183076 cl_acc 1.000 233.826sec(train) 10.709sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 31 tst: l 0.937 a 0.759  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.808sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 32 tr: l 0.749 a 0.829  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.181245 cl_acc 1.000 183.637sec(train) 5.584sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 32 tst: l 0.936 a 0.762  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.167sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 33 tr: l 0.735 a 0.832  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.179433 cl_acc 1.000 149.427sec(train) 5.590sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 33 tst: l 0.936 a 0.763  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.943sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 34 tr: l 0.756 a 0.824  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.177638 cl_acc 1.000 147.594sec(train) 4.800sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 34 tst: l 0.931 a 0.763  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.971sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 35 tr: l 0.710 a 0.841  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.175862 cl_acc 1.000 146.215sec(train) 4.795sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 35 tst: l 0.923 a 0.764  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.990sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 36 tr: l 0.731 a 0.832  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.174103 cl_acc 1.000 153.639sec(train) 4.684sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 36 tst: l 0.919 a 0.766  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.913sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 37 tr: l 0.686 a 0.847  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.172362 cl_acc 1.000 148.704sec(train) 4.675sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 37 tst: l 0.923 a 0.764  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.909sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 38 tr: l 0.695 a 0.844  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.170639 cl_acc 1.000 147.803sec(train) 5.161sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 38 tst: l 0.915 a 0.765  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.945sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 39 tr: l 0.701 a 0.842  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.168932 cl_acc 1.000 223.961sec(train) 5.613sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 39 tst: l 0.911 a 0.770  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.132sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 40 tr: l 0.709 a 0.837  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.167243 cl_acc 1.000 234.790sec(train) 6.189sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 40 tst: l 0.904 a 0.771  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.150sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 41 tr: l 0.679 a 0.849  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.165571 cl_acc 1.000 173.915sec(train) 4.744sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 41 tst: l 0.893 a 0.773  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.924sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 42 tr: l 0.700 a 0.842  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.163915 cl_acc 1.000 161.129sec(train) 5.110sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 42 tst: l 0.896 a 0.777  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.006sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 43 tr: l 0.669 a 0.853  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.162276 cl_acc 1.000 164.812sec(train) 4.728sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 43 tst: l 0.901 a 0.774  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.920sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 44 tr: l 0.675 a 0.851  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.160653 cl_acc 1.000 148.196sec(train) 5.479sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 44 tst: l 0.892 a 0.775  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.990sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 45 tr: l 0.664 a 0.853  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.159046 cl_acc 1.000 148.766sec(train) 4.953sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 45 tst: l 0.890 a 0.779  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.916sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 46 tr: l 0.634 a 0.863  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.157456 cl_acc 1.000 147.530sec(train) 5.020sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 46 tst: l 0.891 a 0.776  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.973sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 47 tr: l 0.681 a 0.848  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.155881 cl_acc 1.000 191.128sec(train) 6.083sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 47 tst: l 0.893 a 0.775  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.222sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 48 tr: l 0.650 a 0.857  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.154323 cl_acc 1.000 246.496sec(train) 6.218sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 48 tst: l 0.886 a 0.777  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.243sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 49 tr: l 0.644 a 0.859  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.152779 cl_acc 1.000 182.585sec(train) 5.375sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 49 tst: l 0.885 a 0.777  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.018sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 50 tr: l 0.662 a 0.849  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.151252 cl_acc 1.000 177.493sec(train) 5.251sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 50 tst: l 0.883 a 0.777  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.111sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 51 tr: l 0.663 a 0.851  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.149739 cl_acc 1.000 156.784sec(train) 5.409sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 51 tst: l 0.871 a 0.780  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.079sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 52 tr: l 0.651 a 0.856  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.148242 cl_acc 1.000 175.156sec(train) 5.162sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 52 tst: l 0.877 a 0.780  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.021sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 53 tr: l 0.637 a 0.859  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.146759 cl_acc 1.000 162.180sec(train) 5.193sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 53 tst: l 0.880 a 0.781  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.934sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 54 tr: l 0.629 a 0.862  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.145292 cl_acc 1.000 205.766sec(train) 5.214sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 54 tst: l 0.866 a 0.786  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.000sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 55 tr: l 0.630 a 0.862  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.143839 cl_acc 1.000 288.707sec(train) 6.926sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 55 tst: l 0.863 a 0.785  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.492sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 56 tr: l 0.626 a 0.863  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.142400 cl_acc 1.000 272.624sec(train) 5.276sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 56 tst: l 0.869 a 0.782  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.036sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 57 tr: l 0.592 a 0.873  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.140976 cl_acc 1.000 221.863sec(train) 5.356sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 57 tst: l 0.865 a 0.785  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.090sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 58 tr: l 0.609 a 0.868  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.139567 cl_acc 1.000 227.435sec(train) 5.605sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 58 tst: l 0.863 a 0.784  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.026sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 59 tr: l 0.598 a 0.871  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.138171 cl_acc 1.000 222.505sec(train) 5.408sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 59 tst: l 0.860 a 0.784  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.016sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 60 tr: l 0.627 a 0.859  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.136789 cl_acc 1.000 219.946sec(train) 5.605sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 60 tst: l 0.861 a 0.785  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.998sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 61 tr: l 0.618 a 0.865  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.135421 cl_acc 1.000 302.184sec(train) 6.889sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 61 tst: l 0.853 a 0.785  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.238sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 62 tr: l 0.620 a 0.862  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.134067 cl_acc 1.000 278.864sec(train) 5.719sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 62 tst: l 0.849 a 0.788  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.075sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 63 tr: l 0.618 a 0.862  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.132726 cl_acc 1.000 236.980sec(train) 6.235sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 63 tst: l 0.854 a 0.786  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.173sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 64 tr: l 0.600 a 0.869  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.131399 cl_acc 1.000 225.678sec(train) 6.949sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 64 tst: l 0.850 a 0.789  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.026sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 65 tr: l 0.580 a 0.874  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.130085 cl_acc 1.000 214.535sec(train) 6.333sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 65 tst: l 0.844 a 0.788  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.036sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 66 tr: l 0.587 a 0.872  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.128784 cl_acc 1.000 218.889sec(train) 5.375sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 66 tst: l 0.844 a 0.790  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.126sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 67 tr: l 0.590 a 0.870  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.127496 cl_acc 1.000 250.679sec(train) 6.678sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 67 tst: l 0.839 a 0.790  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.229sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 68 tr: l 0.550 a 0.883  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.126221 cl_acc 1.000 303.278sec(train) 7.228sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 68 tst: l 0.844 a 0.791  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.508sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 69 tr: l 0.558 a 0.880  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.124959 cl_acc 1.000 240.062sec(train) 5.902sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 69 tst: l 0.838 a 0.792  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.096sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 70 tr: l 0.572 a 0.877  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.123710 cl_acc 1.000 217.357sec(train) 5.987sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 70 tst: l 0.845 a 0.792  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.100sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 71 tr: l 0.561 a 0.880  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.122473 cl_acc 1.000 215.797sec(train) 5.811sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 71 tst: l 0.840 a 0.791  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.110sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 72 tr: l 0.560 a 0.879  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.121248 cl_acc 1.000 196.135sec(train) 6.565sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 72 tst: l 0.829 a 0.795  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.996sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 73 tr: l 0.569 a 0.875  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.120035 cl_acc 1.000 246.339sec(train) 7.331sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 73 tst: l 0.832 a 0.794  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 3.167sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 74 tr: l 0.562 a 0.878  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.118835 cl_acc 1.000 314.622sec(train) 7.469sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 74 tst: l 0.822 a 0.798  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.366sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 75 tr: l 0.566 a 0.876  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.117647 cl_acc 1.000 269.597sec(train) 6.366sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 75 tst: l 0.825 a 0.793  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.441sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 76 tr: l 0.565 a 0.876  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.116470 cl_acc 1.000 219.619sec(train) 5.375sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 76 tst: l 0.818 a 0.796  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.023sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 77 tr: l 0.551 a 0.880  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.115305 cl_acc 1.000 229.804sec(train) 6.008sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 77 tst: l 0.817 a 0.797  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.212sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 78 tr: l 0.544 a 0.883  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.114152 cl_acc 1.000 215.398sec(train) 5.194sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 78 tst: l 0.824 a 0.794  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.176sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 79 tr: l 0.570 a 0.872  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.113011 cl_acc 1.000 238.438sec(train) 7.443sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 79 tst: l 0.823 a 0.794  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.232sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 80 tr: l 0.519 a 0.890  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.111881 cl_acc 1.000 312.495sec(train) 6.694sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 80 tst: l 0.818 a 0.796  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.316sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 81 tr: l 0.547 a 0.882  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.110762 cl_acc 1.000 237.513sec(train) 6.482sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 81 tst: l 0.821 a 0.795  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.120sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 82 tr: l 0.564 a 0.874  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.109654 cl_acc 1.000 222.034sec(train) 6.258sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 82 tst: l 0.812 a 0.795  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.399sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 83 tr: l 0.519 a 0.890  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.108558 cl_acc 1.000 233.891sec(train) 5.191sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 83 tst: l 0.817 a 0.795  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.004sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 84 tr: l 0.524 a 0.887  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.107472 cl_acc 1.000 235.641sec(train) 5.506sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 84 tst: l 0.813 a 0.799  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.020sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 85 tr: l 0.555 a 0.875  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.106398 cl_acc 1.000 257.837sec(train) 6.599sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 85 tst: l 0.811 a 0.798  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.343sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 86 tr: l 0.523 a 0.889  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.105334 cl_acc 1.000 304.676sec(train) 6.598sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 86 tst: l 0.806 a 0.798  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.369sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 87 tr: l 0.507 a 0.894  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.104280 cl_acc 1.000 241.396sec(train) 5.276sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 87 tst: l 0.809 a 0.799  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.965sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 88 tr: l 0.498 a 0.895  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.103237 cl_acc 1.000 217.982sec(train) 4.966sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 88 tst: l 0.803 a 0.798  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.988sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 89 tr: l 0.517 a 0.888  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.102205 cl_acc 1.000 221.192sec(train) 4.508sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 89 tst: l 0.809 a 0.797  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.943sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 90 tr: l 0.504 a 0.893  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.101183 cl_acc 1.000 196.838sec(train) 6.078sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 90 tst: l 0.794 a 0.801  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.433sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 91 tr: l 0.490 a 0.897  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.100171 cl_acc 1.000 244.872sec(train) 6.572sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 91 tst: l 0.802 a 0.803  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.237sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 92 tr: l 0.511 a 0.889  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.099169 cl_acc 1.000 301.373sec(train) 6.559sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 92 tst: l 0.794 a 0.803  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.259sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 93 tr: l 0.503 a 0.894  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.098178 cl_acc 1.000 259.888sec(train) 5.323sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 93 tst: l 0.791 a 0.804  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.022sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 94 tr: l 0.495 a 0.896  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.097196 cl_acc 1.000 218.175sec(train) 6.494sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 94 tst: l 0.797 a 0.802  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.062sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 95 tr: l 0.507 a 0.891  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.096224 cl_acc 1.000 217.089sec(train) 6.101sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 95 tst: l 0.795 a 0.801  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.303sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 96 tr: l 0.487 a 0.897  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.095262 cl_acc 1.000 232.720sec(train) 5.306sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 96 tst: l 0.787 a 0.803  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.958sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 97 tr: l 0.482 a 0.899  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.094309 cl_acc 1.000 255.687sec(train) 7.654sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 97 tst: l 0.787 a 0.806  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.529sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 98 tr: l 0.504 a 0.890  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.093366 cl_acc 1.000 316.837sec(train) 6.691sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 98 tst: l 0.789 a 0.804  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.383sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 99 tr: l 0.495 a 0.894  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.092432 cl_acc 1.000 243.047sec(train) 6.113sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 99 tst: l 0.789 a 0.804  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.119sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 100 tr: l 0.503 a 0.890  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.091508 cl_acc 1.000 216.339sec(train) 5.452sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 100 tst: l 0.788 a 0.803  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.165sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 101 tr: l 0.475 a 0.900  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.090593 cl_acc 1.000 219.817sec(train) 5.287sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 101 tst: l 0.784 a 0.804  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.164sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 102 tr: l 0.477 a 0.898  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.089687 cl_acc 1.000 225.529sec(train) 5.406sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 102 tst: l 0.785 a 0.804  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.020sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 103 tr: l 0.498 a 0.892  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.088790 cl_acc 1.000 235.273sec(train) 6.802sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 103 tst: l 0.783 a 0.805  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.365sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 104 tr: l 0.486 a 0.895  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.087902 cl_acc 1.000 306.819sec(train) 6.275sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 104 tst: l 0.775 a 0.807  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.377sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 105 tr: l 0.480 a 0.897  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.087023 cl_acc 1.000 253.002sec(train) 5.558sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 105 tst: l 0.778 a 0.807  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.136sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 106 tr: l 0.451 a 0.908  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.086153 cl_acc 1.000 219.357sec(train) 5.349sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 106 tst: l 0.781 a 0.806  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.052sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 107 tr: l 0.483 a 0.896  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.085292 cl_acc 1.000 216.115sec(train) 4.796sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 107 tst: l 0.779 a 0.807  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.916sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 108 tr: l 0.459 a 0.904  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.084439 cl_acc 1.000 197.557sec(train) 6.570sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 108 tst: l 0.775 a 0.809  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.067sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 109 tr: l 0.476 a 0.897  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.083594 cl_acc 1.000 210.128sec(train) 5.059sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 109 tst: l 0.774 a 0.809  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.889sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 110 tr: l 0.458 a 0.904  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.082758 cl_acc 1.000 295.221sec(train) 6.557sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 110 tst: l 0.775 a 0.809  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.180sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 111 tr: l 0.487 a 0.892  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.081931 cl_acc 1.000 262.064sec(train) 5.321sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 111 tst: l 0.765 a 0.810  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.993sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 112 tr: l 0.474 a 0.896  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.081111 cl_acc 1.000 217.305sec(train) 5.118sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 112 tst: l 0.770 a 0.809  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.967sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 113 tr: l 0.452 a 0.904  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.080300 cl_acc 1.000 217.006sec(train) 5.462sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 113 tst: l 0.769 a 0.810  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.999sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 114 tr: l 0.464 a 0.900  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.079497 cl_acc 1.000 216.271sec(train) 5.063sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 114 tst: l 0.774 a 0.807  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.971sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 115 tr: l 0.446 a 0.907  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.078702 cl_acc 1.000 224.647sec(train) 6.527sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 115 tst: l 0.776 a 0.810  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.154sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 116 tr: l 0.451 a 0.904  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.077915 cl_acc 1.000 291.802sec(train) 6.867sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 116 tst: l 0.770 a 0.811  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.148sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 117 tr: l 0.443 a 0.907  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.077136 cl_acc 1.000 268.663sec(train) 5.568sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 117 tst: l 0.768 a 0.809  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.115sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 118 tr: l 0.440 a 0.908  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.076365 cl_acc 1.000 218.356sec(train) 5.360sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 118 tst: l 0.764 a 0.811  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.025sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 119 tr: l 0.443 a 0.907  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.075601 cl_acc 1.000 217.343sec(train) 6.259sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 119 tst: l 0.767 a 0.811  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.085sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 120 tr: l 0.449 a 0.904  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.074845 cl_acc 1.000 219.843sec(train) 5.552sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 120 tst: l 0.764 a 0.812  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.105sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 121 tr: l 0.452 a 0.901  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.074097 cl_acc 1.000 218.917sec(train) 6.073sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 121 tst: l 0.759 a 0.814  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.289sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 122 tr: l 0.458 a 0.901  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.073356 cl_acc 1.000 284.567sec(train) 7.345sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 122 tst: l 0.761 a 0.812  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.506sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 123 tr: l 0.466 a 0.897  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.072622 cl_acc 1.000 275.738sec(train) 6.229sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 123 tst: l 0.763 a 0.813  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.030sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 124 tr: l 0.434 a 0.909  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.071896 cl_acc 1.000 222.640sec(train) 6.550sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 124 tst: l 0.758 a 0.814  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.088sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 125 tr: l 0.443 a 0.904  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.071177 cl_acc 1.000 217.126sec(train) 7.622sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 125 tst: l 0.755 a 0.815  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.010sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 126 tr: l 0.433 a 0.907  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.070465 cl_acc 1.000 194.142sec(train) 7.066sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 126 tst: l 0.759 a 0.813  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.012sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 127 tr: l 0.445 a 0.903  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.069761 cl_acc 1.000 216.067sec(train) 6.142sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 127 tst: l 0.749 a 0.812  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.179sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 128 tr: l 0.425 a 0.910  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.069063 cl_acc 1.000 269.217sec(train) 7.131sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 128 tst: l 0.754 a 0.812  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.495sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 129 tr: l 0.448 a 0.902  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.068372 cl_acc 1.000 307.634sec(train) 5.864sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 129 tst: l 0.752 a 0.814  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.437sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 130 tr: l 0.414 a 0.914  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.067689 cl_acc 1.000 222.192sec(train) 6.492sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 130 tst: l 0.757 a 0.814  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.142sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 131 tr: l 0.436 a 0.904  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.067012 cl_acc 1.000 217.220sec(train) 5.933sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 131 tst: l 0.751 a 0.813  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.204sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 132 tr: l 0.428 a 0.908  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.066342 cl_acc 1.000 219.263sec(train) 5.770sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 132 tst: l 0.754 a 0.816  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.037sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 133 tr: l 0.429 a 0.906  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.065678 cl_acc 1.000 217.666sec(train) 6.491sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 133 tst: l 0.748 a 0.815  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.008sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 134 tr: l 0.411 a 0.913  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.065021 cl_acc 1.000 266.639sec(train) 7.770sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 134 tst: l 0.742 a 0.817  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.472sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 135 tr: l 0.406 a 0.915  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.064371 cl_acc 1.000 302.309sec(train) 6.063sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 135 tst: l 0.742 a 0.815  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.138sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 136 tr: l 0.438 a 0.904  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.063727 cl_acc 1.000 217.948sec(train) 5.563sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 136 tst: l 0.745 a 0.815  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.033sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 137 tr: l 0.410 a 0.912  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.063090 cl_acc 1.000 220.052sec(train) 5.722sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 137 tst: l 0.736 a 0.817  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.070sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 138 tr: l 0.390 a 0.921  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.062459 cl_acc 1.000 218.515sec(train) 5.487sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 138 tst: l 0.743 a 0.814  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.112sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 139 tr: l 0.402 a 0.916  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.061835 cl_acc 1.000 218.345sec(train) 5.574sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 139 tst: l 0.740 a 0.816  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.069sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 140 tr: l 0.409 a 0.914  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.061216 cl_acc 1.000 271.963sec(train) 7.485sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 140 tst: l 0.739 a 0.818  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.517sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 141 tr: l 0.417 a 0.910  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.060604 cl_acc 1.000 303.724sec(train) 6.047sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 141 tst: l 0.740 a 0.816  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.297sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 142 tr: l 0.414 a 0.911  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.059998 cl_acc 1.000 219.618sec(train) 6.046sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 142 tst: l 0.734 a 0.818  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.162sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 143 tr: l 0.390 a 0.919  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.059398 cl_acc 1.000 216.555sec(train) 6.283sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 143 tst: l 0.735 a 0.817  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.101sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 144 tr: l 0.410 a 0.911  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.058804 cl_acc 1.000 170.902sec(train) 4.879sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 144 tst: l 0.733 a 0.817  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.919sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 145 tr: l 0.398 a 0.916  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.058216 cl_acc 1.000 148.539sec(train) 4.922sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 145 tst: l 0.737 a 0.817  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.951sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 146 tr: l 0.399 a 0.914  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.057634 cl_acc 1.000 148.488sec(train) 4.584sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 146 tst: l 0.732 a 0.820  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.864sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 147 tr: l 0.392 a 0.918  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.057058 cl_acc 1.000 231.286sec(train) 7.489sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 147 tst: l 0.733 a 0.819  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.578sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 148 tr: l 0.400 a 0.914  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.056487 cl_acc 1.000 248.270sec(train) 6.653sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 148 tst: l 0.730 a 0.819  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.276sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 149 tr: l 0.393 a 0.915  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.055922 cl_acc 1.000 153.807sec(train) 4.956sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 149 tst: l 0.734 a 0.821  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.912sec\n",
      "result written at output/results.pickle\n",
      "---train cluster Ended in 9.28 hour (33390.943 sec) \n",
      "---------------------------------DFCA, lr: 0.25, seed: 4012---------------------------------\n",
      "config: {'m': 50, 'm_test': 10, 'p': 2, 'n': 2000, 'local_model_init': False, 'participation_rate': 1, 'Gp': 0.25, 'graph': 'er', 'agg': 'seq', 'num_epochs': 150, 'batch_size': 50, 'tau': 10, 'lr': 0.25, 'data_seed': 4012, 'train_seed': 4012, 'project_dir': 'output'}\n",
      "Using device: cuda:2\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "I0000 00:00:1758556332.432263 4028755 gpu_device.cc:2019] Created device /job:localhost/replica:0/task:0/device:GPU:0 with 33884 MB memory:  -> device: 2, name: NVIDIA A100-SXM4-40GB, pci bus id: 0000:81:00.0, compute capability: 8.0\n",
      "2025-09-22 17:52:12.619835: 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.675 a 0.098  clct[np.int64(17), np.int64(33)] ans[np.int64(25), np.int64(25)] cl_acc 0.560 6.135sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-09-22 17:52:18.840719: 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(50), np.int64(0)] ans[np.int64(25), np.int64(25)] cl_acc 0.500 5.386sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-09-22 17:52:24.316290: 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.098  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] cl_acc 0.500 4.923sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-09-22 17:52:29.344568: 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.680 a 0.104  clct[np.int64(22), np.int64(28)] ans[np.int64(25), np.int64(25)] cl_acc 0.860 5.073sec\n",
      "found good initializer\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch -1 tr: l 4.680 a 0.103  clct[np.int64(18), np.int64(32)] ans[np.int64(25), np.int64(25)] cl_acc 0.860 5.074sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch -1 tst: l 4.680 a 0.109  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.033sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0 tr: l 3.239 a 0.257  clct[np.int64(18), np.int64(32)] ans[np.int64(25), np.int64(25)] lr 0.250000 cl_acc 0.860 146.803sec(train) 4.521sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0 tst: l 3.253 a 0.224  clct[np.int64(9), np.int64(1)] ans[np.int64(5), np.int64(5)] cl_acc 0.600 0.883sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1 tr: l 2.321 a 0.402  clct[np.int64(18), np.int64(32)] ans[np.int64(25), np.int64(25)] lr 0.247500 cl_acc 0.860 144.832sec(train) 4.800sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1 tst: l 2.441 a 0.373  clct[np.int64(6), np.int64(4)] ans[np.int64(5), np.int64(5)] cl_acc 0.700 0.911sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2 tr: l 1.801 a 0.494  clct[np.int64(18), np.int64(32)] ans[np.int64(25), np.int64(25)] lr 0.245025 cl_acc 0.860 144.179sec(train) 5.410sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2 tst: l 1.856 a 0.496  clct[np.int64(4), np.int64(6)] ans[np.int64(5), np.int64(5)] cl_acc 0.900 0.939sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3 tr: l 1.583 a 0.538  clct[np.int64(21), np.int64(29)] ans[np.int64(25), np.int64(25)] lr 0.242575 cl_acc 0.920 148.188sec(train) 5.051sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3 tst: l 1.559 a 0.567  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.970sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4 tr: l 1.377 a 0.595  clct[np.int64(24), np.int64(26)] ans[np.int64(25), np.int64(25)] lr 0.240149 cl_acc 0.980 152.770sec(train) 5.005sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4 tst: l 1.392 a 0.602  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.960sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5 tr: l 1.194 a 0.658  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.237748 cl_acc 1.000 174.626sec(train) 9.312sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5 tst: l 1.237 a 0.642  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.410sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6 tr: l 1.145 a 0.673  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.235370 cl_acc 1.000 251.320sec(train) 7.576sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6 tst: l 1.158 a 0.665  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.357sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7 tr: l 1.087 a 0.698  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.233016 cl_acc 1.000 229.471sec(train) 5.650sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7 tst: l 1.125 a 0.682  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.102sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8 tr: l 1.040 a 0.714  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.230686 cl_acc 1.000 169.619sec(train) 4.916sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8 tst: l 1.103 a 0.690  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.112sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9 tr: l 1.008 a 0.729  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.228379 cl_acc 1.000 150.675sec(train) 4.769sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9 tst: l 1.079 a 0.698  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.927sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10 tr: l 0.981 a 0.741  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.226096 cl_acc 1.000 153.303sec(train) 4.945sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10 tst: l 1.083 a 0.702  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.921sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11 tr: l 0.977 a 0.741  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.223835 cl_acc 1.000 149.807sec(train) 4.886sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11 tst: l 1.057 a 0.712  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.937sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12 tr: l 0.936 a 0.758  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.221596 cl_acc 1.000 149.210sec(train) 5.291sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12 tst: l 1.042 a 0.717  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.014sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13 tr: l 0.909 a 0.768  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.219380 cl_acc 1.000 158.856sec(train) 4.805sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13 tst: l 1.031 a 0.724  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.882sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14 tr: l 0.902 a 0.774  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.217186 cl_acc 1.000 248.853sec(train) 6.389sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14 tst: l 1.044 a 0.719  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.337sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15 tr: l 0.872 a 0.788  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.215015 cl_acc 1.000 236.248sec(train) 5.707sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15 tst: l 1.039 a 0.727  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.985sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16 tr: l 0.881 a 0.781  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.212864 cl_acc 1.000 165.516sec(train) 5.969sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16 tst: l 1.037 a 0.725  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.122sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17 tr: l 0.881 a 0.781  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.210736 cl_acc 1.000 176.873sec(train) 5.318sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17 tst: l 1.022 a 0.731  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.976sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18 tr: l 0.856 a 0.792  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.208628 cl_acc 1.000 157.730sec(train) 4.801sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18 tst: l 1.004 a 0.739  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.940sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19 tr: l 0.846 a 0.797  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.206542 cl_acc 1.000 163.362sec(train) 4.933sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19 tst: l 1.012 a 0.739  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.952sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20 tr: l 0.843 a 0.797  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.204477 cl_acc 1.000 151.573sec(train) 5.141sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20 tst: l 0.999 a 0.743  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.995sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21 tr: l 0.839 a 0.799  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.202432 cl_acc 1.000 160.669sec(train) 5.798sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21 tst: l 1.002 a 0.745  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.112sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22 tr: l 0.802 a 0.813  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.200408 cl_acc 1.000 220.777sec(train) 5.997sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22 tst: l 0.996 a 0.744  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.065sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23 tr: l 0.813 a 0.809  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.198404 cl_acc 1.000 218.425sec(train) 6.252sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23 tst: l 1.004 a 0.744  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.306sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24 tr: l 0.805 a 0.811  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.196420 cl_acc 1.000 173.029sec(train) 5.170sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24 tst: l 0.993 a 0.745  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.927sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25 tr: l 0.818 a 0.807  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.194455 cl_acc 1.000 150.536sec(train) 5.124sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25 tst: l 0.976 a 0.752  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.979sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 26 tr: l 0.780 a 0.820  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.192511 cl_acc 1.000 159.517sec(train) 5.034sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 26 tst: l 0.993 a 0.750  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.974sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 27 tr: l 0.776 a 0.819  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.190586 cl_acc 1.000 148.416sec(train) 4.739sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 27 tst: l 0.977 a 0.752  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.919sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 28 tr: l 0.766 a 0.822  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.188680 cl_acc 1.000 150.822sec(train) 5.230sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 28 tst: l 0.985 a 0.751  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.004sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 29 tr: l 0.779 a 0.820  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.186793 cl_acc 1.000 150.074sec(train) 5.302sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 29 tst: l 0.957 a 0.758  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.981sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 30 tr: l 0.764 a 0.824  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.184925 cl_acc 1.000 158.412sec(train) 5.626sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 30 tst: l 0.963 a 0.759  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.146sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 31 tr: l 0.743 a 0.832  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.183076 cl_acc 1.000 237.098sec(train) 6.222sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 31 tst: l 0.962 a 0.757  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.150sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 32 tr: l 0.764 a 0.827  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.181245 cl_acc 1.000 234.618sec(train) 7.768sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 32 tst: l 0.950 a 0.761  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.550sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 33 tr: l 0.735 a 0.831  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.179433 cl_acc 1.000 167.254sec(train) 5.065sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 33 tst: l 0.950 a 0.762  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.950sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 34 tr: l 0.772 a 0.821  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.177638 cl_acc 1.000 149.779sec(train) 4.942sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 34 tst: l 0.944 a 0.762  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.964sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 35 tr: l 0.743 a 0.830  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.175862 cl_acc 1.000 148.552sec(train) 5.376sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 35 tst: l 0.949 a 0.760  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.016sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 36 tr: l 0.723 a 0.839  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.174103 cl_acc 1.000 146.992sec(train) 4.730sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 36 tst: l 0.939 a 0.764  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.919sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 37 tr: l 0.705 a 0.842  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.172362 cl_acc 1.000 147.799sec(train) 5.000sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 37 tst: l 0.940 a 0.763  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.074sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 38 tr: l 0.694 a 0.848  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.170639 cl_acc 1.000 167.628sec(train) 4.872sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 38 tst: l 0.937 a 0.764  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.000sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 39 tr: l 0.714 a 0.837  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.168932 cl_acc 1.000 186.691sec(train) 5.988sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 39 tst: l 0.923 a 0.769  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.225sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 40 tr: l 0.685 a 0.848  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.167243 cl_acc 1.000 226.165sec(train) 6.555sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 40 tst: l 0.921 a 0.769  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.400sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 41 tr: l 0.685 a 0.847  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.165571 cl_acc 1.000 221.316sec(train) 4.757sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 41 tst: l 0.929 a 0.768  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.920sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 42 tr: l 0.667 a 0.854  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.163915 cl_acc 1.000 150.211sec(train) 4.985sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 42 tst: l 0.936 a 0.765  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.983sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 43 tr: l 0.678 a 0.848  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.162276 cl_acc 1.000 151.298sec(train) 5.117sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 43 tst: l 0.931 a 0.768  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.950sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 44 tr: l 0.655 a 0.857  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.160653 cl_acc 1.000 150.525sec(train) 4.881sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 44 tst: l 0.913 a 0.771  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.945sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 45 tr: l 0.642 a 0.863  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.159046 cl_acc 1.000 150.077sec(train) 4.669sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 45 tst: l 0.915 a 0.774  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.898sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 46 tr: l 0.659 a 0.854  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.157456 cl_acc 1.000 146.188sec(train) 4.896sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 46 tst: l 0.911 a 0.775  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.911sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 47 tr: l 0.640 a 0.862  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.155881 cl_acc 1.000 147.041sec(train) 5.209sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 47 tst: l 0.895 a 0.776  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.170sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 48 tr: l 0.660 a 0.854  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.154323 cl_acc 1.000 210.828sec(train) 6.946sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 48 tst: l 0.909 a 0.774  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.570sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 49 tr: l 0.639 a 0.863  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.152779 cl_acc 1.000 233.296sec(train) 7.357sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 49 tst: l 0.898 a 0.774  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.247sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 50 tr: l 0.632 a 0.864  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.151252 cl_acc 1.000 190.348sec(train) 5.476sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 50 tst: l 0.895 a 0.776  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.019sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 51 tr: l 0.655 a 0.856  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.149739 cl_acc 1.000 152.060sec(train) 4.948sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 51 tst: l 0.900 a 0.774  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.980sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 52 tr: l 0.625 a 0.866  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.148242 cl_acc 1.000 151.525sec(train) 5.223sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 52 tst: l 0.899 a 0.775  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.022sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 53 tr: l 0.619 a 0.866  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.146759 cl_acc 1.000 150.939sec(train) 5.593sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 53 tst: l 0.893 a 0.779  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.951sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 54 tr: l 0.597 a 0.874  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.145292 cl_acc 1.000 148.139sec(train) 4.553sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 54 tst: l 0.888 a 0.778  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.921sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 55 tr: l 0.614 a 0.866  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.143839 cl_acc 1.000 155.960sec(train) 4.843sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 55 tst: l 0.879 a 0.779  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.945sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 56 tr: l 0.597 a 0.876  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.142400 cl_acc 1.000 155.480sec(train) 5.689sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 56 tst: l 0.887 a 0.777  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.112sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 57 tr: l 0.625 a 0.863  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.140976 cl_acc 1.000 235.168sec(train) 7.180sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 57 tst: l 0.886 a 0.778  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.652sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 58 tr: l 0.584 a 0.877  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.139567 cl_acc 1.000 257.442sec(train) 6.525sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 58 tst: l 0.882 a 0.781  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.219sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 59 tr: l 0.599 a 0.871  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.138171 cl_acc 1.000 163.138sec(train) 4.928sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 59 tst: l 0.880 a 0.781  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.960sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 60 tr: l 0.569 a 0.882  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.136789 cl_acc 1.000 153.505sec(train) 4.994sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 60 tst: l 0.867 a 0.783  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.000sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 61 tr: l 0.621 a 0.863  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.135421 cl_acc 1.000 153.745sec(train) 5.101sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 61 tst: l 0.865 a 0.784  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.972sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 62 tr: l 0.589 a 0.874  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.134067 cl_acc 1.000 146.675sec(train) 5.502sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 62 tst: l 0.868 a 0.783  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.075sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 63 tr: l 0.599 a 0.870  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.132726 cl_acc 1.000 152.017sec(train) 4.898sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 63 tst: l 0.864 a 0.786  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.958sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 64 tr: l 0.611 a 0.865  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.131399 cl_acc 1.000 157.549sec(train) 4.733sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 64 tst: l 0.858 a 0.786  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.943sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 65 tr: l 0.576 a 0.879  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.130085 cl_acc 1.000 214.630sec(train) 6.150sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 65 tst: l 0.854 a 0.788  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.369sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 66 tr: l 0.576 a 0.878  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.128784 cl_acc 1.000 243.261sec(train) 7.675sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 66 tst: l 0.853 a 0.788  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.771sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 67 tr: l 0.565 a 0.880  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.127496 cl_acc 1.000 199.725sec(train) 5.280sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 67 tst: l 0.841 a 0.791  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.013sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 68 tr: l 0.577 a 0.876  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.126221 cl_acc 1.000 154.484sec(train) 5.218sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 68 tst: l 0.856 a 0.786  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.002sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 69 tr: l 0.565 a 0.879  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.124959 cl_acc 1.000 167.954sec(train) 5.001sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 69 tst: l 0.853 a 0.787  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.023sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 70 tr: l 0.552 a 0.883  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.123710 cl_acc 1.000 162.100sec(train) 5.238sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 70 tst: l 0.856 a 0.786  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.075sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 71 tr: l 0.564 a 0.879  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.122473 cl_acc 1.000 160.833sec(train) 4.894sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 71 tst: l 0.841 a 0.791  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.956sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 72 tr: l 0.576 a 0.874  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.121248 cl_acc 1.000 150.592sec(train) 4.742sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 72 tst: l 0.843 a 0.791  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.932sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 73 tr: l 0.585 a 0.873  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.120035 cl_acc 1.000 168.031sec(train) 6.874sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 73 tst: l 0.844 a 0.789  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.302sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 74 tr: l 0.542 a 0.888  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.118835 cl_acc 1.000 245.534sec(train) 7.727sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 74 tst: l 0.860 a 0.787  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.315sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 75 tr: l 0.541 a 0.887  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.117647 cl_acc 1.000 250.679sec(train) 5.132sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 75 tst: l 0.846 a 0.789  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.952sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 76 tr: l 0.514 a 0.894  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.116470 cl_acc 1.000 155.947sec(train) 5.333sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 76 tst: l 0.824 a 0.795  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.148sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 77 tr: l 0.527 a 0.891  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.115305 cl_acc 1.000 173.347sec(train) 5.877sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 77 tst: l 0.834 a 0.792  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.094sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 78 tr: l 0.536 a 0.887  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.114152 cl_acc 1.000 163.871sec(train) 5.201sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 78 tst: l 0.848 a 0.790  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.093sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 79 tr: l 0.523 a 0.889  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.113011 cl_acc 1.000 150.292sec(train) 5.712sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 79 tst: l 0.827 a 0.794  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.181sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 80 tr: l 0.541 a 0.885  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.111881 cl_acc 1.000 154.022sec(train) 4.916sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 80 tst: l 0.829 a 0.793  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.954sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 81 tr: l 0.519 a 0.891  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.110762 cl_acc 1.000 148.885sec(train) 5.189sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 81 tst: l 0.829 a 0.793  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.012sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 82 tr: l 0.500 a 0.898  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.109654 cl_acc 1.000 180.118sec(train) 5.671sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 82 tst: l 0.821 a 0.795  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.152sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 83 tr: l 0.550 a 0.879  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.108558 cl_acc 1.000 231.724sec(train) 7.607sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 83 tst: l 0.821 a 0.794  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.384sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 84 tr: l 0.535 a 0.884  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.107472 cl_acc 1.000 236.934sec(train) 5.310sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 84 tst: l 0.821 a 0.796  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.029sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 85 tr: l 0.529 a 0.887  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.106398 cl_acc 1.000 161.754sec(train) 4.989sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 85 tst: l 0.817 a 0.795  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.978sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 86 tr: l 0.522 a 0.887  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.105334 cl_acc 1.000 147.219sec(train) 4.617sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 86 tst: l 0.829 a 0.793  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.891sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 87 tr: l 0.503 a 0.893  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.104280 cl_acc 1.000 150.442sec(train) 4.646sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 87 tst: l 0.821 a 0.794  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.026sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 88 tr: l 0.507 a 0.894  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.103237 cl_acc 1.000 156.401sec(train) 4.646sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 88 tst: l 0.811 a 0.797  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.920sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 89 tr: l 0.509 a 0.894  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.102205 cl_acc 1.000 146.547sec(train) 4.335sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 89 tst: l 0.814 a 0.797  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.854sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 90 tr: l 0.501 a 0.893  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.101183 cl_acc 1.000 153.979sec(train) 4.429sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 90 tst: l 0.805 a 0.798  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.884sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 91 tr: l 0.487 a 0.899  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.100171 cl_acc 1.000 206.020sec(train) 8.327sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 91 tst: l 0.812 a 0.800  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.569sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 92 tr: l 0.516 a 0.888  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.099169 cl_acc 1.000 242.050sec(train) 7.081sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 92 tst: l 0.821 a 0.795  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.447sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 93 tr: l 0.503 a 0.892  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.098178 cl_acc 1.000 192.733sec(train) 5.480sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 93 tst: l 0.804 a 0.800  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.203sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 94 tr: l 0.489 a 0.897  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.097196 cl_acc 1.000 158.227sec(train) 4.946sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 94 tst: l 0.821 a 0.798  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.973sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 95 tr: l 0.500 a 0.895  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.096224 cl_acc 1.000 156.529sec(train) 4.593sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 95 tst: l 0.809 a 0.798  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.906sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 96 tr: l 0.477 a 0.900  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.095262 cl_acc 1.000 152.439sec(train) 4.772sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 96 tst: l 0.804 a 0.800  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.923sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 97 tr: l 0.462 a 0.907  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.094309 cl_acc 1.000 157.462sec(train) 5.057sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 97 tst: l 0.799 a 0.801  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.994sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 98 tr: l 0.487 a 0.895  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.093366 cl_acc 1.000 146.591sec(train) 4.774sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 98 tst: l 0.797 a 0.800  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.920sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 99 tr: l 0.476 a 0.901  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.092432 cl_acc 1.000 151.900sec(train) 7.377sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 99 tst: l 0.794 a 0.803  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.595sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 100 tr: l 0.459 a 0.907  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.091508 cl_acc 1.000 231.386sec(train) 6.087sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 100 tst: l 0.796 a 0.800  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.194sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 101 tr: l 0.473 a 0.900  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.090593 cl_acc 1.000 235.536sec(train) 6.539sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 101 tst: l 0.795 a 0.803  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.250sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 102 tr: l 0.484 a 0.898  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.089687 cl_acc 1.000 170.539sec(train) 4.822sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 102 tst: l 0.788 a 0.804  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.931sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 103 tr: l 0.473 a 0.900  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.088790 cl_acc 1.000 150.705sec(train) 5.116sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 103 tst: l 0.786 a 0.805  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.004sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 104 tr: l 0.474 a 0.899  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.087902 cl_acc 1.000 144.447sec(train) 4.753sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 104 tst: l 0.777 a 0.806  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.962sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 105 tr: l 0.478 a 0.897  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.087023 cl_acc 1.000 149.333sec(train) 4.553sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 105 tst: l 0.791 a 0.803  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.874sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 106 tr: l 0.437 a 0.912  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.086153 cl_acc 1.000 154.148sec(train) 4.870sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 106 tst: l 0.792 a 0.801  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.935sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 107 tr: l 0.456 a 0.906  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.085292 cl_acc 1.000 140.404sec(train) 4.360sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 107 tst: l 0.782 a 0.805  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.839sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 108 tr: l 0.454 a 0.905  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.084439 cl_acc 1.000 137.256sec(train) 5.734sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 108 tst: l 0.787 a 0.806  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.321sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 109 tr: l 0.433 a 0.911  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.083594 cl_acc 1.000 228.275sec(train) 6.354sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 109 tst: l 0.786 a 0.806  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.273sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 110 tr: l 0.458 a 0.903  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.082758 cl_acc 1.000 222.660sec(train) 5.864sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 110 tst: l 0.778 a 0.806  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.162sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 111 tr: l 0.455 a 0.904  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.081931 cl_acc 1.000 138.511sec(train) 4.492sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 111 tst: l 0.780 a 0.807  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.883sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 112 tr: l 0.467 a 0.899  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.081111 cl_acc 1.000 131.023sec(train) 4.624sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 112 tst: l 0.775 a 0.807  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.941sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 113 tr: l 0.430 a 0.912  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.080300 cl_acc 1.000 148.011sec(train) 4.334sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 113 tst: l 0.788 a 0.806  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.848sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 114 tr: l 0.461 a 0.901  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.079497 cl_acc 1.000 136.338sec(train) 4.430sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 114 tst: l 0.775 a 0.807  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.872sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 115 tr: l 0.440 a 0.908  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.078702 cl_acc 1.000 143.197sec(train) 4.430sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 115 tst: l 0.779 a 0.805  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.877sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 116 tr: l 0.426 a 0.913  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.077915 cl_acc 1.000 149.683sec(train) 4.505sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 116 tst: l 0.782 a 0.806  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.876sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 117 tr: l 0.454 a 0.903  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.077136 cl_acc 1.000 158.318sec(train) 5.516sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 117 tst: l 0.767 a 0.810  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.093sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 118 tr: l 0.461 a 0.900  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.076365 cl_acc 1.000 232.211sec(train) 5.966sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 118 tst: l 0.769 a 0.807  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.004sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 119 tr: l 0.430 a 0.911  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.075601 cl_acc 1.000 247.448sec(train) 7.682sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 119 tst: l 0.772 a 0.807  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.396sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 120 tr: l 0.432 a 0.909  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.074845 cl_acc 1.000 174.926sec(train) 5.373sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 120 tst: l 0.776 a 0.808  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.100sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 121 tr: l 0.416 a 0.915  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.074097 cl_acc 1.000 134.898sec(train) 4.546sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 121 tst: l 0.771 a 0.809  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.937sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 122 tr: l 0.432 a 0.910  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.073356 cl_acc 1.000 135.463sec(train) 4.473sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 122 tst: l 0.764 a 0.812  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.922sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 123 tr: l 0.423 a 0.913  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.072622 cl_acc 1.000 152.789sec(train) 4.596sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 123 tst: l 0.763 a 0.811  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.898sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 124 tr: l 0.440 a 0.905  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.071896 cl_acc 1.000 119.796sec(train) 4.383sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 124 tst: l 0.770 a 0.809  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.857sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 125 tr: l 0.437 a 0.906  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.071177 cl_acc 1.000 118.111sec(train) 4.346sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 125 tst: l 0.760 a 0.810  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.850sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 126 tr: l 0.437 a 0.906  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.070465 cl_acc 1.000 119.408sec(train) 4.413sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 126 tst: l 0.766 a 0.812  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.860sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 127 tr: l 0.421 a 0.912  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.069761 cl_acc 1.000 148.368sec(train) 6.813sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 127 tst: l 0.762 a 0.809  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.354sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 128 tr: l 0.400 a 0.920  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.069063 cl_acc 1.000 244.874sec(train) 8.519sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 128 tst: l 0.763 a 0.809  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 2.587sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 129 tr: l 0.422 a 0.911  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.068372 cl_acc 1.000 241.137sec(train) 5.081sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 129 tst: l 0.768 a 0.810  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.018sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 130 tr: l 0.410 a 0.915  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.067689 cl_acc 1.000 154.351sec(train) 4.642sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 130 tst: l 0.760 a 0.811  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.859sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 131 tr: l 0.424 a 0.909  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.067012 cl_acc 1.000 146.278sec(train) 4.316sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 131 tst: l 0.755 a 0.811  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.856sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 132 tr: l 0.413 a 0.913  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.066342 cl_acc 1.000 147.958sec(train) 4.369sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 132 tst: l 0.751 a 0.813  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.881sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 133 tr: l 0.418 a 0.911  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.065678 cl_acc 1.000 148.314sec(train) 4.216sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 133 tst: l 0.748 a 0.812  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.861sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 134 tr: l 0.425 a 0.908  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.065021 cl_acc 1.000 148.296sec(train) 4.869sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 134 tst: l 0.760 a 0.812  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.926sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 135 tr: l 0.404 a 0.915  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.064371 cl_acc 1.000 154.374sec(train) 4.674sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 135 tst: l 0.749 a 0.813  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.845sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 136 tr: l 0.404 a 0.914  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.063727 cl_acc 1.000 216.995sec(train) 11.978sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 136 tst: l 0.749 a 0.812  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 2.085sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 137 tr: l 0.410 a 0.912  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.063090 cl_acc 1.000 231.285sec(train) 5.416sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 137 tst: l 0.743 a 0.813  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.014sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 138 tr: l 0.397 a 0.917  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.062459 cl_acc 1.000 184.846sec(train) 4.328sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 138 tst: l 0.745 a 0.813  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.864sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 139 tr: l 0.420 a 0.907  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.061835 cl_acc 1.000 148.326sec(train) 4.325sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 139 tst: l 0.743 a 0.813  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.832sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 140 tr: l 0.408 a 0.912  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.061216 cl_acc 1.000 142.580sec(train) 4.250sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 140 tst: l 0.750 a 0.810  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.852sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 141 tr: l 0.393 a 0.919  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.060604 cl_acc 1.000 143.569sec(train) 4.585sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 141 tst: l 0.750 a 0.812  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.886sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 142 tr: l 0.394 a 0.917  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.059998 cl_acc 1.000 134.621sec(train) 4.492sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 142 tst: l 0.748 a 0.810  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.838sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 143 tr: l 0.376 a 0.923  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.059398 cl_acc 1.000 139.126sec(train) 4.339sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 143 tst: l 0.740 a 0.816  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.830sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 144 tr: l 0.377 a 0.922  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.058804 cl_acc 1.000 146.524sec(train) 4.222sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 144 tst: l 0.735 a 0.816  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.846sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 145 tr: l 0.398 a 0.914  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.058216 cl_acc 1.000 226.816sec(train) 5.287sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 145 tst: l 0.735 a 0.815  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.173sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 146 tr: l 0.401 a 0.914  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.057634 cl_acc 1.000 256.374sec(train) 6.598sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 146 tst: l 0.741 a 0.814  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.973sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 147 tr: l 0.372 a 0.925  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.057058 cl_acc 1.000 153.109sec(train) 5.068sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 147 tst: l 0.729 a 0.816  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.943sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 148 tr: l 0.380 a 0.921  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.056487 cl_acc 1.000 152.173sec(train) 4.796sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 148 tst: l 0.738 a 0.814  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.041sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 149 tr: l 0.367 a 0.925  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.055922 cl_acc 1.000 148.031sec(train) 4.745sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 149 tst: l 0.739 a 0.813  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.919sec\n",
      "result written at output/results.pickle\n",
      "---train cluster Ended in 7.44 hour (26768.552 sec) \n",
      "---------------------------------DFCA, lr: 0.25, seed: 3657---------------------------------\n",
      "config: {'m': 50, 'm_test': 10, 'p': 2, 'n': 2000, 'local_model_init': False, 'participation_rate': 1, 'Gp': 0.25, 'graph': 'er', 'agg': 'seq', 'num_epochs': 150, 'batch_size': 50, 'tau': 10, 'lr': 0.25, 'data_seed': 3657, 'train_seed': 3657, 'project_dir': 'output'}\n",
      "Using device: cuda:2\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "I0000 00:00:1758583100.906309 4028755 gpu_device.cc:2019] Created device /job:localhost/replica:0/task:0/device:GPU:0 with 33884 MB memory:  -> device: 2, name: NVIDIA A100-SXM4-40GB, pci bus id: 0000:81:00.0, compute capability: 8.0\n",
      "2025-09-23 01:18:21.011119: 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.680 a 0.099  clct[np.int64(0), np.int64(50)] ans[np.int64(25), np.int64(25)] cl_acc 0.500 5.811sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-09-23 01:18:26.907827: 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.081  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] cl_acc 0.500 4.945sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-09-23 01:18:31.953230: 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(48), np.int64(2)] ans[np.int64(25), np.int64(25)] cl_acc 0.540 4.793sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-09-23 01:18:36.836338: 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.103  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] cl_acc 0.500 4.866sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-09-23 01:18:41.804259: 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.104  clct[np.int64(0), np.int64(50)] ans[np.int64(25), np.int64(25)] cl_acc 0.500 4.782sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-09-23 01:18:46.691730: 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.094  clct[np.int64(35), np.int64(15)] ans[np.int64(25), np.int64(25)] cl_acc 0.640 4.486sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-09-23 01:18:51.274600: 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.105  clct[np.int64(50), np.int64(0)] ans[np.int64(25), np.int64(25)] cl_acc 0.500 4.786sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-09-23 01:18:56.149813: 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(0), np.int64(50)] ans[np.int64(25), np.int64(25)] cl_acc 0.500 4.274sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-09-23 01:19:00.521255: 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.090  clct[np.int64(0), np.int64(50)] ans[np.int64(25), np.int64(25)] cl_acc 0.500 4.419sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-09-23 01:19:05.028562: 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.098  clct[np.int64(0), np.int64(50)] ans[np.int64(25), np.int64(25)] cl_acc 0.500 4.579sec\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-09-23 01:19:09.700692: 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.109  clct[np.int64(24), np.int64(26)] ans[np.int64(25), np.int64(25)] cl_acc 0.820 4.762sec\n",
      "found good initializer\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch -1 tr: l 4.677 a 0.109  clct[np.int64(21), np.int64(29)] ans[np.int64(25), np.int64(25)] cl_acc 0.760 4.552sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch -1 tst: l 4.677 a 0.112  clct[np.int64(6), np.int64(4)] ans[np.int64(5), np.int64(5)] cl_acc 0.900 1.015sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0 tr: l 3.246 a 0.254  clct[np.int64(21), np.int64(29)] ans[np.int64(25), np.int64(25)] lr 0.250000 cl_acc 0.760 131.988sec(train) 4.662sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0 tst: l 3.264 a 0.235  clct[np.int64(2), np.int64(8)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.938sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1 tr: l 2.457 a 0.350  clct[np.int64(21), np.int64(29)] ans[np.int64(25), np.int64(25)] lr 0.247500 cl_acc 0.760 136.442sec(train) 4.555sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1 tst: l 2.502 a 0.328  clct[np.int64(2), np.int64(8)] ans[np.int64(5), np.int64(5)] cl_acc 0.500 0.910sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2 tr: l 1.941 a 0.451  clct[np.int64(20), np.int64(30)] ans[np.int64(25), np.int64(25)] lr 0.245025 cl_acc 0.780 122.716sec(train) 4.763sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2 tst: l 1.992 a 0.431  clct[np.int64(2), np.int64(8)] ans[np.int64(5), np.int64(5)] cl_acc 0.700 0.847sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3 tr: l 1.656 a 0.513  clct[np.int64(20), np.int64(30)] ans[np.int64(25), np.int64(25)] lr 0.242575 cl_acc 0.860 175.164sec(train) 5.880sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3 tst: l 1.681 a 0.523  clct[np.int64(4), np.int64(6)] ans[np.int64(5), np.int64(5)] cl_acc 0.900 1.308sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4 tr: l 1.433 a 0.578  clct[np.int64(22), np.int64(28)] ans[np.int64(25), np.int64(25)] lr 0.240149 cl_acc 0.940 249.217sec(train) 6.270sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4 tst: l 1.443 a 0.586  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.109sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5 tr: l 1.299 a 0.621  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.237748 cl_acc 1.000 200.702sec(train) 4.765sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5 tst: l 1.303 a 0.620  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.936sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6 tr: l 1.175 a 0.667  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.235370 cl_acc 1.000 134.088sec(train) 4.233sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6 tst: l 1.229 a 0.644  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.785sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7 tr: l 1.093 a 0.689  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.233016 cl_acc 1.000 140.279sec(train) 4.624sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7 tst: l 1.175 a 0.660  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.921sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8 tr: l 1.058 a 0.707  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.230686 cl_acc 1.000 137.306sec(train) 4.964sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8 tst: l 1.124 a 0.675  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.954sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9 tr: l 1.023 a 0.722  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.228379 cl_acc 1.000 130.660sec(train) 4.848sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9 tst: l 1.107 a 0.688  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.954sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10 tr: l 0.957 a 0.749  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.226096 cl_acc 1.000 129.504sec(train) 4.853sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10 tst: l 1.087 a 0.695  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.935sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11 tr: l 0.983 a 0.740  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.223835 cl_acc 1.000 135.026sec(train) 4.666sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11 tst: l 1.086 a 0.699  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.902sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12 tr: l 0.914 a 0.767  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.221596 cl_acc 1.000 169.043sec(train) 4.838sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12 tst: l 1.085 a 0.707  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.945sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13 tr: l 0.935 a 0.757  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.219380 cl_acc 1.000 233.860sec(train) 5.614sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13 tst: l 1.074 a 0.707  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.153sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14 tr: l 0.879 a 0.780  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.217186 cl_acc 1.000 227.384sec(train) 4.369sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14 tst: l 1.041 a 0.719  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.863sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15 tr: l 0.880 a 0.783  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.215015 cl_acc 1.000 129.299sec(train) 4.524sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15 tst: l 1.040 a 0.724  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.906sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16 tr: l 0.829 a 0.800  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.212864 cl_acc 1.000 134.321sec(train) 4.825sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16 tst: l 1.035 a 0.726  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.993sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17 tr: l 0.857 a 0.788  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.210736 cl_acc 1.000 131.263sec(train) 4.928sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17 tst: l 1.031 a 0.729  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.922sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18 tr: l 0.876 a 0.782  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.208628 cl_acc 1.000 131.932sec(train) 4.513sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18 tst: l 1.052 a 0.726  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.879sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19 tr: l 0.837 a 0.799  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.206542 cl_acc 1.000 148.281sec(train) 4.642sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19 tst: l 1.039 a 0.729  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.894sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20 tr: l 0.833 a 0.800  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.204477 cl_acc 1.000 128.804sec(train) 4.543sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20 tst: l 1.040 a 0.732  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.911sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21 tr: l 0.797 a 0.813  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.202432 cl_acc 1.000 127.319sec(train) 4.485sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21 tst: l 1.008 a 0.740  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.847sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22 tr: l 0.803 a 0.812  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.200408 cl_acc 1.000 122.890sec(train) 4.379sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22 tst: l 1.020 a 0.739  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.843sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23 tr: l 0.820 a 0.804  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.198404 cl_acc 1.000 195.309sec(train) 7.150sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23 tst: l 1.006 a 0.743  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.275sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24 tr: l 0.788 a 0.817  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.196420 cl_acc 1.000 272.130sec(train) 6.827sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24 tst: l 1.026 a 0.739  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.416sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25 tr: l 0.766 a 0.824  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.194455 cl_acc 1.000 145.822sec(train) 4.672sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25 tst: l 1.011 a 0.744  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.911sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 26 tr: l 0.780 a 0.819  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.192511 cl_acc 1.000 130.632sec(train) 4.311sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 26 tst: l 0.986 a 0.748  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.836sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 27 tr: l 0.779 a 0.820  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.190586 cl_acc 1.000 129.321sec(train) 4.708sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 27 tst: l 1.005 a 0.746  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.907sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 28 tr: l 0.772 a 0.823  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.188680 cl_acc 1.000 126.422sec(train) 4.634sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 28 tst: l 1.007 a 0.748  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.869sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 29 tr: l 0.792 a 0.813  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.186793 cl_acc 1.000 124.687sec(train) 4.492sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 29 tst: l 1.010 a 0.751  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.893sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 30 tr: l 0.748 a 0.828  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.184925 cl_acc 1.000 143.734sec(train) 4.365sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 30 tst: l 0.968 a 0.755  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.874sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 31 tr: l 0.765 a 0.821  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.183076 cl_acc 1.000 125.622sec(train) 4.627sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 31 tst: l 0.978 a 0.755  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.867sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 32 tr: l 0.741 a 0.831  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.181245 cl_acc 1.000 132.261sec(train) 4.342sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 32 tst: l 0.974 a 0.756  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.896sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 33 tr: l 0.716 a 0.839  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.179433 cl_acc 1.000 234.423sec(train) 5.823sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 33 tst: l 0.974 a 0.755  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.057sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 34 tr: l 0.705 a 0.844  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.177638 cl_acc 1.000 257.933sec(train) 7.281sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 34 tst: l 0.967 a 0.758  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.967sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 35 tr: l 0.713 a 0.840  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.175862 cl_acc 1.000 126.428sec(train) 4.773sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 35 tst: l 0.960 a 0.762  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.981sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 36 tr: l 0.705 a 0.842  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.174103 cl_acc 1.000 135.633sec(train) 4.342sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 36 tst: l 0.972 a 0.759  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.820sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 37 tr: l 0.724 a 0.836  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.172362 cl_acc 1.000 133.191sec(train) 4.637sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 37 tst: l 0.953 a 0.760  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.852sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 38 tr: l 0.711 a 0.837  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.170639 cl_acc 1.000 130.481sec(train) 4.699sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 38 tst: l 0.942 a 0.764  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.934sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 39 tr: l 0.680 a 0.847  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.168932 cl_acc 1.000 125.130sec(train) 4.031sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 39 tst: l 0.955 a 0.763  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.830sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 40 tr: l 0.694 a 0.844  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.167243 cl_acc 1.000 125.491sec(train) 4.321sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 40 tst: l 0.938 a 0.764  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.856sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 41 tr: l 0.690 a 0.847  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.165571 cl_acc 1.000 123.656sec(train) 4.657sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 41 tst: l 0.930 a 0.767  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.955sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 42 tr: l 0.666 a 0.853  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.163915 cl_acc 1.000 125.953sec(train) 3.996sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 42 tst: l 0.937 a 0.766  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.821sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 43 tr: l 0.663 a 0.856  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.162276 cl_acc 1.000 129.868sec(train) 4.050sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 43 tst: l 0.926 a 0.769  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.835sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 44 tr: l 0.670 a 0.851  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.160653 cl_acc 1.000 227.197sec(train) 6.385sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 44 tst: l 0.933 a 0.769  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.259sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 45 tr: l 0.647 a 0.860  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.159046 cl_acc 1.000 247.391sec(train) 6.047sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 45 tst: l 0.939 a 0.768  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.236sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 46 tr: l 0.655 a 0.858  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.157456 cl_acc 1.000 168.871sec(train) 4.606sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 46 tst: l 0.938 a 0.767  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.914sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 47 tr: l 0.653 a 0.857  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.155881 cl_acc 1.000 132.451sec(train) 4.338sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 47 tst: l 0.932 a 0.769  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.849sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 48 tr: l 0.638 a 0.860  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.154323 cl_acc 1.000 131.856sec(train) 4.392sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 48 tst: l 0.924 a 0.771  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.902sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 49 tr: l 0.650 a 0.857  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.152779 cl_acc 1.000 129.332sec(train) 4.635sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 49 tst: l 0.923 a 0.772  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.850sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 50 tr: l 0.641 a 0.861  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.151252 cl_acc 1.000 130.095sec(train) 4.210sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 50 tst: l 0.930 a 0.772  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.868sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 51 tr: l 0.642 a 0.858  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.149739 cl_acc 1.000 140.287sec(train) 4.231sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 51 tst: l 0.918 a 0.775  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.937sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 52 tr: l 0.617 a 0.868  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.148242 cl_acc 1.000 133.601sec(train) 4.500sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 52 tst: l 0.937 a 0.773  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.888sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 53 tr: l 0.606 a 0.870  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.146759 cl_acc 1.000 147.842sec(train) 4.382sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 53 tst: l 0.914 a 0.778  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.873sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 54 tr: l 0.651 a 0.855  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.145292 cl_acc 1.000 248.584sec(train) 6.313sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 54 tst: l 0.910 a 0.776  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.349sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 55 tr: l 0.618 a 0.864  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.143839 cl_acc 1.000 246.349sec(train) 6.885sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 55 tst: l 0.887 a 0.777  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.573sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 56 tr: l 0.612 a 0.866  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.142400 cl_acc 1.000 148.772sec(train) 4.616sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 56 tst: l 0.914 a 0.776  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.896sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 57 tr: l 0.605 a 0.869  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.140976 cl_acc 1.000 131.463sec(train) 5.591sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 57 tst: l 0.909 a 0.776  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.118sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 58 tr: l 0.600 a 0.871  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.139567 cl_acc 1.000 149.542sec(train) 4.398sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 58 tst: l 0.899 a 0.779  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.849sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 59 tr: l 0.582 a 0.876  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.138171 cl_acc 1.000 130.767sec(train) 4.509sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 59 tst: l 0.907 a 0.777  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.903sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 60 tr: l 0.586 a 0.876  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.136789 cl_acc 1.000 127.305sec(train) 4.386sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 60 tst: l 0.886 a 0.780  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.862sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 61 tr: l 0.615 a 0.866  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.135421 cl_acc 1.000 127.685sec(train) 4.163sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 61 tst: l 0.894 a 0.781  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.888sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 62 tr: l 0.585 a 0.875  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.134067 cl_acc 1.000 130.686sec(train) 4.331sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 62 tst: l 0.900 a 0.777  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.805sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 63 tr: l 0.562 a 0.883  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.132726 cl_acc 1.000 125.800sec(train) 4.544sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 63 tst: l 0.897 a 0.778  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.863sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 64 tr: l 0.584 a 0.874  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.131399 cl_acc 1.000 206.911sec(train) 5.891sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 64 tst: l 0.882 a 0.785  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.159sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 65 tr: l 0.577 a 0.877  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.130085 cl_acc 1.000 248.051sec(train) 5.382sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 65 tst: l 0.867 a 0.785  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.057sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 66 tr: l 0.562 a 0.882  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.128784 cl_acc 1.000 175.722sec(train) 4.156sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 66 tst: l 0.868 a 0.786  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.879sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 67 tr: l 0.564 a 0.880  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.127496 cl_acc 1.000 140.011sec(train) 4.673sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 67 tst: l 0.876 a 0.785  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.874sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 68 tr: l 0.551 a 0.884  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.126221 cl_acc 1.000 128.721sec(train) 4.579sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 68 tst: l 0.875 a 0.785  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.889sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 69 tr: l 0.544 a 0.885  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.124959 cl_acc 1.000 130.343sec(train) 4.633sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 69 tst: l 0.869 a 0.786  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.922sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 70 tr: l 0.559 a 0.883  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.123710 cl_acc 1.000 121.853sec(train) 4.457sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 70 tst: l 0.868 a 0.785  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.865sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 71 tr: l 0.568 a 0.878  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.122473 cl_acc 1.000 126.341sec(train) 4.468sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 71 tst: l 0.890 a 0.783  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.881sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 72 tr: l 0.541 a 0.887  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.121248 cl_acc 1.000 124.808sec(train) 4.666sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 72 tst: l 0.873 a 0.785  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.885sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 73 tr: l 0.583 a 0.873  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.120035 cl_acc 1.000 143.638sec(train) 4.517sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 73 tst: l 0.859 a 0.791  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.849sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 74 tr: l 0.550 a 0.881  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.118835 cl_acc 1.000 200.015sec(train) 5.680sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 74 tst: l 0.857 a 0.788  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.015sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 75 tr: l 0.541 a 0.885  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.117647 cl_acc 1.000 234.300sec(train) 5.824sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 75 tst: l 0.863 a 0.789  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.173sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 76 tr: l 0.536 a 0.885  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.116470 cl_acc 1.000 174.620sec(train) 4.585sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 76 tst: l 0.861 a 0.789  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.890sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 77 tr: l 0.543 a 0.882  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.115305 cl_acc 1.000 135.840sec(train) 4.156sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 77 tst: l 0.855 a 0.792  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.815sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 78 tr: l 0.522 a 0.892  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.114152 cl_acc 1.000 132.815sec(train) 4.303sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 78 tst: l 0.881 a 0.787  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.844sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 79 tr: l 0.517 a 0.893  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.113011 cl_acc 1.000 127.598sec(train) 4.380sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 79 tst: l 0.848 a 0.789  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.995sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 80 tr: l 0.525 a 0.889  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.111881 cl_acc 1.000 121.912sec(train) 4.711sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 80 tst: l 0.874 a 0.787  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.910sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 81 tr: l 0.534 a 0.885  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.110762 cl_acc 1.000 124.718sec(train) 4.155sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 81 tst: l 0.849 a 0.789  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.831sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 82 tr: l 0.519 a 0.891  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.109654 cl_acc 1.000 126.081sec(train) 4.368sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 82 tst: l 0.856 a 0.791  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.852sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 83 tr: l 0.497 a 0.899  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.108558 cl_acc 1.000 122.901sec(train) 4.339sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 83 tst: l 0.834 a 0.793  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.874sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 84 tr: l 0.524 a 0.888  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.107472 cl_acc 1.000 155.761sec(train) 5.423sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 84 tst: l 0.830 a 0.795  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.034sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 85 tr: l 0.523 a 0.889  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.106398 cl_acc 1.000 252.992sec(train) 8.727sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 85 tst: l 0.840 a 0.794  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.298sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 86 tr: l 0.503 a 0.893  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.105334 cl_acc 1.000 224.796sec(train) 4.606sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 86 tst: l 0.837 a 0.795  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.889sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 87 tr: l 0.529 a 0.885  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.104280 cl_acc 1.000 138.101sec(train) 4.443sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 87 tst: l 0.840 a 0.792  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.892sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 88 tr: l 0.504 a 0.893  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.103237 cl_acc 1.000 134.527sec(train) 4.792sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 88 tst: l 0.832 a 0.796  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.966sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 89 tr: l 0.543 a 0.878  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.102205 cl_acc 1.000 134.006sec(train) 4.738sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 89 tst: l 0.822 a 0.799  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.939sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 90 tr: l 0.503 a 0.893  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.101183 cl_acc 1.000 136.708sec(train) 4.741sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 90 tst: l 0.827 a 0.800  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.903sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 91 tr: l 0.501 a 0.895  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.100171 cl_acc 1.000 135.788sec(train) 4.460sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 91 tst: l 0.839 a 0.794  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.796sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 92 tr: l 0.477 a 0.901  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.099169 cl_acc 1.000 131.090sec(train) 4.558sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 92 tst: l 0.829 a 0.797  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.869sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 93 tr: l 0.477 a 0.902  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.098178 cl_acc 1.000 130.213sec(train) 4.837sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 93 tst: l 0.844 a 0.794  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.964sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 94 tr: l 0.500 a 0.893  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.097196 cl_acc 1.000 220.868sec(train) 6.584sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 94 tst: l 0.836 a 0.795  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.237sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 95 tr: l 0.469 a 0.904  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.096224 cl_acc 1.000 227.644sec(train) 6.031sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 95 tst: l 0.840 a 0.795  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.176sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 96 tr: l 0.497 a 0.893  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.095262 cl_acc 1.000 155.775sec(train) 5.169sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 96 tst: l 0.845 a 0.797  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.045sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 97 tr: l 0.476 a 0.899  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.094309 cl_acc 1.000 130.153sec(train) 4.580sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 97 tst: l 0.816 a 0.800  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.911sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 98 tr: l 0.484 a 0.896  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.093366 cl_acc 1.000 139.203sec(train) 5.070sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 98 tst: l 0.825 a 0.797  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.975sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 99 tr: l 0.472 a 0.903  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.092432 cl_acc 1.000 129.112sec(train) 4.491sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 99 tst: l 0.836 a 0.796  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.036sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 100 tr: l 0.468 a 0.901  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.091508 cl_acc 1.000 128.140sec(train) 4.433sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 100 tst: l 0.837 a 0.795  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.880sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 101 tr: l 0.443 a 0.911  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.090593 cl_acc 1.000 131.868sec(train) 5.283sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 101 tst: l 0.820 a 0.800  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.022sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 102 tr: l 0.483 a 0.898  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.089687 cl_acc 1.000 141.242sec(train) 5.032sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 102 tst: l 0.818 a 0.798  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.996sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 103 tr: l 0.476 a 0.898  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.088790 cl_acc 1.000 154.918sec(train) 5.815sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 103 tst: l 0.816 a 0.799  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.147sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 104 tr: l 0.489 a 0.893  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.087902 cl_acc 1.000 234.050sec(train) 6.943sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 104 tst: l 0.819 a 0.798  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.375sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 105 tr: l 0.470 a 0.900  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.087023 cl_acc 1.000 226.904sec(train) 4.392sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 105 tst: l 0.812 a 0.801  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.872sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 106 tr: l 0.472 a 0.900  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.086153 cl_acc 1.000 139.303sec(train) 4.755sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 106 tst: l 0.808 a 0.800  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.963sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 107 tr: l 0.445 a 0.908  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.085292 cl_acc 1.000 134.690sec(train) 4.679sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 107 tst: l 0.809 a 0.801  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.930sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 108 tr: l 0.447 a 0.907  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.084439 cl_acc 1.000 152.903sec(train) 4.587sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 108 tst: l 0.814 a 0.802  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.904sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 109 tr: l 0.468 a 0.899  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.083594 cl_acc 1.000 122.093sec(train) 3.957sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 109 tst: l 0.804 a 0.803  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.787sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 110 tr: l 0.446 a 0.908  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.082758 cl_acc 1.000 122.801sec(train) 4.503sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 110 tst: l 0.820 a 0.798  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.934sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 111 tr: l 0.434 a 0.910  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.081931 cl_acc 1.000 141.166sec(train) 4.815sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 111 tst: l 0.805 a 0.802  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.106sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 112 tr: l 0.428 a 0.912  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.081111 cl_acc 1.000 120.947sec(train) 4.484sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 112 tst: l 0.810 a 0.800  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.918sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 113 tr: l 0.451 a 0.904  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.080300 cl_acc 1.000 213.246sec(train) 6.555sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 113 tst: l 0.808 a 0.802  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.453sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 114 tr: l 0.456 a 0.904  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.079497 cl_acc 1.000 234.961sec(train) 6.662sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 114 tst: l 0.803 a 0.802  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.223sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 115 tr: l 0.455 a 0.904  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.078702 cl_acc 1.000 169.698sec(train) 4.490sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 115 tst: l 0.789 a 0.802  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.029sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 116 tr: l 0.428 a 0.912  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.077915 cl_acc 1.000 137.039sec(train) 4.737sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 116 tst: l 0.795 a 0.804  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.986sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 117 tr: l 0.447 a 0.905  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.077136 cl_acc 1.000 145.644sec(train) 4.502sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 117 tst: l 0.800 a 0.805  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.897sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 118 tr: l 0.429 a 0.910  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.076365 cl_acc 1.000 156.835sec(train) 6.932sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 118 tst: l 0.779 a 0.808  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.401sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 119 tr: l 0.422 a 0.913  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.075601 cl_acc 1.000 129.834sec(train) 4.801sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 119 tst: l 0.790 a 0.803  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.906sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 120 tr: l 0.450 a 0.903  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.074845 cl_acc 1.000 140.531sec(train) 4.351sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 120 tst: l 0.784 a 0.805  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.846sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 121 tr: l 0.418 a 0.913  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.074097 cl_acc 1.000 149.096sec(train) 4.490sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 121 tst: l 0.792 a 0.805  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.862sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 122 tr: l 0.427 a 0.910  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.073356 cl_acc 1.000 221.230sec(train) 6.686sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 122 tst: l 0.781 a 0.804  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.191sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 123 tr: l 0.428 a 0.908  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.072622 cl_acc 1.000 256.289sec(train) 5.605sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 123 tst: l 0.794 a 0.804  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.119sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 124 tr: l 0.421 a 0.911  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.071896 cl_acc 1.000 153.058sec(train) 4.840sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 124 tst: l 0.781 a 0.805  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.913sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 125 tr: l 0.431 a 0.909  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.071177 cl_acc 1.000 140.453sec(train) 4.496sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 125 tst: l 0.769 a 0.805  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.872sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 126 tr: l 0.435 a 0.906  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.070465 cl_acc 1.000 157.994sec(train) 4.773sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 126 tst: l 0.786 a 0.804  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.940sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 127 tr: l 0.401 a 0.917  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.069761 cl_acc 1.000 154.500sec(train) 4.417sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 127 tst: l 0.780 a 0.805  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.871sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 128 tr: l 0.410 a 0.915  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.069063 cl_acc 1.000 154.195sec(train) 4.472sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 128 tst: l 0.777 a 0.807  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.862sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 129 tr: l 0.407 a 0.916  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.068372 cl_acc 1.000 157.104sec(train) 4.799sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 129 tst: l 0.789 a 0.803  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.916sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 130 tr: l 0.420 a 0.910  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.067689 cl_acc 1.000 187.748sec(train) 6.579sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 130 tst: l 0.783 a 0.806  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.392sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 131 tr: l 0.436 a 0.905  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.067012 cl_acc 1.000 249.864sec(train) 6.750sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 131 tst: l 0.786 a 0.804  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.079sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 132 tr: l 0.409 a 0.914  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.066342 cl_acc 1.000 218.505sec(train) 4.567sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 132 tst: l 0.781 a 0.807  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.938sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 133 tr: l 0.402 a 0.916  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.065678 cl_acc 1.000 143.857sec(train) 4.966sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 133 tst: l 0.791 a 0.803  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.909sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 134 tr: l 0.377 a 0.925  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.065021 cl_acc 1.000 144.841sec(train) 4.796sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 134 tst: l 0.778 a 0.808  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.908sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 135 tr: l 0.398 a 0.917  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.064371 cl_acc 1.000 150.440sec(train) 4.578sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 135 tst: l 0.791 a 0.804  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.986sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 136 tr: l 0.412 a 0.911  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.063727 cl_acc 1.000 143.370sec(train) 4.397sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 136 tst: l 0.772 a 0.808  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.862sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 137 tr: l 0.432 a 0.905  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.063090 cl_acc 1.000 141.593sec(train) 4.460sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 137 tst: l 0.778 a 0.807  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.868sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 138 tr: l 0.406 a 0.914  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.062459 cl_acc 1.000 148.219sec(train) 4.785sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 138 tst: l 0.768 a 0.809  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.944sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 139 tr: l 0.421 a 0.909  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.061835 cl_acc 1.000 218.481sec(train) 15.572sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 139 tst: l 0.770 a 0.807  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 3.095sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 140 tr: l 0.389 a 0.919  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.061216 cl_acc 1.000 238.011sec(train) 5.924sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 140 tst: l 0.772 a 0.810  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.082sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 141 tr: l 0.362 a 0.928  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.060604 cl_acc 1.000 152.928sec(train) 5.020sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 141 tst: l 0.766 a 0.811  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.944sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 142 tr: l 0.387 a 0.919  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.059998 cl_acc 1.000 141.552sec(train) 4.405sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 142 tst: l 0.779 a 0.808  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.906sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 143 tr: l 0.395 a 0.916  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.059398 cl_acc 1.000 127.965sec(train) 4.704sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 143 tst: l 0.774 a 0.808  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.913sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 144 tr: l 0.377 a 0.922  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.058804 cl_acc 1.000 130.100sec(train) 4.541sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 144 tst: l 0.756 a 0.811  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.867sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 145 tr: l 0.380 a 0.920  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.058216 cl_acc 1.000 151.690sec(train) 4.580sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 145 tst: l 0.768 a 0.810  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.895sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 146 tr: l 0.381 a 0.921  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.057634 cl_acc 1.000 128.189sec(train) 4.561sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 146 tst: l 0.768 a 0.809  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.896sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 147 tr: l 0.392 a 0.917  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.057058 cl_acc 1.000 152.797sec(train) 4.702sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 147 tst: l 0.758 a 0.812  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 0.947sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 148 tr: l 0.371 a 0.924  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.056487 cl_acc 1.000 220.723sec(train) 5.985sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 148 tst: l 0.768 a 0.808  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.282sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 149 tr: l 0.395 a 0.914  clct[np.int64(25), np.int64(25)] ans[np.int64(25), np.int64(25)] lr 0.055922 cl_acc 1.000 239.482sec(train) 9.610sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 149 tst: l 0.768 a 0.811  clct[np.int64(5), np.int64(5)] ans[np.int64(5), np.int64(5)] cl_acc 1.000 1.360sec\n",
      "result written at output/results.pickle\n",
      "---train cluster Ended in 6.86 hour (24680.959 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, 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": 5,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-23T06:09:37.312063Z",
     "iopub.status.busy": "2025-09-23T06:09:37.311801Z",
     "iopub.status.idle": "2025-09-23T06:09:37.957723Z",
     "shell.execute_reply": "2025-09-23T06:09:37.956293Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Average Test Loss (Last Epoch): 0.7495\n",
      "Average Test Accuracy (Last Epoch): 0.8150\n",
      "Average Cluster Accuracy (Last Epoch): 1.0000\n",
      "Average Standard Deviation (Last Epoch): 0.0000\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA1YAAAH3CAYAAAC4g84JAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjMsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvZiW1igAAAAlwSFlzAAAPYQAAD2EBqD+naQAAcDxJREFUeJzt3Xd8U/Xi//F3uncpLVA2BUGmICAORFBQQcWJ4gb1KvAT3KioV+DqxYVbtopeF+IWuCiXKaLIkqmAQtlQVndL5/n9cb5JG5J0JW2S9vV8PM4j6Vn55HNSyLufcSyGYRgCAAAAAFRZgLcLAAAAAAD+jmAFAAAAAG4iWAEAAACAmwhWAAAAAOAmghUAAAAAuIlgBQAAAABuIlgBAAAAgJsIVgAAAADgJoIVAAAAALiJYAUAACqkVatWslgsdsuECRO8Vp4ffvjBoTzr16932G/48OEO+/Xr16/mC4wadejQIYWFhdld9ylTpni7WKjFCFZAJTn7YuHOMnz4cG+/Jac2btyoCRMmOCye9MEHHzitkw8++MCjrwNIcuv31JvhAc7l5+frgQcesFs3cOBA9ejRw0sl8o6dO3dqwoQJOv/889WkSROFhoYqISFBXbp00ejRo7V8+fJqed0TJ07oq6++0hNPPKFBgwbpzDPPVL169RQcHKzIyEg1bdpU/fv317PPPqu//vqrQufs169flX4/n3nmGafna9KkicP/sf/85z91/Phxd98+4FSQtwsAwDdt3LhREydOdFjPF0wAvmD69OkOX9iffvppL5Wm5uXn5+uJJ57QO++8o8LCQrttJ06c0IkTJ7R161ZNmTJFgwYN0qxZs9S0aVOPvPYDDzygKVOmqLi42On2wsJC5eTk6NChQ1q6dKmef/553XfffXr11VcVGRnpkTJU1BNPPKH33nvPVkepqan697//rddff71Gy4G6gRYrAADgV3Jzc/Xvf//bbt3555+vCy+80EslqlmnTp3StddeqzfeeMMhVDmzcOFCXXTRRdqzZ49HXn/fvn0uQ5UzhmFoxowZGjRokPLy8jxShopKSkrSjTfeaLdu2rRpOnjwYI2WA3UDLVZAJZ111llKSEhwuu3QoUM6fPiww/p27dopOjra6TFJSUkeLR+AiouKitKZZ55Z7n5NmjSpgdKgombPnq2jR4/arbvzzju9VJqa98wzz2jhwoUO68PDw9W6dWsdPnxYJ0+etNu2e/du3Xzzzfrll18UEOD5v6vHx8crMTHR6WtbrVy5Ui+++KLGjx9foXOGhISoS5cu5e5XXkvcHXfcoc8++8z2c15ent566y299NJLFSoHUFEEK6CSvv/+e5fbJkyY4LT73IwZMxgoDfigHj16VNsYFFSft99+2+7n4OBgh1aJ2mrr1q164403HNZfccUV+uSTT1SvXj0VFhbq+eefd/j/6LffftOMGTM0atQoj5SlRYsWGjlypK677jq1b9/etn7dunUaOXKk04lEpk+frn/+858VCneNGzfWunXr3C7npZdeqgYNGujYsWO2dTNnztTEiRMVFhbm9vkBK7oCAj4iNTVVb775pq677jolJSUpJiZGoaGhatKkifr166d//etfOnToUIXO9ddff+nZZ59Vv3791LRpU0VGRio4OFiNGjVSx44ddfHFF2v06NH64IMPtGvXLrtjrYOB77rrLqfn9peB/T/88INGjRqlbt26qWHDhgoJCVG9evV0xhln6MYbb9SMGTOUnZ1doXOtWLFC999/v3r16qUGDRooLCxMYWFhatq0qbp27aorrrhCTz75pL755psyB0W7c10qa/ny5U6vlbUr0KJFizR06FC1aNFCYWFhatSokQYOHKjPP/+8wq9RUFCgzz77TMOHD1fHjh0VHx+v4OBgNWjQQN27d9fDDz/s9IvV6cqaaW779u0aM2aM2rdvr+joaJ/6vE2YMMGh3K1atZIkFRUV6d1331X//v2VmJiosLAwtWjRQnfccYd+++23Cr9GSkqKXn75ZV155ZVq1aqVoqOjFRoaqsaNG+u8887To48+WukvnmlpaZoyZYpuuukmtW3bVvXr11dISIgSExPVtWtXDRkyRG+99ZYOHDhQqfOeOHFCEydO1Nlnn63Y2FhFRkaqY8eOGjt2rEPrkjtWr16t7du326277LLLFB8f7/a59+zZ4/T3xhq+//e//+nmm29Wy5YtbbPN1XQwnzZtmoqKiuzWRUZG6qOPPlK9evUkSUFBQZowYYLOO+88h+M9MSteYmKiZsyYod27d2vcuHF2oUqSevbsqcWLF6thw4YOxx45ckS7d+92uwyVERQU5BC809LS9O2339ZoOVAHGAA8Zvz48YYkh2XZsmUujykqKjImTZpkREZGOj229BIaGmqMHz/eKCoqcnm+Z5991ggMDCz3XKWX0ipznHUZP358lepr9uzZTs83e/bsKp3PMAxjw4YNxllnnVWhcsfFxRmzZs1yea7MzEzj6quvrlRd9O3b1+m53L0ulbVs2TKn59yxY4dx++23l/m6l112mZGZmVnm+efNm2c0a9asQu9jyJAhRlpamstztWzZ0ulnasaMGUZoaKjHPm+VuV4V4ez3vWXLlsb+/fuN7t27u6wPi8VijBs3rsxzFxQUGOPGjXP6/p0tl19+uXHw4MFyzzl+/HgjIiKiQuccNmyYwzlcXav//ve/RoMGDVyeq2HDhsbmzZurXNelPfzwww7nf/3118s8ZtiwYRW69snJyU7Lv2TJEuMf//iH021l/fvuacXFxUb9+vUdynDDDTc43f+tt95yWuZNmzbVSHlHjBjh9PV//fVXp/v37dvX4ffJU77++usK1xtQVXQFBLyoqKhIN9xwg7777rsK7Z+Xl6eJEydq69atmjt3rkNXig8//FD/+te/qqOofuG///2vrr/++goPjk5NTdW9996rzZs366233nLYPmbMmDK7flaUL12XYcOGafXq1WXus2jRIl111VVaunSp0+46r7zyih5//PEKv+aXX36pzZs3a9WqVS7HJ55u3rx5+v3332UYRoVfxxdkZWXpkksuKXN6acMw9MILLygwMFDPPfecw/b8/HxdccUVWrJkSYVf98cff1S3bt30008/ObQeSOZkD4MGDdKKFSsqfM6KWrRokSZNmqSCggKX+xw9elQ33XSTNm/erODgYLdez9nYonPPPdetc5bniSeeqFDL4Pz58z3WotqjRw/NmDHDbt1ff/3ldPySqynme/bs6XT9b7/9prPOOsv9QpYjJibG6frGjRtX6Pjjx4/rwgsv1Pbt25Wenq6oqCg1bNhQPXr00JVXXqkbb7xRISEhFTqXs8/IokWLVFhYqKAgvg7DM/gkAV40duxYp6EqMDBQzZo1U3h4uPbs2aNTp07Zbf/qq680ceJEh/7z77zzjtPXady4sRo0aKC8vDwdPXpUqampLstk/Q/6xIkTTmeQcvYfuC8M7P/rr780dOhQp6EqMjJSSUlJOn78uI4cOeKw/e2331bHjh01cuRI27q0tDR98sknDvtau3vFxMQoOztbBw8eVG5ubpll88R18RRrqIqMjFTr1q2VkpLitJvWihUr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+zqd7GHWrFlO9//kk08c7g0mOY47cVWfgYGBatmypa677jqHe4lJ5uQBFTmPVPnr4q7333/f6foPPvjA6foLLrjA9tzZZ3br1q12Y8XKsn37dv3xxx8V2tefVaaOg4KC7O5j5Wzs08aNG53enDY/P18fffSRw/ozzjjDLqw5u8fPb7/9Vu6NyZ39jnibszGCu3btcnvslr+wWCy65ZZbHNb/+OOPTkPDZ5995rCuc+fOTsf7DR8+XBaLxW7p16+fy7KkpaVp4MCBTkPVmDFj9M0331QqVL399tsuJ8gp7eeff7abVMeqTZs25bYsbt261WEd97CCJxGsAC+56667HMLAkSNHNGDAAP34448OA3Ozs7P1888/6+mnn9aZZ56p/v37O8ywdc0112jQoEGaPn26duzY4dDlKi8vz+XNak+fAS8uLs7pfvPmzavQ+6tJsbGxTmc4W7BggcaNG2f3BXH+/Pm2lqfS4uPjdfXVV9utS0xM1LBhw/T555/r0KFDDsecPHlSs2fPdlh/el168rq4a/ny5Xr00UdtdWIYhj7//HP9+9//dti3UaNGdoP2+/fv7/Svu9dcc43ef/99hy/iBQUF2rx5s1577TX16dNHHTp0cHrD0Npm0qRJ+uSTT2y/w3l5eXriiSecthINHjzYbpa04cOHO22hvOmmm/T777/bfj558qRuvfVWpzfivfvuu+1+HjFihNNy3nzzzXrjjTccgv+ff/6pRx55RA8++GAZ79I7EhISHCaIKSgosKub2m7kyJEO/3dkZ2frjjvusI2pKyws1Pjx4203BC/t/vvvd7sM+/bt04UXXqhly5bZrQ8ICNBrr72mt956q9It7evXr9ell16qHj16aMqUKQ6f7VOnTumNN97Q4MGDnc52OGTIkDLPf/DgQYcbjEdFRbmcVAaokhqa1h2oEypzHyvDMIwHH3zQ5X05IiIijLZt2xqdO3c2mjZtalgsFod9kpOT7c53+j1AQkJCjKSkJKNr165G+/btjcjISKev1aZNG4eyHThwwGXZWrVqZfTo0cO2lL6JbGW4uufL6ed3tXz66ae2c+3YscPl+4uKijK6dOliNG7c2OV7mjJlikP5Tt8nOjraaNu2rdGtWzejTZs2Tm/wLMm45557qu26VFRZNwguXSeNGjVyuc/kyZMdzvv111+73D84ONho0aKF0bVr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7tSpU1qyZImWLFmiu+66SxdddJFHXuuTTz7RiBEjlJ2dbbc+LS1Na9as0Zo1azR37lyHKd3vu+8+ffjhhw7nO3nypO24d955R99995169+7tkbJWB4KVr4uIMIMVLVYAAACohIyMDF1++eW2UDV06FANGzZMDRs21M6dO/Xaa69p9uzZ2rp1q8Oxs2fPVnZ2tr777js988wzkqQff/xRTZo0se2TlJRke/7RRx/pzjvvlCSFhYXp3nvv1aBBg5SYmKisrCxt3rxZ33//vf766y+H1yosLFTr1q113XXXqVevXmrRooWCgoK0d+9eLV68WO+//75OnDih6667Tlu3blXDhg09Wk+eQrDyddzLCgAAAFXw3HPPaf/+/ZKkSZMmady4cbZtPXr00JAhQ3TVVVdp0aJFDsdaQ9O6dets69q1a6dWrVo57Hv48GGNHDlSktSwYUMtWbJEnTt3ttunT58+uv/++23lKW3ixIlq3bq1LBaL3fqePXvqhhtu0P/7f/9PF1xwgY4dO6a3335bzz33XAVroGYRrHwd97ICAAB1jWHUje8+ERHSaWHCU/Lz8/Xee+9Jks466yw9+eSTDvsEBwfrvffeU+vWrVVQUFDl13r77beV83/Xa+bMmQ6hqrTmzZs7rGvTpk2Z5+/SpYv+8Y9/6I033tC3335LsEIVcS8rAABQ1+TkSFFR3i5F9cvKkiIjq+XU69evV2pqqiRp2LBhDq1BVs2aNdNll12mBQsWVPm15s+fL0lq3bq1rr766iqfxyo1NVUnT57UqVOnZBiGJKlevXqSpD/++EMFBQU+OUMhwcrXWVus6AoIAACACtqyZYvt+TnnnFPmvr169apysCooKLCN0brwwgtdBrjybNmyRa+//roWLlyoI0eOuNyvuLhYqampPjnOimDl6+gKCAAA6pqICLM1p7Yrfc9SDzt58qTteXkhpFGjRm69jrVVqXHjxlU6x3vvvaeRI0eqsLCwQvvn+miDA8HK19EVEAAA1DUWS7V1kauLqtqKVBO2b99uC1UNGzbU2LFjdckll6hVq1aKjo62dfl7//33dc8990iSLcj5GoKVr6MrIAAAACopLi7O9jwlJUXt2rVzuW9KSkqVX6d+/foKCAhQcXGxDh8+XOnjP/jgAxUWFiowMFArVqxQ+/btne5XugXOVwV4uwAoB10BAQAAUEld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57zxxhuGJOO2224zxo8fX2awot6rLjs722jdurUhyRgzZkyljqXeq65fv36GJOOMM84wCgoKHLbn5+fbrsvNN99st416d81Zq0bLli0r9EXzmWeesbUcnv5HBMMwjEmTJhmSjMDAQFtoKu322283JBmJiYlGamqqw/b77rvP1opV21oTq1rvaWlpxvr1611uLy4uNgYOHGhrDcnNzXXYx93r5s/c+byf7qGHHjIkGU8//bQxbNiwcoNVXa53TyJY+ZA+ffoYkoyLL77Y6fbi4mIjKSnJkGTceeedNVy62mvNmjUu/5LMNfEM619+4+PjjaNHj5YbrKj3qps+fbrty6CzLy1lod6r7swzzzQkGTfccIPLfa6//npDknHVVVfZrafeK6eiXzRbtGhh667nTGZmphEVFWVIMp599lm7bVlZWbZW34kTJzo93to6I8l4//33q/Re/ElVv+Cfbu7cubZ627Bhg8N2d65bbVSVev/111+NgIAAo127dkZubm6FghX17hlMXuEjcnJytGrVKknSoEGDnO5jsVg0cOBASdKiRYtqrGy1XVhYmO15UVGR7TnXxHPuvfdeZWdn67XXXlODBg3K3Jd6d89//vMfSdKNN95o99kuD/XuntatW0uSNm3apMLCQoftBQUF2rhxoySpZ8+etvXUe/XYsWOH9u3bJ8l1vUZFRalPnz6SHOv1559/Vm5ubpnHt2rVSh06dHB6PFxz9X+u5P51g5SXl6e7775bhmFo5syZFfp/gHr3HIKVj/jzzz9VXFwsSercubPL/azbjhw5opMnT9ZI2Wq75cuX25536dLF9pxr4hmzZs3SkiVLNGDAAN15553l7k+9V11eXp7WrVsnSerRo4f27dun++67T82bN1dISIgaNWqkwYMHa8GCBQ7HUu/uGTVqlCTp77//1i233KK///7btm3Hjh266aabtHv3brVp00YPP/ywbRv1Xj22bt1qe16Rev3jjz/cOn7btm1VKmddZP0/NyQkRO3atbPb5u51g/Svf/1Lf/75p+655x717du3QsdQ755DsPIRhw4dsj1v2rSpy/1Kbyt9DKomLS1NL7zwgiSpT58+OvPMM23buCbuO3jwoMaOHavw8HDNmDGjQsdQ71W3Z88e27Tcu3fvVufOnTVr1iwdPXpUkZGROnr0qObPn6+rrrpK9957r93UudS7ewYPHqzXX39dISEh+vLLL9W2bVtFREQoIiJC7du31/LlyzVq1CitWbNGMTExtuOo9+pR2XrNyMhQVlaWw/FxcXEKDw8v93iuScUkJydr+vTpkqShQ4fa/S5I7l+3uu7333/Xyy+/rEaNGumVV16p8HHUu+cQrHxEZmam7XlERITL/UpvK30MKq+4uFh33HGHDh8+rLCwML3zzjt227km7hsxYoTS09M1YcIEW1ep8lDvVZeammp7/vzzzys4OFhffPGFsrKylJqaqr179+rGG2+UJL377rt6/fXXbftT7+576KGH9PXXX6thw4aSpNzcXFt3svz8fGVlZSk9Pd3uGOq9erhbr9bnZR1bejvXpHy5ubm68cYblZOTo4SEBL344osO+/D7UHWFhYW6++67VVhYqLfeekv16tWr8LHUu+cQrFBnPfjgg5o/f74kacqUKTrrrLO8XKLa5eOPP9aCBQvUrVs3PfLII94uTp1g7VJmff7ee+9pyJAhCg4OliS1aNFCc+bMUdeuXSVJkyZNcjoeCJWXk5OjoUOH6qqrrlKLFi20aNEiHTt2TMeOHdOiRYvUsWNHffTRR+rVq5c2b97s7eICNaqwsFC33nqr1q9fr+DgYH3yySdq0qSJt4tVq7z44ovauHGjrrrqKt10003eLk6dRbDyEdHR0bbnOTk5Lvcrva30Maicxx57zNZC9frrr+vuu+922IdrUnUpKSl66KGHFBgYqFmzZikoKKjCx1LvVVe6Htq2batrr73WYZ+AgAA99thjkqQTJ05o/fr1DsdS75U3duxYzZ07V2eeeaZWrlypSy+9VAkJCUpISNCll16qn376Se3atdPx48d1//33246j3quHu/VqfV7WsaW3c01cKyoq0m233aZvv/1WQUFB+vTTT3XZZZc53Zffh6r5448/9NxzzykqKkpTp06t9PHUu+cQrHxE6b/cHDx40OV+pbfx156qefzxx/Xqq69KkiZPnqyHHnrI6X5ck6p78skndeLECd13331q3769srKy7BbrOCBJDuuo96or3Te+ffv2Lvfr2LGj7fnevXslUe/uyMzM1MyZMyVJ999/v9NZuMLDwzV69GhJ5oxzR48elUS9V5fK1mtMTIyioqIcjk9NTbV15yzreK6Jc0VFRbr99ts1d+5cBQYG6uOPP9aQIUNc7u/udaur7r//fuXn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",
      "text/plain": [
       "<Figure size 1000x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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vxcjRowQ9evXFz4+PsLe3l6o1WoRFBQk2rdvL15++WXxww8/iPj4eJPlGKtnRe1x0/YoZWdni2+//Va0b99e+Pr6CicnJxEWFibGjh0rLly4YHa9r127JmbMmCG6dOkigoODhbOzs3BychIBAQGiQ4cOYurUqSUqTwhl7/2SPFdl1eMmhBBvvvmmQdnbt283mb6y9bgVduLECfHWW2+JRx99VDzyyCPCwcFB+Pr6ikcffVS89dZbRoclGmPtHjchhEhPTxdbtmwR77zzjujevbuoVauWcHd3132GCA4OFk888YSYPn26uHTpktltNG/ePIM6zJs3z+z8ZFskIR6aPYGIiKgMaDQaRERE6E00oVKpEBUVhRo1aljsOsuXLzfaA81/d5bzwgsvGEyD3qlTJ+zdu9c6FapCbt26hTp16uiNeBg2bJjFZvilyqVNmzY4fPiw7vdHHnkE0dHRFh1NQeWHQyWJiKjM5eXl4YMPPjCYWfGpp56yaNBGVNlVr14d48eP1zv2008/GV3fi6q2ffv26QVtADBt2jQGbRUYAzciIioTv/32G1q0aIEmTZrAz88PM2fONEgzZcqU8q8YUQU3bdo0vfuj8/Ly8Omnn1qxRmSLPvroI73fa9eujZdfftlKtSFLYOBGRERl4v79+zhx4gTOnDljsF4hIK/j1b59eyvUjKhi8/X1xX/+8x+9Y0uXLjW6riZVTSdOnMD27dv1jn311VdwcnKyUo3IEkxPi0ZERFRGHnvsMSxcuNDa1SCqsMaPH28wZJJIq3nz5ryvtxJijxsREZULNzc3tG7dGl9++SX27dtnMK05ERERmcZZJYmIiIiIiGwch0qWM41Gg9u3b8Pd3b3YhSOJiIiIiKjyEkIgNTUVQUFBUKmKHgzJwK2c3b59GyEhIdauBhERERER2YibN2+ievXqRaZh4FbO3N3dAchPDu/vICIiIiKqulJSUhASEqKLEYrCwK2caYdHenh4MHAjIiIiIiKzbqHirJJEREREREQ2joEbERERERGRjWPgRkREREREZOMYuBEREREREdk4Bm5EREREREQ2joEbERERERGRjWPgRkREREREZOMYuBEREREREdk4Bm5EREREREQ2joEbERERERGRjWPgRkREREREZOMYuBEREREREdk4Bm5EREREREQ2zt7aFSAiIiIiItLJywPi4wGN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2XlatGgBADhz5oySS5O1aDTA/fvyPiegISIiIiIqF4oCtwcPHgAAHilBz4uvr69eXqpgEhLk4A0A/n0uiYiIiIiobCkK3Nzc3AAAycnJZudJSUkBADg6Oiq5NFmLdpikpyfA55CIiIiIqFwoCtyqV68OADh06JDZeQ4ePAgAZk1mQjaI97cREREREZU7RYFb586dIYTAN998o+tJK0pKSgq+/fZbSJKEzp07K7k0WYs2cOP9bURERERE5UZR4DZu3DhIkoQ7d+7gqaeewl3twsxGxMXF4amnnsLt27chSRLGjRun5NJkLfHx8k/2uBERERERlRt7JZkbNGiAN954A19++SX++usv1KlTB4MGDUKHDh0QGBgIALhz5w727duHtWvXIiMjA5IkYcKECXj00UctUX8qbxwqSURERERU7hQFbgAwZ84cJCcnY9myZUhPT8eyZcuwbNkyg3RCCADASy+9hC+//FLpZclaGLgREREREZU7RUMlAUClUmHJkiX45Zdf0KZNGwBykFZ4A4B27dph06ZNWLRoESRJUnpZshYGbkRERERE5U5xj5vW008/jaeffhoJCQk4ffo07v+7SLOvry+aNm0Kb29vS12KrImTkxARERERlTuLBW5aPj4+ePzxxy1dLNkKTk5CRERERFTuFA+VpCqGQyWJiIiIiModAzcyn0YD/DsEloEbEREREVH5sdhQydTUVOzatQt///037t+/j8zMTN3EJMZIkoQlS5ZY6vJUHpKSgPx8eZ+BGxERERFRuVEcuGk0GnzwwQeYO3cu0tPTzcojhGDgVhFph0l6eABOTtatCxERERFRFaI4cHvhhRewevVqCCFgZ2eHatWqIT4+HpIkoXr16khMTERaWhoAuZfN19cXarVaccXJCjgxCRERERGRVSi6x2379u1YtWoVADmAi4+Px65du3TnY2JikJKSgosXL+L111+HSqWCt7c3fv/9d0RFRSmr+b9SU1Mxc+ZMNGrUCG5ubvD09ETLli0xd+5c5OTkWOQaWi+//DIkSYIkSQgNDbVo2RUCJyYhIiIiIrIKRYHbsmXLAAANGjTA0qVL4e3tbXRx7bp16+LLL7/Ezz//jGvXrqFXr15ITk5WcmkAcmDYuHFjzJo1C+fOnYMQAtnZ2Th+/DjefvttPPbYY0hMTFR8HQDYs2cPFi1aZJGyKiwGbkREREREVqEocDt8+DAkScKECRPMSt+nTx+MHDkSMTEx+Prrr5VcGnl5eejTpw+io6MRGBiInTt3Ij09HRkZGVizZg3c3d1x6tQpDB8+XNF1ACAjIwNjxoyBvb09WrRoobi8CouBGxERERGRVSgK3OL/vecpIiJCd8zOzk63n52dbZCnf//+EEJg48aNSi6NFStW4OzZswCADRs2oFu3bgAAlUqFQYMG4X//+x8AYOvWrdi9e7eia02bNg3Xrl3DlClT0KBBA0VlVWjawM3Pz7r1ICIiIiKqYiyyjpuPj49u393dXbevDewK8/v3Q390dLSia65YsQIA0KVLF7Rp08bg/ODBgxEWFgYAWLlyZamvc/jwYXz99deIiIjA+++/X+pyKgVOTkJEREREZBWKAjd/f38AQEJCgt4xR0dHAMCZM2cM8sTExAAAsrKySn3djIwMHDx4EADQs2dPo2kkSUKPHj0AADt27CjVdbKzszF69GgIIbBo0SI4OzuXrsKVBYdKEhERERFZhaLArVGjRgCACxcu6I7Z29ujadOmAAomLylswYIFAICaNWuW+roXL16ERqMBADRs2NBkOu25uLg4veDSXLNnz8bFixfx4osvolOnTqWrbGXCwI2IiIiIyCoUBW6dO3eGEEJvCQAAGD58uO4+tpEjR2LLli1Yu3YtnnrqKezatQuSJOGZZ54p9XVv376t2w8ODjaZrvC5wnnMcerUKXz22Wfw9/fH559/XvJK/is7OxspKSl6W4XFwI2IiIiIyCoUBW59+/YFAGzbtg13797VHR83bhyaNWsGIQRWrVqFp59+GkOGDMG2bdsAADVq1MA777xT6uumpqbq9otazLvwucJ5ipOXl4fRo0cjLy8PX3/9Nby8vEpVTwD4+OOP4enpqdtCQkJKXZZVCcHJSYiIiIiIrERR4BYWFobr16/j3Llz8PDw0B23t7fHzp07MWzYMNjb20MIASEEAOCpp57C/v374e3trazmZeiTTz7B6dOn0bt3bwwcOFBRWVOnTkVycrJuu3nzpoVqWc6SkoC8PHmfPW5EREREROXKXmkBoaGhRo97e3vj+++/x/z583HlyhXk5eWhTp06ejNQllbhmSszMjJMpit8rnCeoly4cAEffPAB3NzcMH/+/NJX8l9OTk5wcnJSXI7VaXvb3NyAqj5JCxERERFROVMcuBXH3d0dzZo1s2iZQUFBuv3Y2Fg0btzYaLrY2FijeYoyYcIE5OTkYNasWfD29kZaWpre+bx/e52EELpzTk5OcHBwKNFjqHB4fxsRERERkdVYZB238la/fn2oVHLVz507ZzKd9lxAQIDZPX1RUVEA5CGO7u7uBtvq1asBADdu3NAdmzdvnpKHUzHw/jYiIiIiIqupkIGbWq1Gu3btAEA34cnDhBDYvn07AKB79+7lVrdKiz1uRERERERWUyEDNwAYOXIkAGDPnj04cuSIwfl169bh+vXrAIARI0aYXW50dLRuMhVjm/a6NWvW1B2bOHGi8gdk6+Lj5Z8M3IiIiIiIyl2FDtwaNWoEIQT69euH3bt3AwA0Gg3WrVuHMWPGAAB69uyJrl276uWdOXMmJEmCJEmIjo4u76pXTOxxIyIiIiKymjKfnKSs2NvbY9OmTejSpQuio6PRrVs3qNVqaDQaZGVlAQCaNm2quyeNFGLgRkRERERkNRW2xw2QlyI4c+YMpk+fjoYNG0KSJDg4OKB58+aYM2cODh8+bNPrxVUonJyEiIiIiMhqJKFdGZvKRUpKCjw9PZGcnKy3aLnNa9oUOH0a2LoV6NnT2rUhIiIiIqrwShIbVOgeNypHnJyEiIiIiMhqGLhR8YTgPW5ERERERFakKHAbPXo0XnzxRdy5c8fsPPfu3dPlowoiJQXIzZX3GbgREREREZU7Rfe4qVQqSJKEs2fPIjIy0qw8165dQ3h4OCRJQn5+fmkvXWFVyHvcrl4FwsMBV1cgLc3atSEiIiIiqhR4jxtZFu9vIyIiIiKyqnIP3LRrrDk5OZX3pam0eH8bEREREZFVlXvgdvDgQQCAv79/eV+aSouBGxERERGRVdmXJPHs2bONHp8/fz78ilmYOTs7G9euXcOmTZsgSRLatWtXkkuTNTFwIyIiIiKyqhIFbjNnzoQkSXrHhBBYsGCB2WUIIeDs7IzJkyeX5NJkTdrArZjgnIiIiIiIykaJh0oKIXSbJEmQJEnvmKnNyckJoaGhGDZsGA4dOoQmTZqUxeOhssDJSYiIiIiIrKpEPW4ajUbvd+1yAOfOnTN7OQCqgDhUkoiIiIjIqkoUuD2sRo0akCQJjo6OlqoP2SIGbkREREREVqUocIuOjrZQNcim8R43IiIiIiKr4gLcVDQh2ONGRERERGRligK33NxcXLhwARcuXEB2drbB+aysLLz11lsICQmBi4sLIiMj8c033yi5JJW31FRA+9wycCMiIiIisgpFQyU3btyIIUOGwMfHB7du3TI437dvX+zYsQNCCADAP//8g4kTJ+LSpUv49ttvlVyayou2t83FBXB1tW5diIiIiIiqKEU9btu3b4cQAs8++yycnJz0zm3ZsgXbt28HAFSvXh19+/ZFcHCwbt23v/76S8mlqbxwmCQRERERkdUpCtxOnjwJSZLQqVMng3NLly4FAEREROD8+fPYsGEDzp07h/r16wMAFi9erOTSVF44MQkRERERkdUpCtzi/12YuU6dOnrHNRoNdu/eDUmS8Nprr8Hd3R0A4OnpiVdffRVCCBw6dEjJpam8sMeNiIiIiMjqFAVu9+/fBwC4uLjoHT99+jRSUlIAAE899ZTeuYYNGwIAbt68qeTSVF7+Dc4ZuBERERERWY+iwE17X5s2gNPat28fAPnetpo1a+qd0/a+5efnK7k0lRf2uBERERERWZ2iwE0blB05ckTv+ObNmyFJEjp27GiQJyEhAQDwCAOBioGBGxERERGR1SkK3Lp06QIhBL755htcvHgRALBp0ybs3bsXANCrVy+DPOfOnQMABAYGKrk0lRdOTkJEREREZHWKArfXXnsNjo6OiI+PR8OGDeHr64u+fftCCIHg4GD069fPIM+OHTsgSRIaN26s5NJUXtjjRkRERERkdYoCt/DwcHz//fdQq9UQQiAhIQFCCHh5eeHHH3+Eo6OjXvq4uDjs3LkTAPD4448ruTSVF05OQkRERERkdfZKCxgwYAA6deqELVu2IC4uDoGBgXj66afh4+NjkPbMmTMYOnQoAOPDKMnGCMEeNyIiIiIiGyAJIYS1K1GVpKSkwNPTE8nJyfDw8LB2dYqWlgb8OwsoUlIK9omIiIiISLGSxAaKhkpSJaftbXN2BtzcrFsXIiIiIqIqTPFQycIyMzNx4sQJxMXFISMjA88++6zt9yqRaYWHSUqSdetCRERERFSFWSRwu3nzJt577z2sW7cOubm5uuMtWrRAZGSk7vclS5bgf//7Hzw9PXWzS5IN48QkREREREQ2QfFQySNHjqBp06b44YcfkJOTAyEETN0216dPH5w5cwZ//PEHduzYofTSVNY4MQkRERERkU1QFLglJSXhmWeeQUJCAgICAjB//nycPXvWZHo/Pz/07NkTALBlyxYll6bywMW3iYiIiIhsgqKhkl9//TXi4+Ph6+uLQ4cOoUaNGsXm6datG3799VccPXpUyaWpPLDHjYiIiIjIJijqcdu8eTMkScKbb75pVtAGAA0aNAAAXLt2TcmlqTwwcCMiIiIisgmKArerV68CADp27Gh2Hm9vbwDymgVk4zg5CRERERGRTVAUuGVlZQEAHBwczM6Tnp4OAHBxcVFyaSoP7HEjIiIiIrIJigI3v38nrYiKijI7z+nTpwEAQUFBSi5N5YGTkxARERER2QRFgVvr1q0BAL///rtZ6YUQ+O677yBJEjp06KDk0lQe2ONGRERERGQTFAVuw4YNgxACq1ev1vWkFeWtt97C33//DQAYOXKkkktTWUtPBzIy5H0GbkREREREVqUocHvmmWfQpUsX5OXloWvXrliwYAHitRNaAMjLy8Pt27exbt06dOjQAV999RUkScJzzz2Htm3bKq48lSFtb5ujI+Dubt26EBERERFVcZIQQigpICkpCV27dsWpU6cgSVKRaYUQeOyxx7Bz5064uroquWyFlZKSAk9PTyQnJ8PDw8Pa1THt2DGgVSsgOBi4dcvatSEiIiIiqnRKEhso6nEDAC8vLxw6dAhTp06Fh4cHhBBGNxcXF0yZMgV79+6tskFbhcKJSYiIiIiIbIa9JQpxdHTEf/7zH7z33nv4888/cfz4ccTHxyM/Px/VqlVD06ZN0a1bN3h6elriclQeODEJEREREZHNsEjgpuXq6opevXqhV69eliyWrIGLbxMRERER2QxFgdu+ffsAAC1btjR7Qe2srCwcPXoUANCxY0cll6eyxB43IiIiIiKboShw69y5M1QqFc6cOYPIyEiz8sTGxury5eXlKbk8lSUGbkRERERENkPx5CSlnZRS4WSWVNY4OQkRERERkc1QHLiVlEajAQDY2dmV96WpJNjjRkRERERkM8o9cIuJiQEAzjBp6zg5CRERERGRzSjRPW43btwwevzOnTtwc3MrMm92djauXbuG//u//4MkSWjQoEFJLk3ljT1uREREREQ2o0SBW1hYmMExIQS6d+9e4guPGDGixHmonGRmAunp8j7vcSMiIiIisroSBW6mJhQpyUQjzs7OeP311zF69OiSXJrKk7a3zcEB8PCwbl2IiIiIiKhkgduyZcv0fh81ahQkScIHH3yA4OBgk/kk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By+//DIAwM/PD7t370bDhg310nTo0AETJkzQ1aewWbNmoVatWpAemj29RYsW6NevH1555RW0bdsW9+7dwzfffIMPPvjAzBYoXwzciIEbERERVS1CABkZ1q5F2VOry2ypp5ycHCxZsgQA0LhxY7z77rsGaRwcHLBkyRLUqlULubm5pb7WN998g4x/n69FixYZBG2FhYSEGByrXbt2keU3atQIL730Er788kv88ssvDNzIhjFwIyIioqokIwNwc7N2LcpeWhrg6lomRZ84cQKJiYkAgJEjRxr0ZmlVr14d3bt3x5YtW0p9rd9++w0AUKtWLTz99NOlLkcrMTERCQkJyMrKghACAODl5QUAuHDhAnJzc21yhksGbsTAjYiIiIhK5OzZs7r9li1bFpm2VatWpQ7ccnNzdffItW/f3mSAWJyzZ8/iv//9L37//XfExcWZTKfRaJCYmGiT97kxcKvqhGDgRkRERFWLWi33RlV2anWZFZ2QkKDbLy7I8ff3V3Qdba9YYGBgqcpYsmQJXn75ZeTl5ZmVPjMzs1TXKWsM3Kq61FRAO+aYC3ATERFRVSBJZTaEsCoqbS9Yefjnn390QZufnx8mT56Mxx9/HKGhoXB3d9cNiVy6dClefPFFANAFiraGgVtVp+1tU6vL9FsZIiIiIqo8vL29dft3795FRESEybR3794t9XV8fHygUqmg0Whw586dEudfvnw58vLyYGdnhz///BP16tUzmq5wD6KtUlm7AmRlDx7IPzlMkoiIiIjM1KhRI93+sWPHikxb3PmiODg46GaR3L9/f4l7w86fPw8AaNKkicmgDdBflsBWMXCr6nh/GxERERGVUPPmzXW9bt9//73JgCo2NtboOm4l0adPHwBAVFQUfv311xLl1d7Xlp6ebjLNnTt3sGnTptJXsJwwcKvqGLgRERERUQk5OTlh1KhRAIDTp0/j888/N0iTl5eHMWPGICcnR9G1Xn31Vbj+e0/iuHHjdLNMGnPr1i2938PDwwEAV65cwV9//WWQPiMjA0OHDrXZCUkKY+BW1TFwIyIiIqJSmD59OqpXrw4AeOeddzB06FBs27YNJ0+exJo1a9C2bVv8/vvvaNGihaLrBAQEYMGCBQCA+Ph4tGrVCm+88Qa2bduG06dP48CBA1i4cCF69eqFTp066eV9/vnnAcjT/D/11FP46KOPsG/f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ABD29vZizZo1JbqO0uetsjG33YsycuRIAUDUrFnTZBq2u2UwcKtCcnNzRaNGjXQfqLT/oPPz88XatWuFh4eHACB69uxp5ZpWLJMnT9Z96Pniiy9KlJfPSdkoLnBjuyvTv39/AUBUq1ZNrF+/XhdIxMTEiIEDB+rafvny5Xr52O6l99prr+natUePHuLMmTMiPz9f5Ofni7///lt0795dd37WrFl6ednuRUtISBD37t3TbSEhIQKAmDx5st7x1NRUvXxJSUkiICBAABCRkZHi+PHjQgghsrOzxfz584Wjo6MAIMaPH2/0utevXxeurq4CgOjQoYO4fPmyEEKItLQ0MWvWLCFJkgAgPv3007JtACspTbvn5eWJwYMH64K2tWvXlvi6Sp+3iq60r/eimBO4VfV2txQGblVMVFSUCA0N1f2DV6vVwtnZWfd706ZNq8Q3e5YSExOjazuVSiX8/f2L3D7//HODMvicWF5xgZsQbHcl0tLSRMeOHXVt5eTkJLy9vXW/F/XtLdu9dDIyMkSPHj302tjJyUk4OTnpHRsyZIheb5sW2900bY9DcdvIkSMN8h4/flxUq1ZNl8bd3V04ODjofu/evbvIysoyee0tW7YItVqtS+/p6Sns7Ox0v48aNUpoNJoyfPTWU5p2//PPP3XHHRwciv2fa6o3TunzVpEpeb2bYk7gJkTVbndL4T1uVUxoaCjOnDmD6dOno2HDhpAkCQ4ODmjevDnmzJmDw4cPw9vb29rVrDAeXtfq7t27RW5paWkGZfA5sQ62e+m5urpiz549+O6779CxY0e4uroiLS0NwcHBGDx4MA4ePIiZM2cazct2Lx0XFxds3boV69atwzPPPIPq1avrJoEJCQlBv3798Ntvv+GHH36AnZ2dQX62e9lo3rw5zp8/j0mTJiE8PBy5ublwdXVF+/bt8d133+H333+Hk5OTyfy9evXCmTNnMGbMGISGhiIrKwve3t544oknsH79eixdulQ3wQ/p/8/Nzc0t9n+uqRk7lT5vVDpsd+UkIQpN/0VEREREREQ2hz1uRERERERENo6BGxERERERkY1j4EZERERERGTjGLgRERERERHZOAZuRERERERENo6BGxERERERkY1j4EZERERERGTjGLgRERERERHZOAZuRERERERENo6BGxERERERkY1j4EZERFTJde7cGZIkoXPn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",
      "text/plain": [
       "<Figure size 1000x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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CO/WYJrW8EmHo3bPk5UlhYfXeLdbtmzRyZMnJUnjx4+v8GpWy5YtNWTIEH322WfVPteSJUskSe3atdNVV11V7X6cTp48qbS0NOXm5sp5Mb1Ro0aSpN27d6ugoIAZLgEAAHwQwQ34jR07dri2e/XqVWnb3r17Vzu4FRQUuO6R69evX4UB8Ux27Nih559/XkuXLlVqamqF7YqLi3Xy5EnucwMAAPBBBLf6JizMuhJVm776Svrd787c7vPPpRqadbFcYWG10m1aWppr+0whp1mzZh6dx3lVLC4urlp9vPXWW7rttttUWFjoVvvTp09X6zwAAADwLoJbfWMYtTJ8sJQhQ6zZI5OTy7/PzTCs/UOG+PzSANW9ClYXfvjhB1doa9q0qaZMmaLLL79cbdu2VWRkpGtI5Ntvv60///nPkiTmIgIAAPBNPrsAd05OjpYuXaonnnhC11xzjdq0aeNa3DghIaFGznHkyBFNnjxZ5557rkJDQxUTE6P+/fvrzTffbNj/APb3t6b8l8pODuL8/oUXfDa0RUdHu7aPHDlSadsz7a9MTEyM/PysP8GUlJQqH//OO++osLBQ/v7++vLLL3XfffepR48eiomJKXUfW8kriAAAAPBNPnvFbePGjfqdO8P1qmnLli0aOnSoTpw4IUmKiIhQZmam1q1bp3Xr1mnhwoVavHixgoKCaq0GW7vmGmvK//LWcXvhBZ9eCqBbt26u7U2bNql///4Vtt20aVO1zxMYGKiuXbtq+/btWrt2rUzTrNIVvl27dkmSzj//fHXs2LHCdps3b652jQAAALAHn73iJllXRgYNGqQpU6bogw8+UGxsbI30m56eriuvvFInTpxQx44dtWnTJmVmZio7O1svv/yyAgMDtXz5ct199901cj6fdc01UlKStHq19P771tfERJ8ObZLUs2dP11W3d999t8Krq8nJyaXWcauO4cOHS7LWefvkk0+qdKzzvrbs7OwK26SkpGjx4sXVLxAAAAC24LPBrX///kpLS9PKlSv17LPPatSoUQoODq6RvmfMmKHU1FSFhobq888/14UXXihJCgoK0h133KHHHntMkrXu1t69e2vknD7L318aMEAaPdr66qPDI0sKDg52LZz93Xffafr06WXaFBYWauLEicrPz/foXHfeeafC/3dP4q233uqaZbI8h0pe2ZTUvn17SdJPP/2k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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
}
