{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-16T07:15:24.264921Z",
     "iopub.status.busy": "2025-09-16T07:15:24.264483Z",
     "iopub.status.idle": "2025-09-16T07:15:29.141725Z",
     "shell.execute_reply": "2025-09-16T07:15:29.141003Z"
    },
    "id": "OHJWesKs-tqd"
   },
   "outputs": [],
   "source": [
    "import json\n",
    "import os\n",
    "import time\n",
    "import ipyparallel as ipp\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "import torch\n",
    "import dfca as DFCA\n",
    "import ifca as IFCA\n",
    "\n",
    "import numpy as np\n",
    "\n",
    "from util import *"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-16T07:15:29.144485Z",
     "iopub.status.busy": "2025-09-16T07:15:29.144095Z",
     "iopub.status.idle": "2025-09-16T07:15:29.147261Z",
     "shell.execute_reply": "2025-09-16T07:15:29.146791Z"
    }
   },
   "outputs": [],
   "source": [
    "learning_rates = [0.1]\n",
    "\n",
    "dfca_gi = []\n",
    "ifca = []\n",
    "dfca_li = []"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-16T07:15:29.149529Z",
     "iopub.status.busy": "2025-09-16T07:15:29.149368Z",
     "iopub.status.idle": "2025-09-16T07:15:29.152850Z",
     "shell.execute_reply": "2025-09-16T07:15:29.152335Z"
    }
   },
   "outputs": [],
   "source": [
    "\n",
    "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.1]\n",
    "\n",
    "ifca = []"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "7ADsUSUi-tqf"
   },
   "source": [
    "Running the dfca-gi experiment"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 1000
    },
    "execution": {
     "iopub.execute_input": "2025-09-16T07:15:29.155219Z",
     "iopub.status.busy": "2025-09-16T07:15:29.155020Z",
     "iopub.status.idle": "2025-09-16T09:31:48.250357Z",
     "shell.execute_reply": "2025-09-16T09:31:48.249580Z"
    },
    "id": "T_XDv25r-tqf",
    "outputId": "9c8f4300-c792-4e49-be40-c694fa066e6f"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "---------------------------------IFCA, lr: 0.1, seed: 1824---------------------------------\n",
      "config: {'m': 400, 'm_test': 40, 'p': 4, 'n': 2000, 'uneven': False, 'local_model_init': False, 'Gp': 0.2, 'graph': 'fixed', 'h1': 512, 'num_epochs': 150, 'batch_size': 100, 'tau': 5, 'lr': 0.1, 'data_seed': 1824, 'train_seed': 1824, 'config_override': '', 'project_dir': 'output_dfca_gi'}\n",
      "Using device: cuda:3\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      "Generating partition_id_to_indices: 0it [00:00, ?it/s]"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      "Generating partition_id_to_indices: 126302it [00:00, 1262921.84it/s]"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      "Generating partition_id_to_indices: 261330it [00:00, 1314267.54it/s]"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      "Generating partition_id_to_indices: 396638it [00:00, 1331955.30it/s]"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      "Generating partition_id_to_indices: 532094it [00:00, 1340840.44it/s]"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      "Generating partition_id_to_indices: 667525it [00:00, 1345675.94it/s]"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      "Generating partition_id_to_indices: 803410it [00:00, 1350118.19it/s]"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      "Generating partition_id_to_indices: 814277it [00:00, 1336968.69it/s]"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch -1 tr: l 4.133 a 0.010 clct[np.int64(19), np.int64(66), np.int64(95), np.int64(220)]  2.640sec\n",
      "Epoch -1 tst: l 4.124 a 0.013 clct[np.int64(3), np.int64(3), np.int64(9), np.int64(25)]  0.189sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0 tr: l 3.535 a 0.225 clct[np.int64(193), np.int64(23), np.int64(171), np.int64(13)]  lr 0.100000 9.863sec(train) 2.159sec(infer)\n",
      "Epoch 0 tst: l 3.545 a 0.244 clct[np.int64(17), np.int64(4), np.int64(13), np.int64(6)]  0.147sec\n",
      "result written at output_dfca_gi/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1 tr: l 2.714 a 0.408 clct[np.int64(138), np.int64(9), np.int64(249), np.int64(4)]  lr 0.100000 9.539sec(train) 2.869sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1 tst: l 2.715 a 0.406 clct[np.int64(12), np.int64(1), np.int64(24), np.int64(3)]  0.222sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2 tr: l 2.174 a 0.533 clct[np.int64(132), np.int64(9), np.int64(229), np.int64(30)]  lr 0.100000 7.470sec(train) 2.153sec(infer)\n",
      "Epoch 2 tst: l 2.173 a 0.531 clct[np.int64(13), np.int64(1), np.int64(21), np.int64(5)]  0.149sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3 tr: l 1.771 a 0.627 clct[np.int64(137), np.int64(12), np.int64(214), np.int64(37)]  lr 0.100000 7.355sec(train) 2.154sec(infer)\n",
      "Epoch 3 tst: l 1.772 a 0.624 clct[np.int64(11), np.int64(1), np.int64(20), np.int64(8)]  0.147sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4 tr: l 1.494 a 0.662 clct[np.int64(119), np.int64(23), np.int64(174), np.int64(84)]  lr 0.100000 6.465sec(train) 2.417sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4 tst: l 1.479 a 0.665 clct[np.int64(8), np.int64(3), np.int64(17), np.int64(12)]  0.206sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5 tr: l 1.307 a 0.702 clct[np.int64(120), np.int64(26), np.int64(155), np.int64(99)]  lr 0.100000 9.194sec(train) 2.158sec(infer)\n",
      "Epoch 5 tst: l 1.299 a 0.706 clct[np.int64(9), np.int64(3), np.int64(15), np.int64(13)]  0.147sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6 tr: l 1.175 a 0.723 clct[np.int64(115), np.int64(33), np.int64(148), np.int64(104)]  lr 0.100000 8.251sec(train) 2.152sec(infer)\n",
      "Epoch 6 tst: l 1.164 a 0.731 clct[np.int64(8), np.int64(6), np.int64(12), np.int64(14)]  0.151sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7 tr: l 1.077 a 0.738 clct[np.int64(117), np.int64(32), np.int64(138), np.int64(113)]  lr 0.100000 8.536sec(train) 2.844sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7 tst: l 1.070 a 0.745 clct[np.int64(8), np.int64(8), np.int64(12), np.int64(12)]  0.221sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8 tr: l 0.997 a 0.753 clct[np.int64(116), np.int64(35), np.int64(139), np.int64(110)]  lr 0.100000 8.594sec(train) 2.149sec(infer)\n",
      "Epoch 8 tst: l 0.989 a 0.757 clct[np.int64(8), np.int64(10), np.int64(10), np.int64(12)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9 tr: l 0.932 a 0.763 clct[np.int64(115), np.int64(35), np.int64(135), np.int64(115)]  lr 0.100000 7.692sec(train) 2.155sec(infer)\n",
      "Epoch 9 tst: l 0.927 a 0.764 clct[np.int64(8), np.int64(10), np.int64(11), np.int64(11)]  0.146sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10 tr: l 0.875 a 0.775 clct[np.int64(116), np.int64(37), np.int64(135), np.int64(112)]  lr 0.100000 8.009sec(train) 3.029sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10 tst: l 0.871 a 0.778 clct[np.int64(8), np.int64(11), np.int64(10), np.int64(11)]  0.217sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11 tr: l 0.830 a 0.783 clct[np.int64(115), np.int64(36), np.int64(132), np.int64(117)]  lr 0.100000 8.287sec(train) 2.143sec(infer)\n",
      "Epoch 11 tst: l 0.829 a 0.783 clct[np.int64(9), np.int64(10), np.int64(11), np.int64(10)]  0.148sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12 tr: l 0.791 a 0.791 clct[np.int64(115), np.int64(37), np.int64(133), np.int64(115)]  lr 0.100000 7.966sec(train) 2.147sec(infer)\n",
      "Epoch 12 tst: l 0.793 a 0.789 clct[np.int64(9), np.int64(11), np.int64(10), np.int64(10)]  0.150sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13 tr: l 0.758 a 0.798 clct[np.int64(114), np.int64(38), np.int64(129), np.int64(119)]  lr 0.100000 7.827sec(train) 3.003sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13 tst: l 0.761 a 0.797 clct[np.int64(9), np.int64(10), np.int64(11), np.int64(10)]  0.213sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14 tr: l 0.729 a 0.804 clct[np.int64(115), np.int64(38), np.int64(131), np.int64(116)]  lr 0.100000 8.459sec(train) 2.142sec(infer)\n",
      "Epoch 14 tst: l 0.736 a 0.796 clct[np.int64(9), np.int64(11), np.int64(10), np.int64(10)]  0.146sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15 tr: l 0.704 a 0.808 clct[np.int64(115), np.int64(38), np.int64(129), np.int64(118)]  lr 0.100000 7.675sec(train) 2.149sec(infer)\n",
      "Epoch 15 tst: l 0.712 a 0.802 clct[np.int64(9), np.int64(10), np.int64(11), np.int64(10)]  0.147sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16 tr: l 0.680 a 0.814 clct[np.int64(115), np.int64(39), np.int64(130), np.int64(116)]  lr 0.100000 7.873sec(train) 3.029sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16 tst: l 0.694 a 0.803 clct[np.int64(9), np.int64(11), np.int64(10), np.int64(10)]  0.216sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17 tr: l 0.659 a 0.818 clct[np.int64(115), np.int64(38), np.int64(129), np.int64(118)]  lr 0.100000 8.733sec(train) 2.149sec(infer)\n",
      "Epoch 17 tst: l 0.671 a 0.813 clct[np.int64(9), np.int64(10), np.int64(9), np.int64(12)]  0.146sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18 tr: l 0.640 a 0.823 clct[np.int64(115), np.int64(39), np.int64(129), np.int64(117)]  lr 0.100000 8.765sec(train) 2.057sec(infer)\n",
      "Epoch 18 tst: l 0.657 a 0.813 clct[np.int64(9), np.int64(10), np.int64(10), np.int64(11)]  0.196sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19 tr: l 0.623 a 0.826 clct[np.int64(115), np.int64(39), np.int64(128), np.int64(118)]  lr 0.100000 9.388sec(train) 2.869sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19 tst: l 0.639 a 0.819 clct[np.int64(9), np.int64(10), np.int64(9), np.int64(12)]  0.217sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20 tr: l 0.607 a 0.830 clct[np.int64(115), np.int64(39), np.int64(129), np.int64(117)]  lr 0.100000 7.715sec(train) 2.149sec(infer)\n",
      "Epoch 20 tst: l 0.628 a 0.817 clct[np.int64(10), np.int64(11), np.int64(9), np.int64(10)]  0.145sec\n",
      "result written at output_dfca_gi/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21 tr: l 0.593 a 0.832 clct[np.int64(115), np.int64(39), np.int64(128), np.int64(118)]  lr 0.100000 7.715sec(train) 2.226sec(infer)\n",
      "Epoch 21 tst: l 0.613 a 0.826 clct[np.int64(9), np.int64(10), np.int64(9), np.int64(12)]  0.196sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22 tr: l 0.579 a 0.836 clct[np.int64(115), np.int64(39), np.int64(129), np.int64(117)]  lr 0.100000 9.201sec(train) 2.479sec(infer)\n",
      "Epoch 22 tst: l 0.604 a 0.823 clct[np.int64(10), np.int64(11), np.int64(8), np.int64(11)]  0.147sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23 tr: l 0.567 a 0.838 clct[np.int64(115), np.int64(39), np.int64(127), np.int64(119)]  lr 0.100000 7.660sec(train) 2.148sec(infer)\n",
      "Epoch 23 tst: l 0.592 a 0.829 clct[np.int64(9), np.int64(10), np.int64(9), np.int64(12)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24 tr: l 0.555 a 0.841 clct[np.int64(115), np.int64(39), np.int64(128), np.int64(118)]  lr 0.100000 7.921sec(train) 2.346sec(infer)\n",
      "Epoch 24 tst: l 0.585 a 0.828 clct[np.int64(9), np.int64(11), np.int64(9), np.int64(11)]  0.161sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25 tr: l 0.545 a 0.843 clct[np.int64(115), np.int64(39), np.int64(127), np.int64(119)]  lr 0.100000 9.175sec(train) 2.242sec(infer)\n",
      "Epoch 25 tst: l 0.574 a 0.831 clct[np.int64(10), np.int64(9), np.int64(9), np.int64(12)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 26 tr: l 0.534 a 0.846 clct[np.int64(115), np.int64(40), np.int64(127), np.int64(118)]  lr 0.100000 7.659sec(train) 2.147sec(infer)\n",
      "Epoch 26 tst: l 0.568 a 0.831 clct[np.int64(9), np.int64(11), np.int64(9), np.int64(11)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 27 tr: l 0.525 a 0.848 clct[np.int64(115), np.int64(39), np.int64(127), np.int64(119)]  lr 0.100000 7.867sec(train) 2.182sec(infer)\n",
      "Epoch 27 tst: l 0.558 a 0.838 clct[np.int64(9), np.int64(9), np.int64(10), np.int64(12)]  0.158sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 28 tr: l 0.515 a 0.851 clct[np.int64(115), np.int64(40), np.int64(127), np.int64(118)]  lr 0.100000 9.065sec(train) 2.165sec(infer)\n",
      "Epoch 28 tst: l 0.554 a 0.836 clct[np.int64(9), np.int64(10), np.int64(10), np.int64(11)]  0.146sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 29 tr: l 0.507 a 0.852 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 8.703sec(train) 2.151sec(infer)\n",
      "Epoch 29 tst: l 0.544 a 0.842 clct[np.int64(9), np.int64(9), np.int64(10), np.int64(12)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 30 tr: l 0.499 a 0.855 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 7.668sec(train) 1.984sec(infer)\n",
      "Epoch 30 tst: l 0.541 a 0.841 clct[np.int64(9), np.int64(10), np.int64(10), np.int64(11)]  0.161sec\n",
      "result written at output_dfca_gi/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 31 tr: l 0.491 a 0.856 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 9.307sec(train) 2.153sec(infer)\n",
      "Epoch 31 tst: l 0.532 a 0.845 clct[np.int64(9), np.int64(9), np.int64(10), np.int64(12)]  0.146sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 32 tr: l 0.484 a 0.858 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 7.682sec(train) 2.151sec(infer)\n",
      "Epoch 32 tst: l 0.530 a 0.842 clct[np.int64(9), np.int64(10), np.int64(10), np.int64(11)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 33 tr: l 0.477 a 0.859 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 7.663sec(train) 1.951sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 33 tst: l 0.522 a 0.846 clct[np.int64(9), np.int64(9), np.int64(10), np.int64(12)]  0.203sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 34 tr: l 0.470 a 0.862 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 9.131sec(train) 2.149sec(infer)\n",
      "Epoch 34 tst: l 0.521 a 0.844 clct[np.int64(9), np.int64(10), np.int64(10), np.int64(11)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 35 tr: l 0.464 a 0.862 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 7.671sec(train) 2.150sec(infer)\n",
      "Epoch 35 tst: l 0.513 a 0.849 clct[np.int64(9), np.int64(9), np.int64(10), np.int64(12)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 36 tr: l 0.457 a 0.865 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 7.883sec(train) 2.015sec(infer)\n",
      "Epoch 36 tst: l 0.512 a 0.847 clct[np.int64(10), np.int64(9), np.int64(10), np.int64(11)]  0.161sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 37 tr: l 0.452 a 0.865 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 9.118sec(train) 2.155sec(infer)\n",
      "Epoch 37 tst: l 0.505 a 0.851 clct[np.int64(9), np.int64(9), np.int64(10), np.int64(12)]  0.146sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 38 tr: l 0.446 a 0.868 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 7.686sec(train) 2.156sec(infer)\n",
      "Epoch 38 tst: l 0.504 a 0.849 clct[np.int64(10), np.int64(9), np.int64(10), np.int64(11)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 39 tr: l 0.442 a 0.868 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 7.875sec(train) 2.056sec(infer)\n",
      "Epoch 39 tst: l 0.498 a 0.853 clct[np.int64(9), np.int64(9), np.int64(10), np.int64(12)]  0.161sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 40 tr: l 0.436 a 0.871 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 9.146sec(train) 2.150sec(infer)\n",
      "Epoch 40 tst: l 0.497 a 0.851 clct[np.int64(10), np.int64(9), np.int64(10), np.int64(11)]  0.146sec\n",
      "result written at output_dfca_gi/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 41 tr: l 0.431 a 0.871 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 7.830sec(train) 2.154sec(infer)\n",
      "Epoch 41 tst: l 0.491 a 0.853 clct[np.int64(9), np.int64(9), np.int64(10), np.int64(12)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 42 tr: l 0.426 a 0.874 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 7.739sec(train) 1.994sec(infer)\n",
      "Epoch 42 tst: l 0.491 a 0.851 clct[np.int64(10), np.int64(9), np.int64(10), np.int64(11)]  0.159sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 43 tr: l 0.422 a 0.874 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 9.304sec(train) 2.156sec(infer)\n",
      "Epoch 43 tst: l 0.485 a 0.854 clct[np.int64(9), np.int64(9), np.int64(10), np.int64(12)]  0.146sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 44 tr: l 0.416 a 0.876 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 7.678sec(train) 2.155sec(infer)\n",
      "Epoch 44 tst: l 0.485 a 0.851 clct[np.int64(9), np.int64(9), np.int64(10), np.int64(12)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 45 tr: l 0.413 a 0.876 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 7.885sec(train) 1.973sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 45 tst: l 0.480 a 0.855 clct[np.int64(9), np.int64(9), np.int64(10), np.int64(12)]  0.244sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 46 tr: l 0.408 a 0.878 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 8.898sec(train) 2.150sec(infer)\n",
      "Epoch 46 tst: l 0.480 a 0.852 clct[np.int64(9), np.int64(9), np.int64(10), np.int64(12)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 47 tr: l 0.404 a 0.878 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 7.667sec(train) 2.152sec(infer)\n",
      "Epoch 47 tst: l 0.475 a 0.856 clct[np.int64(9), np.int64(9), np.int64(10), np.int64(12)]  0.147sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 48 tr: l 0.399 a 0.880 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 7.855sec(train) 2.019sec(infer)\n",
      "Epoch 48 tst: l 0.475 a 0.854 clct[np.int64(9), np.int64(9), np.int64(10), np.int64(12)]  0.159sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 49 tr: l 0.396 a 0.880 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 9.222sec(train) 2.149sec(infer)\n",
      "Epoch 49 tst: l 0.471 a 0.860 clct[np.int64(10), np.int64(8), np.int64(10), np.int64(12)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 50 tr: l 0.392 a 0.882 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 7.871sec(train) 2.151sec(infer)\n",
      "Epoch 50 tst: l 0.471 a 0.856 clct[np.int64(9), np.int64(9), np.int64(10), np.int64(12)]  0.147sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 51 tr: l 0.389 a 0.882 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 7.674sec(train) 2.014sec(infer)\n",
      "Epoch 51 tst: l 0.466 a 0.860 clct[np.int64(9), np.int64(8), np.int64(10), np.int64(13)]  0.160sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 52 tr: l 0.384 a 0.884 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 9.130sec(train) 2.153sec(infer)\n",
      "Epoch 52 tst: l 0.466 a 0.857 clct[np.int64(9), np.int64(9), np.int64(10), np.int64(12)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 53 tr: l 0.381 a 0.884 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 8.140sec(train) 2.151sec(infer)\n",
      "Epoch 53 tst: l 0.462 a 0.859 clct[np.int64(10), np.int64(8), np.int64(10), np.int64(12)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 54 tr: l 0.378 a 0.885 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 7.658sec(train) 1.960sec(infer)\n",
      "Epoch 54 tst: l 0.463 a 0.858 clct[np.int64(9), np.int64(9), np.int64(10), np.int64(12)]  0.177sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 55 tr: l 0.374 a 0.886 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 9.183sec(train) 2.151sec(infer)\n",
      "Epoch 55 tst: l 0.459 a 0.860 clct[np.int64(10), np.int64(8), np.int64(10), np.int64(12)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 56 tr: l 0.371 a 0.887 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 7.829sec(train) 2.150sec(infer)\n",
      "Epoch 56 tst: l 0.459 a 0.860 clct[np.int64(9), np.int64(9), np.int64(10), np.int64(12)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 57 tr: l 0.368 a 0.888 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 7.664sec(train) 1.965sec(infer)\n",
      "Epoch 57 tst: l 0.455 a 0.861 clct[np.int64(10), np.int64(8), np.int64(10), np.int64(12)]  0.160sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 58 tr: l 0.364 a 0.889 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 9.218sec(train) 2.152sec(infer)\n",
      "Epoch 58 tst: l 0.455 a 0.860 clct[np.int64(9), np.int64(8), np.int64(10), np.int64(13)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 59 tr: l 0.361 a 0.889 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 7.659sec(train) 2.149sec(infer)\n",
      "Epoch 59 tst: l 0.452 a 0.863 clct[np.int64(10), np.int64(8), np.int64(10), np.int64(12)]  0.148sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 60 tr: l 0.358 a 0.890 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 7.868sec(train) 1.931sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 60 tst: l 0.452 a 0.861 clct[np.int64(9), np.int64(8), np.int64(10), np.int64(13)]  0.237sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 61 tr: l 0.356 a 0.891 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 8.902sec(train) 2.154sec(infer)\n",
      "Epoch 61 tst: l 0.449 a 0.863 clct[np.int64(10), np.int64(8), np.int64(10), np.int64(12)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 62 tr: l 0.353 a 0.892 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 8.873sec(train) 2.149sec(infer)\n",
      "Epoch 62 tst: l 0.449 a 0.861 clct[np.int64(9), np.int64(8), np.int64(10), np.int64(13)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 63 tr: l 0.350 a 0.892 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 7.854sec(train) 2.163sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 63 tst: l 0.447 a 0.863 clct[np.int64(10), np.int64(8), np.int64(10), np.int64(12)]  0.225sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 64 tr: l 0.347 a 0.893 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 8.818sec(train) 2.153sec(infer)\n",
      "Epoch 64 tst: l 0.447 a 0.860 clct[np.int64(10), np.int64(8), np.int64(10), np.int64(12)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 65 tr: l 0.344 a 0.894 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 7.847sec(train) 2.150sec(infer)\n",
      "Epoch 65 tst: l 0.444 a 0.864 clct[np.int64(10), np.int64(8), np.int64(10), np.int64(12)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 66 tr: l 0.342 a 0.895 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 7.655sec(train) 1.946sec(infer)\n",
      "Epoch 66 tst: l 0.445 a 0.859 clct[np.int64(10), np.int64(8), np.int64(10), np.int64(12)]  0.197sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 67 tr: l 0.339 a 0.895 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 9.192sec(train) 2.149sec(infer)\n",
      "Epoch 67 tst: l 0.442 a 0.866 clct[np.int64(10), np.int64(8), np.int64(10), np.int64(12)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 68 tr: l 0.337 a 0.896 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 7.825sec(train) 2.151sec(infer)\n",
      "Epoch 68 tst: l 0.442 a 0.862 clct[np.int64(10), np.int64(7), np.int64(10), np.int64(13)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 69 tr: l 0.334 a 0.896 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 7.670sec(train) 1.946sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 69 tst: l 0.440 a 0.867 clct[np.int64(10), np.int64(8), np.int64(10), np.int64(12)]  0.206sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 70 tr: l 0.332 a 0.897 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 9.284sec(train) 2.151sec(infer)\n",
      "Epoch 70 tst: l 0.440 a 0.863 clct[np.int64(10), np.int64(7), np.int64(10), np.int64(13)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 71 tr: l 0.329 a 0.898 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 8.572sec(train) 2.154sec(infer)\n",
      "Epoch 71 tst: l 0.438 a 0.867 clct[np.int64(10), np.int64(8), np.int64(10), np.int64(12)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 72 tr: l 0.327 a 0.899 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 8.796sec(train) 2.890sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 72 tst: l 0.438 a 0.864 clct[np.int64(10), np.int64(7), np.int64(10), np.int64(13)]  0.219sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 73 tr: l 0.325 a 0.899 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 8.577sec(train) 2.149sec(infer)\n",
      "Epoch 73 tst: l 0.436 a 0.868 clct[np.int64(10), np.int64(8), np.int64(10), np.int64(12)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 74 tr: l 0.322 a 0.900 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 8.803sec(train) 2.151sec(infer)\n",
      "Epoch 74 tst: l 0.436 a 0.864 clct[np.int64(10), np.int64(7), np.int64(10), np.int64(13)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 75 tr: l 0.320 a 0.900 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 8.067sec(train) 2.935sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 75 tst: l 0.434 a 0.869 clct[np.int64(10), np.int64(8), np.int64(10), np.int64(12)]  0.212sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 76 tr: l 0.318 a 0.901 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 8.154sec(train) 2.150sec(infer)\n",
      "Epoch 76 tst: l 0.435 a 0.865 clct[np.int64(10), np.int64(7), np.int64(10), np.int64(13)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 77 tr: l 0.316 a 0.901 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 7.829sec(train) 2.150sec(infer)\n",
      "Epoch 77 tst: l 0.433 a 0.870 clct[np.int64(10), np.int64(7), np.int64(10), np.int64(13)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 78 tr: l 0.314 a 0.902 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 8.083sec(train) 2.893sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 78 tst: l 0.433 a 0.866 clct[np.int64(10), np.int64(7), np.int64(10), np.int64(13)]  0.216sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 79 tr: l 0.311 a 0.902 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 8.190sec(train) 2.150sec(infer)\n",
      "Epoch 79 tst: l 0.432 a 0.871 clct[np.int64(10), np.int64(7), np.int64(11), np.int64(12)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 80 tr: l 0.309 a 0.903 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 7.830sec(train) 2.149sec(infer)\n",
      "Epoch 80 tst: l 0.431 a 0.867 clct[np.int64(10), np.int64(7), np.int64(11), np.int64(12)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 81 tr: l 0.307 a 0.903 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 7.906sec(train) 2.954sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 81 tst: l 0.430 a 0.873 clct[np.int64(10), np.int64(7), np.int64(11), np.int64(12)]  0.217sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 82 tr: l 0.305 a 0.904 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 8.395sec(train) 2.146sec(infer)\n",
      "Epoch 82 tst: l 0.430 a 0.869 clct[np.int64(10), np.int64(7), np.int64(11), np.int64(12)]  0.146sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 83 tr: l 0.303 a 0.905 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 7.670sec(train) 2.152sec(infer)\n",
      "Epoch 83 tst: l 0.429 a 0.873 clct[np.int64(10), np.int64(7), np.int64(11), np.int64(12)]  0.146sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 84 tr: l 0.301 a 0.905 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 8.070sec(train) 2.824sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 84 tst: l 0.429 a 0.869 clct[np.int64(10), np.int64(7), np.int64(11), np.int64(12)]  0.221sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 85 tr: l 0.299 a 0.906 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 8.191sec(train) 2.150sec(infer)\n",
      "Epoch 85 tst: l 0.427 a 0.872 clct[np.int64(10), np.int64(7), np.int64(11), np.int64(12)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 86 tr: l 0.298 a 0.906 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 7.671sec(train) 2.153sec(infer)\n",
      "Epoch 86 tst: l 0.427 a 0.869 clct[np.int64(10), np.int64(7), np.int64(11), np.int64(12)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 87 tr: l 0.296 a 0.907 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 8.076sec(train) 2.982sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 87 tst: l 0.426 a 0.873 clct[np.int64(10), np.int64(7), np.int64(11), np.int64(12)]  0.217sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 88 tr: l 0.294 a 0.907 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 8.143sec(train) 2.148sec(infer)\n",
      "Epoch 88 tst: l 0.427 a 0.869 clct[np.int64(10), np.int64(7), np.int64(11), np.int64(12)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 89 tr: l 0.292 a 0.907 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 7.845sec(train) 2.147sec(infer)\n",
      "Epoch 89 tst: l 0.425 a 0.872 clct[np.int64(10), np.int64(7), np.int64(11), np.int64(12)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 90 tr: l 0.290 a 0.908 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 7.883sec(train) 2.896sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 90 tst: l 0.426 a 0.870 clct[np.int64(10), np.int64(7), np.int64(11), np.int64(12)]  0.222sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 91 tr: l 0.288 a 0.909 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 8.249sec(train) 2.147sec(infer)\n",
      "Epoch 91 tst: l 0.424 a 0.873 clct[np.int64(10), np.int64(7), np.int64(11), np.int64(12)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 92 tr: l 0.287 a 0.909 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 7.831sec(train) 2.150sec(infer)\n",
      "Epoch 92 tst: l 0.424 a 0.870 clct[np.int64(10), np.int64(6), np.int64(11), np.int64(13)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 93 tr: l 0.285 a 0.909 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 7.903sec(train) 3.100sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 93 tst: l 0.423 a 0.874 clct[np.int64(10), np.int64(7), np.int64(11), np.int64(12)]  0.232sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 94 tr: l 0.283 a 0.910 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 8.289sec(train) 2.147sec(infer)\n",
      "Epoch 94 tst: l 0.423 a 0.870 clct[np.int64(10), np.int64(7), np.int64(11), np.int64(12)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 95 tr: l 0.281 a 0.910 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 7.658sec(train) 2.148sec(infer)\n",
      "Epoch 95 tst: l 0.422 a 0.873 clct[np.int64(10), np.int64(7), np.int64(11), np.int64(12)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 96 tr: l 0.280 a 0.911 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 7.945sec(train) 2.871sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 96 tst: l 0.422 a 0.870 clct[np.int64(10), np.int64(6), np.int64(11), np.int64(13)]  0.212sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 97 tr: l 0.278 a 0.911 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 8.314sec(train) 2.150sec(infer)\n",
      "Epoch 97 tst: l 0.421 a 0.873 clct[np.int64(10), np.int64(7), np.int64(11), np.int64(12)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 98 tr: l 0.277 a 0.912 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 7.652sec(train) 2.152sec(infer)\n",
      "Epoch 98 tst: l 0.421 a 0.870 clct[np.int64(10), np.int64(6), np.int64(11), np.int64(13)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 99 tr: l 0.275 a 0.912 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 8.435sec(train) 2.846sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 99 tst: l 0.420 a 0.874 clct[np.int64(10), np.int64(7), np.int64(10), np.int64(13)]  0.231sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 100 tr: l 0.274 a 0.912 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 8.031sec(train) 2.150sec(infer)\n",
      "Epoch 100 tst: l 0.420 a 0.870 clct[np.int64(10), np.int64(6), np.int64(11), np.int64(13)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 101 tr: l 0.272 a 0.913 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 7.653sec(train) 2.153sec(infer)\n",
      "Epoch 101 tst: l 0.419 a 0.874 clct[np.int64(10), np.int64(7), np.int64(10), np.int64(13)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 102 tr: l 0.271 a 0.913 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 8.311sec(train) 2.857sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 102 tst: l 0.420 a 0.870 clct[np.int64(10), np.int64(6), np.int64(11), np.int64(13)]  0.232sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 103 tr: l 0.269 a 0.914 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 7.971sec(train) 2.151sec(infer)\n",
      "Epoch 103 tst: l 0.418 a 0.874 clct[np.int64(10), np.int64(6), np.int64(10), np.int64(14)]  0.143sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 104 tr: l 0.267 a 0.914 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 7.950sec(train) 2.153sec(infer)\n",
      "Epoch 104 tst: l 0.419 a 0.872 clct[np.int64(10), np.int64(6), np.int64(11), np.int64(13)]  0.106sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 105 tr: l 0.266 a 0.915 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 8.129sec(train) 3.006sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 105 tst: l 0.418 a 0.874 clct[np.int64(10), np.int64(6), np.int64(10), np.int64(14)]  0.226sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 106 tr: l 0.265 a 0.915 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 8.119sec(train) 2.150sec(infer)\n",
      "Epoch 106 tst: l 0.418 a 0.872 clct[np.int64(10), np.int64(6), np.int64(11), np.int64(13)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 107 tr: l 0.263 a 0.916 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 7.670sec(train) 2.098sec(infer)\n",
      "Epoch 107 tst: l 0.417 a 0.874 clct[np.int64(10), np.int64(6), np.int64(10), np.int64(14)]  0.159sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 108 tr: l 0.262 a 0.916 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 8.116sec(train) 2.893sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 108 tst: l 0.417 a 0.873 clct[np.int64(11), np.int64(5), np.int64(10), np.int64(14)]  0.231sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 109 tr: l 0.260 a 0.917 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 8.196sec(train) 2.152sec(infer)\n",
      "Epoch 109 tst: l 0.416 a 0.874 clct[np.int64(10), np.int64(6), np.int64(10), np.int64(14)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 110 tr: l 0.259 a 0.917 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 7.655sec(train) 2.153sec(infer)\n",
      "Epoch 110 tst: l 0.416 a 0.871 clct[np.int64(12), np.int64(4), np.int64(10), np.int64(14)]  0.146sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 111 tr: l 0.257 a 0.917 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 8.350sec(train) 2.842sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 111 tst: l 0.416 a 0.875 clct[np.int64(11), np.int64(5), np.int64(10), np.int64(14)]  0.229sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 112 tr: l 0.256 a 0.918 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 7.925sec(train) 2.150sec(infer)\n",
      "Epoch 112 tst: l 0.416 a 0.872 clct[np.int64(12), np.int64(4), np.int64(10), np.int64(14)]  0.146sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 113 tr: l 0.254 a 0.918 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 7.657sec(train) 2.150sec(infer)\n",
      "Epoch 113 tst: l 0.415 a 0.875 clct[np.int64(11), np.int64(5), np.int64(10), np.int64(14)]  0.133sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 114 tr: l 0.253 a 0.918 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 8.596sec(train) 2.935sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 114 tst: l 0.415 a 0.872 clct[np.int64(12), np.int64(4), np.int64(10), np.int64(14)]  0.224sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 115 tr: l 0.251 a 0.919 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 7.841sec(train) 2.149sec(infer)\n",
      "Epoch 115 tst: l 0.415 a 0.876 clct[np.int64(11), np.int64(5), np.int64(10), np.int64(14)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 116 tr: l 0.251 a 0.919 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 7.841sec(train) 2.111sec(infer)\n",
      "Epoch 116 tst: l 0.415 a 0.873 clct[np.int64(12), np.int64(4), np.int64(10), np.int64(14)]  0.193sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 117 tr: l 0.249 a 0.920 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 8.344sec(train) 3.155sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 117 tst: l 0.414 a 0.876 clct[np.int64(11), np.int64(5), np.int64(10), np.int64(14)]  0.221sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 118 tr: l 0.248 a 0.920 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 7.700sec(train) 2.153sec(infer)\n",
      "Epoch 118 tst: l 0.414 a 0.875 clct[np.int64(12), np.int64(4), np.int64(10), np.int64(14)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 119 tr: l 0.246 a 0.921 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 7.833sec(train) 2.226sec(infer)\n",
      "Epoch 119 tst: l 0.414 a 0.875 clct[np.int64(11), np.int64(5), np.int64(10), np.int64(14)]  0.194sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 120 tr: l 0.245 a 0.921 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 8.582sec(train) 2.872sec(infer)\n",
      "Epoch 120 tst: l 0.414 a 0.876 clct[np.int64(12), np.int64(4), np.int64(10), np.int64(14)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 121 tr: l 0.244 a 0.922 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 7.849sec(train) 2.147sec(infer)\n",
      "Epoch 121 tst: l 0.413 a 0.876 clct[np.int64(10), np.int64(5), np.int64(10), np.int64(15)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 122 tr: l 0.243 a 0.921 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 7.661sec(train) 2.441sec(infer)\n",
      "Epoch 122 tst: l 0.413 a 0.875 clct[np.int64(12), np.int64(4), np.int64(10), np.int64(14)]  0.158sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 123 tr: l 0.241 a 0.922 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 8.757sec(train) 2.512sec(infer)\n",
      "Epoch 123 tst: l 0.413 a 0.876 clct[np.int64(10), np.int64(5), np.int64(10), np.int64(15)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 124 tr: l 0.240 a 0.922 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 7.863sec(train) 2.152sec(infer)\n",
      "Epoch 124 tst: l 0.413 a 0.876 clct[np.int64(12), np.int64(4), np.int64(10), np.int64(14)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 125 tr: l 0.239 a 0.923 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 7.671sec(train) 2.321sec(infer)\n",
      "Epoch 125 tst: l 0.412 a 0.876 clct[np.int64(10), np.int64(5), np.int64(10), np.int64(15)]  0.159sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 126 tr: l 0.238 a 0.923 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 8.912sec(train) 2.397sec(infer)\n",
      "Epoch 126 tst: l 0.412 a 0.877 clct[np.int64(12), np.int64(4), np.int64(10), np.int64(14)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 127 tr: l 0.236 a 0.924 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 7.666sec(train) 2.149sec(infer)\n",
      "Epoch 127 tst: l 0.411 a 0.875 clct[np.int64(10), np.int64(5), np.int64(10), np.int64(15)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 128 tr: l 0.236 a 0.924 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 7.826sec(train) 2.301sec(infer)\n",
      "Epoch 128 tst: l 0.412 a 0.877 clct[np.int64(12), np.int64(4), np.int64(10), np.int64(14)]  0.160sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 129 tr: l 0.234 a 0.924 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 8.861sec(train) 2.357sec(infer)\n",
      "Epoch 129 tst: l 0.411 a 0.876 clct[np.int64(10), np.int64(5), np.int64(10), np.int64(15)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 130 tr: l 0.233 a 0.924 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 7.624sec(train) 2.150sec(infer)\n",
      "Epoch 130 tst: l 0.411 a 0.876 clct[np.int64(12), np.int64(4), np.int64(10), np.int64(14)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 131 tr: l 0.232 a 0.925 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 7.899sec(train) 2.176sec(infer)\n",
      "Epoch 131 tst: l 0.411 a 0.875 clct[np.int64(11), np.int64(4), np.int64(10), np.int64(15)]  0.159sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 132 tr: l 0.231 a 0.925 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 9.067sec(train) 2.193sec(infer)\n",
      "Epoch 132 tst: l 0.411 a 0.876 clct[np.int64(12), np.int64(4), np.int64(10), np.int64(14)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 133 tr: l 0.230 a 0.926 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 7.835sec(train) 2.151sec(infer)\n",
      "Epoch 133 tst: l 0.411 a 0.874 clct[np.int64(11), np.int64(4), np.int64(10), np.int64(15)]  0.146sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 134 tr: l 0.229 a 0.926 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 7.631sec(train) 2.158sec(infer)\n",
      "Epoch 134 tst: l 0.411 a 0.875 clct[np.int64(12), np.int64(4), np.int64(10), np.int64(14)]  0.158sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 135 tr: l 0.227 a 0.926 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 9.085sec(train) 2.155sec(infer)\n",
      "Epoch 135 tst: l 0.410 a 0.875 clct[np.int64(11), np.int64(4), np.int64(10), np.int64(15)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 136 tr: l 0.227 a 0.927 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 8.420sec(train) 2.150sec(infer)\n",
      "Epoch 136 tst: l 0.410 a 0.876 clct[np.int64(12), np.int64(4), np.int64(10), np.int64(14)]  0.146sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 137 tr: l 0.225 a 0.927 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 7.631sec(train) 2.045sec(infer)\n",
      "Epoch 137 tst: l 0.410 a 0.875 clct[np.int64(11), np.int64(4), np.int64(10), np.int64(15)]  0.159sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 138 tr: l 0.224 a 0.927 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 9.071sec(train) 2.191sec(infer)\n",
      "Epoch 138 tst: l 0.410 a 0.874 clct[np.int64(11), np.int64(4), np.int64(10), np.int64(15)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 139 tr: l 0.223 a 0.928 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 7.630sec(train) 2.145sec(infer)\n",
      "Epoch 139 tst: l 0.410 a 0.876 clct[np.int64(11), np.int64(4), np.int64(10), np.int64(15)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 140 tr: l 0.222 a 0.928 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 7.825sec(train) 2.156sec(infer)\n",
      "Epoch 140 tst: l 0.410 a 0.876 clct[np.int64(12), np.int64(4), np.int64(10), np.int64(14)]  0.160sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 141 tr: l 0.221 a 0.928 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 9.084sec(train) 2.150sec(infer)\n",
      "Epoch 141 tst: l 0.409 a 0.876 clct[np.int64(11), np.int64(4), np.int64(10), np.int64(15)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 142 tr: l 0.220 a 0.929 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 7.635sec(train) 2.149sec(infer)\n",
      "Epoch 142 tst: l 0.409 a 0.877 clct[np.int64(12), np.int64(4), np.int64(10), np.int64(14)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 143 tr: l 0.219 a 0.929 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 7.810sec(train) 2.134sec(infer)\n",
      "Epoch 143 tst: l 0.409 a 0.875 clct[np.int64(11), np.int64(4), np.int64(10), np.int64(15)]  0.161sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 144 tr: l 0.218 a 0.929 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 9.197sec(train) 2.148sec(infer)\n",
      "Epoch 144 tst: l 0.409 a 0.875 clct[np.int64(11), np.int64(4), np.int64(10), np.int64(15)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 145 tr: l 0.217 a 0.930 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 7.808sec(train) 2.146sec(infer)\n",
      "Epoch 145 tst: l 0.409 a 0.875 clct[np.int64(11), np.int64(4), np.int64(10), np.int64(15)]  0.146sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 146 tr: l 0.219 a 0.929 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 7.646sec(train) 2.141sec(infer)\n",
      "Epoch 146 tst: l 0.410 a 0.875 clct[np.int64(12), np.int64(3), np.int64(10), np.int64(15)]  0.159sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 147 tr: l 0.219 a 0.929 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 9.237sec(train) 2.153sec(infer)\n",
      "Epoch 147 tst: l 0.412 a 0.874 clct[np.int64(12), np.int64(2), np.int64(10), np.int64(16)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 148 tr: l 0.217 a 0.929 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 7.628sec(train) 2.154sec(infer)\n",
      "Epoch 148 tst: l 0.410 a 0.875 clct[np.int64(11), np.int64(3), np.int64(10), np.int64(16)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 149 tr: l 0.214 a 0.930 clct[np.int64(115), np.int64(40), np.int64(126), np.int64(119)]  lr 0.100000 8.522sec(train) 1.932sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 149 tst: l 0.410 a 0.876 clct[np.int64(11), np.int64(3), np.int64(10), np.int64(16)]  0.232sec\n",
      "result written at output_dfca_gi/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "---train cluster Ended in 0.46 hour (1651.602 sec) \n",
      "---------------------------------IFCA, lr: 0.1, seed: 409---------------------------------\n",
      "config: {'m': 400, 'm_test': 40, 'p': 4, 'n': 2000, 'uneven': False, 'local_model_init': False, 'Gp': 0.2, 'graph': 'fixed', 'h1': 512, 'num_epochs': 150, 'batch_size': 100, 'tau': 5, 'lr': 0.1, 'data_seed': 409, 'train_seed': 409, 'config_override': '', 'project_dir': 'output_dfca_gi'}\n",
      "Using device: cuda:3\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      "Generating partition_id_to_indices: 0it [00:00, ?it/s]"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      "Generating partition_id_to_indices: 128523it [00:00, 1285114.80it/s]"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      "Generating partition_id_to_indices: 267360it [00:00, 1345798.82it/s]"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      "Generating partition_id_to_indices: 404223it [00:00, 1356197.60it/s]"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      "Generating partition_id_to_indices: 540460it [00:00, 1358609.24it/s]"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      "Generating partition_id_to_indices: 676531it [00:00, 1359340.35it/s]"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      "Generating partition_id_to_indices: 812466it [00:00, 1358966.23it/s]"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      "Generating partition_id_to_indices: 814277it [00:00, 1351771.59it/s]"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch -1 tr: l 4.111 a 0.025 clct[np.int64(89), np.int64(3), np.int64(269), np.int64(39)]  2.171sec\n",
      "Epoch -1 tst: l 4.102 a 0.026 clct[np.int64(9), np.int64(2), np.int64(19), np.int64(10)]  0.146sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0 tr: l 3.390 a 0.281 clct[np.int64(370), np.int64(8), np.int64(9), np.int64(13)]  lr 0.100000 7.285sec(train) 2.354sec(infer)\n",
      "Epoch 0 tst: l 3.399 a 0.287 clct[np.int64(34), np.int64(3), np.int64(1), np.int64(2)]  0.158sec\n",
      "result written at output_dfca_gi/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1 tr: l 2.708 a 0.416 clct[np.int64(204), np.int64(26), np.int64(21), np.int64(149)]  lr 0.100000 8.068sec(train) 3.114sec(infer)\n",
      "Epoch 1 tst: l 2.679 a 0.426 clct[np.int64(17), np.int64(5), np.int64(4), np.int64(14)]  0.146sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2 tr: l 2.162 a 0.562 clct[np.int64(144), np.int64(5), np.int64(33), np.int64(218)]  lr 0.100000 7.662sec(train) 2.149sec(infer)\n",
      "Epoch 2 tst: l 2.135 a 0.576 clct[np.int64(12), np.int64(1), np.int64(4), np.int64(23)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3 tr: l 1.733 a 0.617 clct[np.int64(153), np.int64(5), np.int64(65), np.int64(177)]  lr 0.100000 8.434sec(train) 2.157sec(infer)\n",
      "Epoch 3 tst: l 1.687 a 0.638 clct[np.int64(14), np.int64(0), np.int64(10), np.int64(16)]  0.160sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4 tr: l 1.492 a 0.664 clct[np.int64(151), np.int64(5), np.int64(65), np.int64(179)]  lr 0.100000 9.466sec(train) 2.154sec(infer)\n",
      "Epoch 4 tst: l 1.444 a 0.682 clct[np.int64(13), np.int64(0), np.int64(10), np.int64(17)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5 tr: l 1.320 a 0.690 clct[np.int64(151), np.int64(6), np.int64(76), np.int64(167)]  lr 0.100000 8.381sec(train) 2.150sec(infer)\n",
      "Epoch 5 tst: l 1.274 a 0.705 clct[np.int64(13), np.int64(0), np.int64(11), np.int64(16)]  0.146sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6 tr: l 1.194 a 0.714 clct[np.int64(151), np.int64(6), np.int64(73), np.int64(170)]  lr 0.100000 7.922sec(train) 2.910sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6 tst: l 1.145 a 0.731 clct[np.int64(13), np.int64(0), np.int64(11), np.int64(16)]  0.326sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7 tr: l 1.088 a 0.733 clct[np.int64(154), np.int64(6), np.int64(77), np.int64(163)]  lr 0.100000 8.752sec(train) 2.153sec(infer)\n",
      "Epoch 7 tst: l 1.048 a 0.740 clct[np.int64(13), np.int64(0), np.int64(12), np.int64(15)]  0.149sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8 tr: l 1.010 a 0.747 clct[np.int64(154), np.int64(6), np.int64(80), np.int64(160)]  lr 0.100000 7.702sec(train) 2.147sec(infer)\n",
      "Epoch 8 tst: l 0.967 a 0.762 clct[np.int64(12), np.int64(0), np.int64(11), np.int64(17)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9 tr: l 0.945 a 0.760 clct[np.int64(157), np.int64(6), np.int64(81), np.int64(156)]  lr 0.100000 8.042sec(train) 2.861sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9 tst: l 0.910 a 0.766 clct[np.int64(14), np.int64(0), np.int64(12), np.int64(14)]  0.226sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10 tr: l 0.891 a 0.770 clct[np.int64(152), np.int64(6), np.int64(82), np.int64(160)]  lr 0.100000 8.346sec(train) 2.151sec(infer)\n",
      "Epoch 10 tst: l 0.854 a 0.779 clct[np.int64(14), np.int64(0), np.int64(11), np.int64(15)]  0.144sec\n",
      "result written at output_dfca_gi/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11 tr: l 0.847 a 0.778 clct[np.int64(160), np.int64(6), np.int64(84), np.int64(150)]  lr 0.100000 7.927sec(train) 2.148sec(infer)\n",
      "Epoch 11 tst: l 0.819 a 0.780 clct[np.int64(15), np.int64(0), np.int64(12), np.int64(13)]  0.147sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12 tr: l 0.806 a 0.787 clct[np.int64(155), np.int64(6), np.int64(89), np.int64(150)]  lr 0.100000 7.721sec(train) 2.866sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12 tst: l 0.775 a 0.797 clct[np.int64(14), np.int64(0), np.int64(12), np.int64(14)]  0.216sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13 tr: l 0.772 a 0.793 clct[np.int64(164), np.int64(6), np.int64(88), np.int64(142)]  lr 0.100000 8.415sec(train) 2.150sec(infer)\n",
      "Epoch 13 tst: l 0.751 a 0.796 clct[np.int64(15), np.int64(0), np.int64(12), np.int64(13)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14 tr: l 0.741 a 0.801 clct[np.int64(164), np.int64(6), np.int64(90), np.int64(140)]  lr 0.100000 7.927sec(train) 2.116sec(infer)\n",
      "Epoch 14 tst: l 0.715 a 0.812 clct[np.int64(16), np.int64(0), np.int64(11), np.int64(13)]  0.142sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15 tr: l 0.715 a 0.804 clct[np.int64(168), np.int64(6), np.int64(89), np.int64(137)]  lr 0.100000 7.670sec(train) 3.042sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15 tst: l 0.700 a 0.807 clct[np.int64(15), np.int64(0), np.int64(12), np.int64(13)]  0.223sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16 tr: l 0.691 a 0.812 clct[np.int64(167), np.int64(6), np.int64(90), np.int64(137)]  lr 0.100000 8.664sec(train) 2.153sec(infer)\n",
      "Epoch 16 tst: l 0.671 a 0.817 clct[np.int64(16), np.int64(0), np.int64(11), np.int64(13)]  0.147sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17 tr: l 0.670 a 0.814 clct[np.int64(170), np.int64(6), np.int64(90), np.int64(134)]  lr 0.100000 7.680sec(train) 2.137sec(infer)\n",
      "Epoch 17 tst: l 0.660 a 0.813 clct[np.int64(17), np.int64(0), np.int64(11), np.int64(12)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18 tr: l 0.650 a 0.820 clct[np.int64(170), np.int64(6), np.int64(89), np.int64(135)]  lr 0.100000 7.904sec(train) 2.876sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18 tst: l 0.636 a 0.823 clct[np.int64(16), np.int64(0), np.int64(11), np.int64(13)]  0.227sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19 tr: l 0.633 a 0.822 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 8.363sec(train) 2.152sec(infer)\n",
      "Epoch 19 tst: l 0.629 a 0.818 clct[np.int64(19), np.int64(0), np.int64(10), np.int64(11)]  0.146sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20 tr: l 0.617 a 0.826 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 7.690sec(train) 2.130sec(infer)\n",
      "Epoch 20 tst: l 0.609 a 0.829 clct[np.int64(16), np.int64(0), np.int64(11), np.int64(13)]  0.142sec\n",
      "result written at output_dfca_gi/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21 tr: l 0.604 a 0.828 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 7.910sec(train) 2.912sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21 tst: l 0.603 a 0.823 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)]  0.217sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22 tr: l 0.590 a 0.833 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 8.413sec(train) 2.147sec(infer)\n",
      "Epoch 22 tst: l 0.586 a 0.835 clct[np.int64(17), np.int64(0), np.int64(11), np.int64(12)]  0.146sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23 tr: l 0.578 a 0.834 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 7.878sec(train) 2.149sec(infer)\n",
      "Epoch 23 tst: l 0.581 a 0.831 clct[np.int64(21), np.int64(0), np.int64(10), np.int64(9)]  0.148sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24 tr: l 0.566 a 0.838 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 7.663sec(train) 2.773sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24 tst: l 0.567 a 0.839 clct[np.int64(18), np.int64(0), np.int64(11), np.int64(11)]  0.218sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25 tr: l 0.556 a 0.839 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 8.495sec(train) 2.152sec(infer)\n",
      "Epoch 25 tst: l 0.562 a 0.834 clct[np.int64(21), np.int64(0), np.int64(10), np.int64(9)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 26 tr: l 0.546 a 0.843 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 7.907sec(train) 2.154sec(infer)\n",
      "Epoch 26 tst: l 0.551 a 0.844 clct[np.int64(19), np.int64(0), np.int64(11), np.int64(10)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 27 tr: l 0.537 a 0.844 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 7.701sec(train) 3.011sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 27 tst: l 0.547 a 0.839 clct[np.int64(21), np.int64(0), np.int64(10), np.int64(9)]  0.238sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 28 tr: l 0.528 a 0.847 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 8.614sec(train) 2.153sec(infer)\n",
      "Epoch 28 tst: l 0.536 a 0.847 clct[np.int64(20), np.int64(0), np.int64(11), np.int64(9)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 29 tr: l 0.520 a 0.848 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 7.926sec(train) 2.152sec(infer)\n",
      "Epoch 29 tst: l 0.533 a 0.841 clct[np.int64(20), np.int64(0), np.int64(11), np.int64(9)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 30 tr: l 0.511 a 0.850 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 7.711sec(train) 3.105sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 30 tst: l 0.523 a 0.848 clct[np.int64(19), np.int64(0), np.int64(12), np.int64(9)]  0.222sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 31 tr: l 0.505 a 0.851 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 8.454sec(train) 2.152sec(infer)\n",
      "Epoch 31 tst: l 0.521 a 0.844 clct[np.int64(19), np.int64(0), np.int64(12), np.int64(9)]  0.143sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 32 tr: l 0.497 a 0.854 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 8.404sec(train) 2.100sec(infer)\n",
      "Epoch 32 tst: l 0.512 a 0.850 clct[np.int64(19), np.int64(0), np.int64(12), np.int64(9)]  0.142sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 33 tr: l 0.491 a 0.854 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 8.153sec(train) 3.182sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 33 tst: l 0.510 a 0.847 clct[np.int64(19), np.int64(0), np.int64(12), np.int64(9)]  0.218sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 34 tr: l 0.484 a 0.857 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 8.112sec(train) 2.152sec(infer)\n",
      "Epoch 34 tst: l 0.502 a 0.852 clct[np.int64(19), np.int64(0), np.int64(12), np.int64(9)]  0.147sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 35 tr: l 0.478 a 0.857 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 7.916sec(train) 2.152sec(infer)\n",
      "Epoch 35 tst: l 0.500 a 0.850 clct[np.int64(19), np.int64(0), np.int64(12), np.int64(9)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 36 tr: l 0.472 a 0.860 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 8.103sec(train) 2.912sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 36 tst: l 0.493 a 0.854 clct[np.int64(19), np.int64(0), np.int64(12), np.int64(9)]  0.230sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 37 tr: l 0.467 a 0.860 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 8.272sec(train) 2.148sec(infer)\n",
      "Epoch 37 tst: l 0.492 a 0.852 clct[np.int64(19), np.int64(0), np.int64(12), np.int64(9)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 38 tr: l 0.461 a 0.863 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 7.693sec(train) 2.153sec(infer)\n",
      "Epoch 38 tst: l 0.485 a 0.858 clct[np.int64(19), np.int64(0), np.int64(12), np.int64(9)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 39 tr: l 0.456 a 0.863 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 8.060sec(train) 2.834sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 39 tst: l 0.484 a 0.854 clct[np.int64(19), np.int64(0), np.int64(12), np.int64(9)]  0.225sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 40 tr: l 0.451 a 0.865 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 8.340sec(train) 2.152sec(infer)\n",
      "Epoch 40 tst: l 0.478 a 0.859 clct[np.int64(19), np.int64(0), np.int64(12), np.int64(9)]  0.146sec\n",
      "result written at output_dfca_gi/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 41 tr: l 0.446 a 0.866 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 7.696sec(train) 2.132sec(infer)\n",
      "Epoch 41 tst: l 0.477 a 0.855 clct[np.int64(19), np.int64(0), np.int64(12), np.int64(9)]  0.142sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 42 tr: l 0.441 a 0.868 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 8.149sec(train) 2.818sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 42 tst: l 0.471 a 0.859 clct[np.int64(19), np.int64(0), np.int64(12), np.int64(9)]  0.246sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 43 tr: l 0.437 a 0.868 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 8.120sec(train) 2.151sec(infer)\n",
      "Epoch 43 tst: l 0.471 a 0.856 clct[np.int64(19), np.int64(0), np.int64(12), np.int64(9)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 44 tr: l 0.433 a 0.870 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 7.690sec(train) 2.097sec(infer)\n",
      "Epoch 44 tst: l 0.465 a 0.860 clct[np.int64(19), np.int64(0), np.int64(12), np.int64(9)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 45 tr: l 0.429 a 0.870 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 8.158sec(train) 2.839sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 45 tst: l 0.465 a 0.856 clct[np.int64(19), np.int64(0), np.int64(12), np.int64(9)]  0.219sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 46 tr: l 0.424 a 0.872 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 8.246sec(train) 2.146sec(infer)\n",
      "Epoch 46 tst: l 0.460 a 0.859 clct[np.int64(19), np.int64(0), np.int64(12), np.int64(9)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 47 tr: l 0.421 a 0.872 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 7.953sec(train) 2.154sec(infer)\n",
      "Epoch 47 tst: l 0.460 a 0.857 clct[np.int64(19), np.int64(0), np.int64(12), np.int64(9)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 48 tr: l 0.417 a 0.874 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 7.977sec(train) 2.925sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 48 tst: l 0.455 a 0.861 clct[np.int64(19), np.int64(0), np.int64(11), np.int64(10)]  0.214sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 49 tr: l 0.413 a 0.874 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 8.211sec(train) 2.154sec(infer)\n",
      "Epoch 49 tst: l 0.455 a 0.858 clct[np.int64(19), np.int64(0), np.int64(12), np.int64(9)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 50 tr: l 0.409 a 0.876 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 8.751sec(train) 2.158sec(infer)\n",
      "Epoch 50 tst: l 0.450 a 0.864 clct[np.int64(19), np.int64(0), np.int64(11), np.int64(10)]  0.130sec\n",
      "result written at output_dfca_gi/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 51 tr: l 0.406 a 0.876 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 8.255sec(train) 3.273sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 51 tst: l 0.450 a 0.861 clct[np.int64(19), np.int64(0), np.int64(12), np.int64(9)]  0.229sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 52 tr: l 0.402 a 0.877 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 7.997sec(train) 2.151sec(infer)\n",
      "Epoch 52 tst: l 0.446 a 0.866 clct[np.int64(18), np.int64(0), np.int64(11), np.int64(11)]  0.146sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 53 tr: l 0.399 a 0.878 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 7.689sec(train) 2.176sec(infer)\n",
      "Epoch 53 tst: l 0.446 a 0.862 clct[np.int64(19), np.int64(0), np.int64(12), np.int64(9)]  0.192sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 54 tr: l 0.396 a 0.879 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 8.674sec(train) 2.856sec(infer)\n",
      "Epoch 54 tst: l 0.442 a 0.868 clct[np.int64(18), np.int64(0), np.int64(11), np.int64(11)]  0.188sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 55 tr: l 0.393 a 0.879 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 7.983sec(train) 2.148sec(infer)\n",
      "Epoch 55 tst: l 0.442 a 0.866 clct[np.int64(19), np.int64(0), np.int64(11), np.int64(10)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 56 tr: l 0.390 a 0.881 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 7.702sec(train) 2.276sec(infer)\n",
      "Epoch 56 tst: l 0.438 a 0.870 clct[np.int64(19), np.int64(0), np.int64(10), np.int64(11)]  0.194sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 57 tr: l 0.387 a 0.881 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 8.737sec(train) 2.713sec(infer)\n",
      "Epoch 57 tst: l 0.439 a 0.867 clct[np.int64(19), np.int64(0), np.int64(11), np.int64(10)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 58 tr: l 0.384 a 0.882 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 7.701sec(train) 2.149sec(infer)\n",
      "Epoch 58 tst: l 0.434 a 0.870 clct[np.int64(19), np.int64(0), np.int64(10), np.int64(11)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 59 tr: l 0.381 a 0.882 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 7.897sec(train) 2.386sec(infer)\n",
      "Epoch 59 tst: l 0.435 a 0.868 clct[np.int64(19), np.int64(0), np.int64(11), np.int64(10)]  0.171sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 60 tr: l 0.378 a 0.884 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 8.764sec(train) 2.538sec(infer)\n",
      "Epoch 60 tst: l 0.431 a 0.871 clct[np.int64(19), np.int64(0), np.int64(10), np.int64(11)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 61 tr: l 0.375 a 0.884 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 8.035sec(train) 2.151sec(infer)\n",
      "Epoch 61 tst: l 0.432 a 0.868 clct[np.int64(19), np.int64(0), np.int64(10), np.int64(11)]  0.150sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 62 tr: l 0.372 a 0.885 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 7.914sec(train) 2.205sec(infer)\n",
      "Epoch 62 tst: l 0.428 a 0.872 clct[np.int64(19), np.int64(0), np.int64(10), np.int64(11)]  0.157sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 63 tr: l 0.370 a 0.885 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 9.043sec(train) 2.187sec(infer)\n",
      "Epoch 63 tst: l 0.429 a 0.869 clct[np.int64(19), np.int64(0), np.int64(10), np.int64(11)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 64 tr: l 0.367 a 0.887 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 7.907sec(train) 2.149sec(infer)\n",
      "Epoch 64 tst: l 0.425 a 0.872 clct[np.int64(20), np.int64(0), np.int64(9), np.int64(11)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 65 tr: l 0.365 a 0.887 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 8.992sec(train) 2.172sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 65 tst: l 0.426 a 0.870 clct[np.int64(20), np.int64(0), np.int64(9), np.int64(11)]  0.245sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 66 tr: l 0.362 a 0.888 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 8.793sec(train) 2.149sec(infer)\n",
      "Epoch 66 tst: l 0.422 a 0.874 clct[np.int64(20), np.int64(0), np.int64(9), np.int64(11)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 67 tr: l 0.360 a 0.888 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 8.432sec(train) 2.153sec(infer)\n",
      "Epoch 67 tst: l 0.423 a 0.872 clct[np.int64(20), np.int64(0), np.int64(9), np.int64(11)]  0.146sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 68 tr: l 0.357 a 0.889 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 7.714sec(train) 1.714sec(infer)\n",
      "Epoch 68 tst: l 0.420 a 0.876 clct[np.int64(20), np.int64(0), np.int64(9), np.int64(11)]  0.100sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 69 tr: l 0.355 a 0.889 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 8.548sec(train) 1.099sec(infer)\n",
      "Epoch 69 tst: l 0.421 a 0.873 clct[np.int64(20), np.int64(0), np.int64(9), np.int64(11)]  0.100sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 70 tr: l 0.353 a 0.890 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 8.658sec(train) 1.104sec(infer)\n",
      "Epoch 70 tst: l 0.418 a 0.877 clct[np.int64(20), np.int64(0), np.int64(9), np.int64(11)]  0.102sec\n",
      "result written at output_dfca_gi/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 71 tr: l 0.350 a 0.890 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 7.452sec(train) 1.103sec(infer)\n",
      "Epoch 71 tst: l 0.418 a 0.874 clct[np.int64(20), np.int64(0), np.int64(9), np.int64(11)]  0.101sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 72 tr: l 0.348 a 0.892 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 7.964sec(train) 1.100sec(infer)\n",
      "Epoch 72 tst: l 0.415 a 0.877 clct[np.int64(20), np.int64(0), np.int64(9), np.int64(11)]  0.100sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 73 tr: l 0.346 a 0.891 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 8.666sec(train) 1.105sec(infer)\n",
      "Epoch 73 tst: l 0.416 a 0.875 clct[np.int64(20), np.int64(0), np.int64(9), np.int64(11)]  0.101sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 74 tr: l 0.344 a 0.893 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 6.531sec(train) 1.916sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 74 tst: l 0.413 a 0.878 clct[np.int64(20), np.int64(0), np.int64(9), np.int64(11)]  0.259sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 75 tr: l 0.342 a 0.893 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 9.074sec(train) 2.138sec(infer)\n",
      "Epoch 75 tst: l 0.414 a 0.875 clct[np.int64(20), np.int64(0), np.int64(9), np.int64(11)]  0.148sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 76 tr: l 0.340 a 0.894 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 7.764sec(train) 2.142sec(infer)\n",
      "Epoch 76 tst: l 0.411 a 0.878 clct[np.int64(20), np.int64(0), np.int64(9), np.int64(11)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 77 tr: l 0.338 a 0.894 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 8.128sec(train) 1.928sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 77 tst: l 0.412 a 0.876 clct[np.int64(20), np.int64(0), np.int64(9), np.int64(11)]  0.220sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 78 tr: l 0.335 a 0.895 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 9.107sec(train) 2.145sec(infer)\n",
      "Epoch 78 tst: l 0.409 a 0.878 clct[np.int64(20), np.int64(0), np.int64(9), np.int64(11)]  0.147sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 79 tr: l 0.333 a 0.895 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 7.857sec(train) 2.138sec(infer)\n",
      "Epoch 79 tst: l 0.410 a 0.877 clct[np.int64(20), np.int64(0), np.int64(9), np.int64(11)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 80 tr: l 0.331 a 0.896 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 7.644sec(train) 1.964sec(infer)\n",
      "Epoch 80 tst: l 0.408 a 0.878 clct[np.int64(20), np.int64(0), np.int64(9), np.int64(11)]  0.157sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 81 tr: l 0.329 a 0.896 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 8.925sec(train) 2.144sec(infer)\n",
      "Epoch 81 tst: l 0.408 a 0.877 clct[np.int64(20), np.int64(0), np.int64(9), np.int64(11)]  0.146sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 82 tr: l 0.328 a 0.897 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 7.859sec(train) 2.141sec(infer)\n",
      "Epoch 82 tst: l 0.407 a 0.878 clct[np.int64(20), np.int64(0), np.int64(9), np.int64(11)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 83 tr: l 0.326 a 0.897 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 8.481sec(train) 2.006sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 83 tst: l 0.406 a 0.877 clct[np.int64(20), np.int64(0), np.int64(9), np.int64(11)]  0.224sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 84 tr: l 0.324 a 0.898 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 9.051sec(train) 2.149sec(infer)\n",
      "Epoch 84 tst: l 0.405 a 0.879 clct[np.int64(21), np.int64(0), np.int64(8), np.int64(11)]  0.146sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 85 tr: l 0.322 a 0.898 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 7.638sec(train) 2.143sec(infer)\n",
      "Epoch 85 tst: l 0.405 a 0.877 clct[np.int64(20), np.int64(0), np.int64(9), np.int64(11)]  0.143sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 86 tr: l 0.320 a 0.899 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 7.833sec(train) 1.947sec(infer)\n",
      "Epoch 86 tst: l 0.404 a 0.880 clct[np.int64(21), np.int64(0), np.int64(8), np.int64(11)]  0.193sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 87 tr: l 0.318 a 0.899 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 9.028sec(train) 2.156sec(infer)\n",
      "Epoch 87 tst: l 0.403 a 0.878 clct[np.int64(20), np.int64(0), np.int64(9), np.int64(11)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 88 tr: l 0.317 a 0.900 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 7.632sec(train) 2.147sec(infer)\n",
      "Epoch 88 tst: l 0.402 a 0.880 clct[np.int64(21), np.int64(0), np.int64(8), np.int64(11)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 89 tr: l 0.315 a 0.900 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 7.867sec(train) 2.026sec(infer)\n",
      "Epoch 89 tst: l 0.402 a 0.878 clct[np.int64(20), np.int64(0), np.int64(9), np.int64(11)]  0.159sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 90 tr: l 0.313 a 0.901 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 9.140sec(train) 2.139sec(infer)\n",
      "Epoch 90 tst: l 0.401 a 0.880 clct[np.int64(21), np.int64(0), np.int64(8), np.int64(11)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 91 tr: l 0.312 a 0.901 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 7.829sec(train) 2.144sec(infer)\n",
      "Epoch 91 tst: l 0.401 a 0.879 clct[np.int64(21), np.int64(0), np.int64(8), np.int64(11)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 92 tr: l 0.310 a 0.902 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 7.639sec(train) 2.014sec(infer)\n",
      "Epoch 92 tst: l 0.400 a 0.881 clct[np.int64(21), np.int64(0), np.int64(8), np.int64(11)]  0.159sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 93 tr: l 0.308 a 0.902 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 9.088sec(train) 2.151sec(infer)\n",
      "Epoch 93 tst: l 0.400 a 0.881 clct[np.int64(21), np.int64(0), np.int64(8), np.int64(11)]  0.146sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 94 tr: l 0.307 a 0.902 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 7.938sec(train) 2.143sec(infer)\n",
      "Epoch 94 tst: l 0.399 a 0.881 clct[np.int64(21), np.int64(0), np.int64(8), np.int64(11)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 95 tr: l 0.305 a 0.903 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 7.630sec(train) 2.017sec(infer)\n",
      "Epoch 95 tst: l 0.398 a 0.881 clct[np.int64(21), np.int64(0), np.int64(8), np.int64(11)]  0.157sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 96 tr: l 0.304 a 0.903 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 9.336sec(train) 2.147sec(infer)\n",
      "Epoch 96 tst: l 0.398 a 0.882 clct[np.int64(21), np.int64(0), np.int64(8), np.int64(11)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 97 tr: l 0.302 a 0.904 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 8.077sec(train) 2.145sec(infer)\n",
      "Epoch 97 tst: l 0.397 a 0.881 clct[np.int64(21), np.int64(0), np.int64(8), np.int64(11)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 98 tr: l 0.301 a 0.904 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 7.652sec(train) 1.965sec(infer)\n",
      "Epoch 98 tst: l 0.396 a 0.883 clct[np.int64(21), np.int64(0), np.int64(8), np.int64(11)]  0.160sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 99 tr: l 0.299 a 0.905 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 9.244sec(train) 2.147sec(infer)\n",
      "Epoch 99 tst: l 0.396 a 0.882 clct[np.int64(21), np.int64(0), np.int64(8), np.int64(11)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 100 tr: l 0.298 a 0.905 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 7.629sec(train) 2.144sec(infer)\n",
      "Epoch 100 tst: l 0.395 a 0.884 clct[np.int64(21), np.int64(0), np.int64(8), np.int64(11)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 101 tr: l 0.296 a 0.905 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 7.843sec(train) 1.975sec(infer)\n",
      "Epoch 101 tst: l 0.395 a 0.884 clct[np.int64(21), np.int64(0), np.int64(8), np.int64(11)]  0.159sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 102 tr: l 0.295 a 0.906 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 9.025sec(train) 2.148sec(infer)\n",
      "Epoch 102 tst: l 0.395 a 0.884 clct[np.int64(21), np.int64(0), np.int64(8), np.int64(11)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 103 tr: l 0.293 a 0.906 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 7.669sec(train) 2.142sec(infer)\n",
      "Epoch 103 tst: l 0.394 a 0.885 clct[np.int64(21), np.int64(0), np.int64(8), np.int64(11)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 104 tr: l 0.292 a 0.907 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 7.818sec(train) 2.103sec(infer)\n",
      "Epoch 104 tst: l 0.394 a 0.885 clct[np.int64(21), np.int64(0), np.int64(8), np.int64(11)]  0.160sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 105 tr: l 0.290 a 0.907 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 9.106sec(train) 2.147sec(infer)\n",
      "Epoch 105 tst: l 0.393 a 0.885 clct[np.int64(21), np.int64(0), np.int64(8), np.int64(11)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 106 tr: l 0.289 a 0.907 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 7.864sec(train) 2.147sec(infer)\n",
      "Epoch 106 tst: l 0.393 a 0.885 clct[np.int64(21), np.int64(0), np.int64(8), np.int64(11)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 107 tr: l 0.287 a 0.908 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 7.635sec(train) 2.106sec(infer)\n",
      "Epoch 107 tst: l 0.393 a 0.885 clct[np.int64(21), np.int64(0), np.int64(8), np.int64(11)]  0.159sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 108 tr: l 0.286 a 0.908 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 9.084sec(train) 2.151sec(infer)\n",
      "Epoch 108 tst: l 0.392 a 0.886 clct[np.int64(21), np.int64(0), np.int64(8), np.int64(11)]  0.147sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 109 tr: l 0.285 a 0.909 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 7.844sec(train) 2.143sec(infer)\n",
      "Epoch 109 tst: l 0.392 a 0.885 clct[np.int64(21), np.int64(0), np.int64(8), np.int64(11)]  0.143sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 110 tr: l 0.283 a 0.909 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 7.645sec(train) 2.119sec(infer)\n",
      "Epoch 110 tst: l 0.391 a 0.886 clct[np.int64(21), np.int64(0), np.int64(8), np.int64(11)]  0.161sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 111 tr: l 0.282 a 0.909 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 9.355sec(train) 2.152sec(infer)\n",
      "Epoch 111 tst: l 0.391 a 0.886 clct[np.int64(21), np.int64(0), np.int64(8), np.int64(11)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 112 tr: l 0.281 a 0.910 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 7.631sec(train) 2.145sec(infer)\n",
      "Epoch 112 tst: l 0.390 a 0.887 clct[np.int64(21), np.int64(0), np.int64(8), np.int64(11)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 113 tr: l 0.280 a 0.910 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 8.261sec(train) 2.188sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 113 tst: l 0.391 a 0.886 clct[np.int64(21), np.int64(0), np.int64(8), np.int64(11)]  0.211sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 114 tr: l 0.278 a 0.911 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 8.735sec(train) 2.145sec(infer)\n",
      "Epoch 114 tst: l 0.390 a 0.888 clct[np.int64(21), np.int64(0), np.int64(8), np.int64(11)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 115 tr: l 0.277 a 0.911 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 7.636sec(train) 2.143sec(infer)\n",
      "Epoch 115 tst: l 0.390 a 0.886 clct[np.int64(21), np.int64(0), np.int64(8), np.int64(11)]  0.146sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 116 tr: l 0.276 a 0.911 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 8.439sec(train) 2.332sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 116 tst: l 0.389 a 0.887 clct[np.int64(21), np.int64(0), np.int64(8), np.int64(11)]  0.244sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 117 tr: l 0.275 a 0.911 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 8.690sec(train) 2.148sec(infer)\n",
      "Epoch 117 tst: l 0.389 a 0.887 clct[np.int64(21), np.int64(0), np.int64(8), np.int64(11)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 118 tr: l 0.273 a 0.912 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 7.853sec(train) 2.145sec(infer)\n",
      "Epoch 118 tst: l 0.389 a 0.888 clct[np.int64(21), np.int64(0), np.int64(8), np.int64(11)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 119 tr: l 0.272 a 0.912 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 7.639sec(train) 2.013sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 119 tst: l 0.389 a 0.887 clct[np.int64(21), np.int64(0), np.int64(8), np.int64(11)]  0.233sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 120 tr: l 0.271 a 0.912 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 8.845sec(train) 2.146sec(infer)\n",
      "Epoch 120 tst: l 0.388 a 0.887 clct[np.int64(21), np.int64(0), np.int64(8), np.int64(11)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 121 tr: l 0.270 a 0.912 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 7.811sec(train) 2.143sec(infer)\n",
      "Epoch 121 tst: l 0.388 a 0.887 clct[np.int64(21), np.int64(0), np.int64(8), np.int64(11)]  0.146sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 122 tr: l 0.268 a 0.913 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 8.292sec(train) 2.118sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 122 tst: l 0.388 a 0.888 clct[np.int64(21), np.int64(0), np.int64(8), np.int64(11)]  0.219sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 123 tr: l 0.267 a 0.913 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 8.955sec(train) 2.145sec(infer)\n",
      "Epoch 123 tst: l 0.388 a 0.887 clct[np.int64(21), np.int64(0), np.int64(8), np.int64(11)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 124 tr: l 0.266 a 0.914 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 8.535sec(train) 2.142sec(infer)\n",
      "Epoch 124 tst: l 0.388 a 0.887 clct[np.int64(21), np.int64(0), np.int64(8), np.int64(11)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 125 tr: l 0.265 a 0.914 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 8.142sec(train) 2.609sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 125 tst: l 0.387 a 0.887 clct[np.int64(21), np.int64(0), np.int64(8), np.int64(11)]  0.224sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 126 tr: l 0.264 a 0.914 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 8.751sec(train) 2.146sec(infer)\n",
      "Epoch 126 tst: l 0.387 a 0.887 clct[np.int64(21), np.int64(0), np.int64(8), np.int64(11)]  0.143sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 127 tr: l 0.263 a 0.914 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 7.612sec(train) 2.143sec(infer)\n",
      "Epoch 127 tst: l 0.387 a 0.888 clct[np.int64(21), np.int64(0), np.int64(8), np.int64(11)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 128 tr: l 0.262 a 0.915 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 7.783sec(train) 2.488sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 128 tst: l 0.386 a 0.888 clct[np.int64(21), np.int64(0), np.int64(8), np.int64(11)]  0.235sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 129 tr: l 0.261 a 0.915 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 8.757sec(train) 2.146sec(infer)\n",
      "Epoch 129 tst: l 0.386 a 0.888 clct[np.int64(21), np.int64(0), np.int64(8), np.int64(11)]  0.143sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 130 tr: l 0.259 a 0.916 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 7.618sec(train) 2.144sec(infer)\n",
      "Epoch 130 tst: l 0.386 a 0.888 clct[np.int64(21), np.int64(0), np.int64(8), np.int64(11)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 131 tr: l 0.258 a 0.916 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 7.787sec(train) 2.489sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 131 tst: l 0.386 a 0.888 clct[np.int64(21), np.int64(0), np.int64(8), np.int64(11)]  0.234sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 132 tr: l 0.257 a 0.916 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 8.629sec(train) 2.147sec(infer)\n",
      "Epoch 132 tst: l 0.386 a 0.888 clct[np.int64(21), np.int64(0), np.int64(8), np.int64(11)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 133 tr: l 0.256 a 0.916 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 7.807sec(train) 2.142sec(infer)\n",
      "Epoch 133 tst: l 0.385 a 0.889 clct[np.int64(21), np.int64(0), np.int64(8), np.int64(11)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 134 tr: l 0.255 a 0.917 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 7.617sec(train) 2.261sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 134 tst: l 0.385 a 0.889 clct[np.int64(21), np.int64(0), np.int64(8), np.int64(11)]  0.221sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 135 tr: l 0.254 a 0.917 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 8.936sec(train) 2.152sec(infer)\n",
      "Epoch 135 tst: l 0.385 a 0.888 clct[np.int64(21), np.int64(0), np.int64(8), np.int64(11)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 136 tr: l 0.253 a 0.918 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 7.634sec(train) 2.145sec(infer)\n",
      "Epoch 136 tst: l 0.385 a 0.889 clct[np.int64(21), np.int64(0), np.int64(8), np.int64(11)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 137 tr: l 0.252 a 0.918 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 7.966sec(train) 2.152sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 137 tst: l 0.384 a 0.889 clct[np.int64(21), np.int64(0), np.int64(8), np.int64(11)]  0.220sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 138 tr: l 0.251 a 0.918 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 9.031sec(train) 2.148sec(infer)\n",
      "Epoch 138 tst: l 0.384 a 0.889 clct[np.int64(22), np.int64(0), np.int64(7), np.int64(11)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 139 tr: l 0.250 a 0.918 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 7.629sec(train) 2.142sec(infer)\n",
      "Epoch 139 tst: l 0.384 a 0.888 clct[np.int64(22), np.int64(0), np.int64(7), np.int64(11)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 140 tr: l 0.249 a 0.919 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 7.804sec(train) 2.107sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 140 tst: l 0.384 a 0.888 clct[np.int64(22), np.int64(0), np.int64(7), np.int64(11)]  0.218sec\n",
      "result written at output_dfca_gi/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 141 tr: l 0.248 a 0.919 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 8.820sec(train) 2.149sec(infer)\n",
      "Epoch 141 tst: l 0.384 a 0.888 clct[np.int64(22), np.int64(0), np.int64(7), np.int64(11)]  0.143sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 142 tr: l 0.247 a 0.919 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 7.633sec(train) 2.147sec(infer)\n",
      "Epoch 142 tst: l 0.383 a 0.888 clct[np.int64(22), np.int64(0), np.int64(7), np.int64(11)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 143 tr: l 0.246 a 0.919 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 7.812sec(train) 1.936sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 143 tst: l 0.383 a 0.889 clct[np.int64(22), np.int64(0), np.int64(7), np.int64(11)]  0.223sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 144 tr: l 0.245 a 0.920 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 9.086sec(train) 2.146sec(infer)\n",
      "Epoch 144 tst: l 0.383 a 0.889 clct[np.int64(22), np.int64(0), np.int64(7), np.int64(11)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 145 tr: l 0.244 a 0.920 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 7.810sec(train) 2.144sec(infer)\n",
      "Epoch 145 tst: l 0.383 a 0.889 clct[np.int64(22), np.int64(0), np.int64(7), np.int64(11)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 146 tr: l 0.243 a 0.920 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 7.623sec(train) 2.037sec(infer)\n",
      "Epoch 146 tst: l 0.383 a 0.888 clct[np.int64(22), np.int64(0), np.int64(7), np.int64(11)]  0.159sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 147 tr: l 0.242 a 0.920 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 9.159sec(train) 2.149sec(infer)\n",
      "Epoch 147 tst: l 0.383 a 0.889 clct[np.int64(22), np.int64(0), np.int64(7), np.int64(11)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 148 tr: l 0.241 a 0.921 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 7.809sec(train) 2.148sec(infer)\n",
      "Epoch 148 tst: l 0.383 a 0.888 clct[np.int64(22), np.int64(0), np.int64(7), np.int64(11)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 149 tr: l 0.240 a 0.921 clct[np.int64(172), np.int64(6), np.int64(89), np.int64(133)]  lr 0.100000 7.631sec(train) 2.026sec(infer)\n",
      "Epoch 149 tst: l 0.382 a 0.889 clct[np.int64(22), np.int64(0), np.int64(7), np.int64(11)]  0.162sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "---train cluster Ended in 0.45 hour (1631.384 sec) \n",
      "---------------------------------IFCA, lr: 0.1, seed: 4506---------------------------------\n",
      "config: {'m': 400, 'm_test': 40, 'p': 4, 'n': 2000, 'uneven': False, 'local_model_init': False, 'Gp': 0.2, 'graph': 'fixed', 'h1': 512, 'num_epochs': 150, 'batch_size': 100, 'tau': 5, 'lr': 0.1, 'data_seed': 4506, 'train_seed': 4506, 'config_override': '', 'project_dir': 'output_dfca_gi'}\n",
      "Using device: cuda:3\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      "Generating partition_id_to_indices: 0it [00:00, ?it/s]"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      "Generating partition_id_to_indices: 128271it [00:00, 1282637.83it/s]"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      "Generating partition_id_to_indices: 266738it [00:00, 1342627.87it/s]"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      "Generating partition_id_to_indices: 406550it [00:00, 1367938.44it/s]"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      "Generating partition_id_to_indices: 546640it [00:00, 1380922.88it/s]"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      "Generating partition_id_to_indices: 685106it [00:00, 1382244.80it/s]"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      "Generating partition_id_to_indices: 814277it [00:00, 1367697.49it/s]"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch -1 tr: l 4.135 a 0.013 clct[np.int64(21), np.int64(73), np.int64(87), np.int64(219)]  2.126sec\n",
      "Epoch -1 tst: l 4.123 a 0.009 clct[np.int64(5), np.int64(5), np.int64(6), np.int64(24)]  0.148sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0 tr: l 3.417 a 0.277 clct[np.int64(64), np.int64(235), np.int64(13), np.int64(88)]  lr 0.100000 7.085sec(train) 2.352sec(infer)\n",
      "Epoch 0 tst: l 3.376 a 0.282 clct[np.int64(8), np.int64(18), np.int64(2), np.int64(12)]  0.158sec\n",
      "result written at output_dfca_gi/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1 tr: l 2.602 a 0.483 clct[np.int64(44), np.int64(51), np.int64(27), np.int64(278)]  lr 0.100000 8.152sec(train) 2.808sec(infer)\n",
      "Epoch 1 tst: l 2.526 a 0.491 clct[np.int64(3), np.int64(2), np.int64(3), np.int64(32)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2 tr: l 1.983 a 0.605 clct[np.int64(17), np.int64(132), np.int64(54), np.int64(197)]  lr 0.100000 7.474sec(train) 2.135sec(infer)\n",
      "Epoch 2 tst: l 1.932 a 0.621 clct[np.int64(2), np.int64(9), np.int64(5), np.int64(24)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3 tr: l 1.619 a 0.651 clct[np.int64(16), np.int64(147), np.int64(62), np.int64(175)]  lr 0.100000 7.640sec(train) 2.157sec(infer)\n",
      "Epoch 3 tst: l 1.593 a 0.656 clct[np.int64(1), np.int64(10), np.int64(6), np.int64(23)]  0.193sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4 tr: l 1.394 a 0.684 clct[np.int64(22), np.int64(145), np.int64(56), np.int64(177)]  lr 0.100000 6.115sec(train) 2.933sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4 tst: l 1.364 a 0.694 clct[np.int64(1), np.int64(7), np.int64(6), np.int64(26)]  0.223sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5 tr: l 1.245 a 0.704 clct[np.int64(27), np.int64(145), np.int64(56), np.int64(172)]  lr 0.100000 8.552sec(train) 2.142sec(infer)\n",
      "Epoch 5 tst: l 1.225 a 0.705 clct[np.int64(2), np.int64(12), np.int64(5), np.int64(21)]  0.146sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6 tr: l 1.124 a 0.730 clct[np.int64(25), np.int64(143), np.int64(56), np.int64(176)]  lr 0.100000 7.567sec(train) 2.140sec(infer)\n",
      "Epoch 6 tst: l 1.106 a 0.740 clct[np.int64(2), np.int64(9), np.int64(6), np.int64(23)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7 tr: l 1.033 a 0.745 clct[np.int64(30), np.int64(141), np.int64(55), np.int64(174)]  lr 0.100000 7.684sec(train) 2.751sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7 tst: l 1.023 a 0.744 clct[np.int64(2), np.int64(12), np.int64(5), np.int64(21)]  0.222sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8 tr: l 0.961 a 0.761 clct[np.int64(30), np.int64(139), np.int64(55), np.int64(176)]  lr 0.100000 8.692sec(train) 2.144sec(infer)\n",
      "Epoch 8 tst: l 0.953 a 0.759 clct[np.int64(3), np.int64(10), np.int64(5), np.int64(22)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9 tr: l 0.901 a 0.770 clct[np.int64(32), np.int64(137), np.int64(55), np.int64(176)]  lr 0.100000 7.703sec(train) 2.138sec(infer)\n",
      "Epoch 9 tst: l 0.900 a 0.761 clct[np.int64(3), np.int64(11), np.int64(4), np.int64(22)]  0.146sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10 tr: l 0.851 a 0.782 clct[np.int64(32), np.int64(137), np.int64(55), np.int64(176)]  lr 0.100000 7.905sec(train) 2.729sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10 tst: l 0.853 a 0.777 clct[np.int64(4), np.int64(10), np.int64(4), np.int64(22)]  0.215sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11 tr: l 0.807 a 0.789 clct[np.int64(32), np.int64(136), np.int64(55), np.int64(177)]  lr 0.100000 8.822sec(train) 2.146sec(infer)\n",
      "Epoch 11 tst: l 0.816 a 0.778 clct[np.int64(3), np.int64(11), np.int64(4), np.int64(22)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12 tr: l 0.771 a 0.798 clct[np.int64(33), np.int64(135), np.int64(55), np.int64(177)]  lr 0.100000 7.897sec(train) 2.147sec(infer)\n",
      "Epoch 12 tst: l 0.782 a 0.794 clct[np.int64(6), np.int64(8), np.int64(4), np.int64(22)]  0.146sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13 tr: l 0.739 a 0.803 clct[np.int64(33), np.int64(134), np.int64(55), np.int64(178)]  lr 0.100000 7.668sec(train) 2.675sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13 tst: l 0.753 a 0.795 clct[np.int64(3), np.int64(10), np.int64(4), np.int64(23)]  0.218sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14 tr: l 0.712 a 0.808 clct[np.int64(34), np.int64(135), np.int64(55), np.int64(176)]  lr 0.100000 8.541sec(train) 2.147sec(infer)\n",
      "Epoch 14 tst: l 0.729 a 0.803 clct[np.int64(6), np.int64(8), np.int64(4), np.int64(22)]  0.148sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15 tr: l 0.686 a 0.814 clct[np.int64(34), np.int64(132), np.int64(55), np.int64(179)]  lr 0.100000 7.934sec(train) 2.145sec(infer)\n",
      "Epoch 15 tst: l 0.707 a 0.808 clct[np.int64(5), np.int64(8), np.int64(3), np.int64(24)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16 tr: l 0.665 a 0.819 clct[np.int64(35), np.int64(134), np.int64(55), np.int64(176)]  lr 0.100000 7.686sec(train) 2.665sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16 tst: l 0.687 a 0.813 clct[np.int64(6), np.int64(7), np.int64(5), np.int64(22)]  0.217sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17 tr: l 0.644 a 0.822 clct[np.int64(35), np.int64(131), np.int64(55), np.int64(179)]  lr 0.100000 8.723sec(train) 2.145sec(infer)\n",
      "Epoch 17 tst: l 0.669 a 0.815 clct[np.int64(7), np.int64(8), np.int64(3), np.int64(22)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18 tr: l 0.626 a 0.826 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.709sec(train) 2.144sec(infer)\n",
      "Epoch 18 tst: l 0.653 a 0.819 clct[np.int64(6), np.int64(7), np.int64(5), np.int64(22)]  0.146sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19 tr: l 0.609 a 0.830 clct[np.int64(35), np.int64(131), np.int64(55), np.int64(179)]  lr 0.100000 7.880sec(train) 2.772sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19 tst: l 0.640 a 0.821 clct[np.int64(7), np.int64(8), np.int64(3), np.int64(22)]  0.216sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20 tr: l 0.594 a 0.833 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 8.517sec(train) 2.151sec(infer)\n",
      "Epoch 20 tst: l 0.625 a 0.827 clct[np.int64(7), np.int64(7), np.int64(5), np.int64(21)]  0.147sec\n",
      "result written at output_dfca_gi/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21 tr: l 0.580 a 0.836 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 8.327sec(train) 2.146sec(infer)\n",
      "Epoch 21 tst: l 0.615 a 0.827 clct[np.int64(8), np.int64(8), np.int64(3), np.int64(21)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22 tr: l 0.567 a 0.839 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.895sec(train) 2.943sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22 tst: l 0.602 a 0.832 clct[np.int64(7), np.int64(7), np.int64(5), np.int64(21)]  0.215sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23 tr: l 0.555 a 0.842 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 8.437sec(train) 2.148sec(infer)\n",
      "Epoch 23 tst: l 0.595 a 0.830 clct[np.int64(7), np.int64(8), np.int64(4), np.int64(21)]  0.142sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24 tr: l 0.543 a 0.844 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.873sec(train) 2.145sec(infer)\n",
      "Epoch 24 tst: l 0.583 a 0.836 clct[np.int64(7), np.int64(7), np.int64(6), np.int64(20)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25 tr: l 0.532 a 0.847 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.701sec(train) 2.927sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25 tst: l 0.578 a 0.835 clct[np.int64(7), np.int64(8), np.int64(4), np.int64(21)]  0.224sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 26 tr: l 0.523 a 0.849 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 8.619sec(train) 2.147sec(infer)\n",
      "Epoch 26 tst: l 0.568 a 0.839 clct[np.int64(7), np.int64(8), np.int64(6), np.int64(19)]  0.146sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 27 tr: l 0.513 a 0.852 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.711sec(train) 2.142sec(infer)\n",
      "Epoch 27 tst: l 0.563 a 0.836 clct[np.int64(7), np.int64(8), np.int64(4), np.int64(21)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 28 tr: l 0.505 a 0.853 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 8.124sec(train) 2.906sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 28 tst: l 0.554 a 0.840 clct[np.int64(7), np.int64(8), np.int64(5), np.int64(20)]  0.214sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 29 tr: l 0.496 a 0.856 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 8.505sec(train) 2.147sec(infer)\n",
      "Epoch 29 tst: l 0.549 a 0.836 clct[np.int64(6), np.int64(8), np.int64(5), np.int64(21)]  0.146sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 30 tr: l 0.488 a 0.857 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.680sec(train) 2.148sec(infer)\n",
      "Epoch 30 tst: l 0.542 a 0.841 clct[np.int64(7), np.int64(8), np.int64(6), np.int64(19)]  0.146sec\n",
      "result written at output_dfca_gi/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 31 tr: l 0.480 a 0.860 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 8.824sec(train) 2.908sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 31 tst: l 0.537 a 0.839 clct[np.int64(6), np.int64(8), np.int64(6), np.int64(20)]  0.226sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 32 tr: l 0.474 a 0.860 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 8.093sec(train) 2.147sec(infer)\n",
      "Epoch 32 tst: l 0.532 a 0.845 clct[np.int64(7), np.int64(8), np.int64(6), np.int64(19)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 33 tr: l 0.466 a 0.863 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.712sec(train) 2.145sec(infer)\n",
      "Epoch 33 tst: l 0.527 a 0.843 clct[np.int64(5), np.int64(8), np.int64(5), np.int64(22)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 34 tr: l 0.460 a 0.864 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 8.365sec(train) 2.902sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 34 tst: l 0.523 a 0.847 clct[np.int64(7), np.int64(8), np.int64(6), np.int64(19)]  0.226sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 35 tr: l 0.454 a 0.866 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.962sec(train) 2.145sec(infer)\n",
      "Epoch 35 tst: l 0.518 a 0.845 clct[np.int64(5), np.int64(8), np.int64(5), np.int64(22)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 36 tr: l 0.448 a 0.866 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.909sec(train) 2.135sec(infer)\n",
      "Epoch 36 tst: l 0.514 a 0.847 clct[np.int64(7), np.int64(8), np.int64(5), np.int64(20)]  0.142sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 37 tr: l 0.442 a 0.869 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 8.165sec(train) 2.911sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 37 tst: l 0.510 a 0.846 clct[np.int64(5), np.int64(8), np.int64(5), np.int64(22)]  0.234sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 38 tr: l 0.437 a 0.869 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 8.175sec(train) 2.139sec(infer)\n",
      "Epoch 38 tst: l 0.506 a 0.850 clct[np.int64(7), np.int64(8), np.int64(5), np.int64(20)]  0.146sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 39 tr: l 0.431 a 0.872 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 8.669sec(train) 2.144sec(infer)\n",
      "Epoch 39 tst: l 0.504 a 0.848 clct[np.int64(5), np.int64(8), np.int64(4), np.int64(23)]  0.192sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 40 tr: l 0.427 a 0.872 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 8.458sec(train) 2.934sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 40 tst: l 0.499 a 0.850 clct[np.int64(7), np.int64(8), np.int64(5), np.int64(20)]  0.216sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 41 tr: l 0.422 a 0.874 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.893sec(train) 2.144sec(infer)\n",
      "Epoch 41 tst: l 0.498 a 0.849 clct[np.int64(5), np.int64(8), np.int64(4), np.int64(23)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 42 tr: l 0.417 a 0.874 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.688sec(train) 2.232sec(infer)\n",
      "Epoch 42 tst: l 0.493 a 0.850 clct[np.int64(7), np.int64(8), np.int64(5), np.int64(20)]  0.200sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 43 tr: l 0.412 a 0.876 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 8.702sec(train) 2.788sec(infer)\n",
      "Epoch 43 tst: l 0.492 a 0.851 clct[np.int64(5), np.int64(8), np.int64(4), np.int64(23)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 44 tr: l 0.408 a 0.877 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.677sec(train) 2.144sec(infer)\n",
      "Epoch 44 tst: l 0.488 a 0.852 clct[np.int64(7), np.int64(8), np.int64(5), np.int64(20)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 45 tr: l 0.404 a 0.879 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.673sec(train) 2.276sec(infer)\n",
      "Epoch 45 tst: l 0.487 a 0.853 clct[np.int64(5), np.int64(8), np.int64(4), np.int64(23)]  0.194sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 46 tr: l 0.399 a 0.879 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 9.059sec(train) 2.505sec(infer)\n",
      "Epoch 46 tst: l 0.483 a 0.853 clct[np.int64(7), np.int64(8), np.int64(5), np.int64(20)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 47 tr: l 0.396 a 0.880 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.681sec(train) 2.145sec(infer)\n",
      "Epoch 47 tst: l 0.482 a 0.853 clct[np.int64(5), np.int64(8), np.int64(4), np.int64(23)]  0.147sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 48 tr: l 0.392 a 0.881 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.904sec(train) 2.360sec(infer)\n",
      "Epoch 48 tst: l 0.479 a 0.855 clct[np.int64(7), np.int64(8), np.int64(5), np.int64(20)]  0.161sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 49 tr: l 0.388 a 0.883 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 9.030sec(train) 2.344sec(infer)\n",
      "Epoch 49 tst: l 0.478 a 0.855 clct[np.int64(4), np.int64(8), np.int64(4), np.int64(24)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 50 tr: l 0.384 a 0.883 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.887sec(train) 2.144sec(infer)\n",
      "Epoch 50 tst: l 0.475 a 0.857 clct[np.int64(7), np.int64(8), np.int64(5), np.int64(20)]  0.144sec\n",
      "result written at output_dfca_gi/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 51 tr: l 0.380 a 0.884 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.704sec(train) 2.207sec(infer)\n",
      "Epoch 51 tst: l 0.473 a 0.856 clct[np.int64(4), np.int64(8), np.int64(4), np.int64(24)]  0.158sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 52 tr: l 0.377 a 0.885 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 9.033sec(train) 2.169sec(infer)\n",
      "Epoch 52 tst: l 0.472 a 0.857 clct[np.int64(7), np.int64(8), np.int64(4), np.int64(21)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 53 tr: l 0.373 a 0.886 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.872sec(train) 2.147sec(infer)\n",
      "Epoch 53 tst: l 0.469 a 0.856 clct[np.int64(4), np.int64(8), np.int64(4), np.int64(24)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 54 tr: l 0.370 a 0.887 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.693sec(train) 2.144sec(infer)\n",
      "Epoch 54 tst: l 0.468 a 0.860 clct[np.int64(5), np.int64(8), np.int64(4), np.int64(23)]  0.160sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 55 tr: l 0.367 a 0.888 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 9.217sec(train) 2.147sec(infer)\n",
      "Epoch 55 tst: l 0.466 a 0.860 clct[np.int64(4), np.int64(8), np.int64(4), np.int64(24)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 56 tr: l 0.364 a 0.889 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.696sec(train) 2.146sec(infer)\n",
      "Epoch 56 tst: l 0.465 a 0.861 clct[np.int64(5), np.int64(8), np.int64(4), np.int64(23)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 57 tr: l 0.361 a 0.890 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.703sec(train) 2.143sec(infer)\n",
      "Epoch 57 tst: l 0.463 a 0.860 clct[np.int64(4), np.int64(8), np.int64(4), np.int64(24)]  0.160sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 58 tr: l 0.357 a 0.890 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 9.086sec(train) 2.204sec(infer)\n",
      "Epoch 58 tst: l 0.461 a 0.864 clct[np.int64(5), np.int64(8), np.int64(4), np.int64(23)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 59 tr: l 0.355 a 0.891 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.698sec(train) 2.146sec(infer)\n",
      "Epoch 59 tst: l 0.460 a 0.862 clct[np.int64(4), np.int64(8), np.int64(4), np.int64(24)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 60 tr: l 0.352 a 0.892 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.915sec(train) 2.161sec(infer)\n",
      "Epoch 60 tst: l 0.458 a 0.865 clct[np.int64(5), np.int64(8), np.int64(4), np.int64(23)]  0.159sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 61 tr: l 0.349 a 0.893 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 9.111sec(train) 2.152sec(infer)\n",
      "Epoch 61 tst: l 0.458 a 0.863 clct[np.int64(4), np.int64(8), np.int64(4), np.int64(24)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 62 tr: l 0.346 a 0.893 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.915sec(train) 2.148sec(infer)\n",
      "Epoch 62 tst: l 0.456 a 0.865 clct[np.int64(4), np.int64(8), np.int64(4), np.int64(24)]  0.147sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 63 tr: l 0.343 a 0.894 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.709sec(train) 2.044sec(infer)\n",
      "Epoch 63 tst: l 0.455 a 0.866 clct[np.int64(4), np.int64(8), np.int64(4), np.int64(24)]  0.161sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 64 tr: l 0.341 a 0.894 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 9.361sec(train) 2.147sec(infer)\n",
      "Epoch 64 tst: l 0.454 a 0.866 clct[np.int64(4), np.int64(8), np.int64(4), np.int64(24)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 65 tr: l 0.338 a 0.896 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 8.293sec(train) 2.147sec(infer)\n",
      "Epoch 65 tst: l 0.452 a 0.867 clct[np.int64(4), np.int64(8), np.int64(4), np.int64(24)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 66 tr: l 0.335 a 0.896 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.700sec(train) 2.217sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 66 tst: l 0.451 a 0.868 clct[np.int64(4), np.int64(8), np.int64(4), np.int64(24)]  0.220sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 67 tr: l 0.333 a 0.897 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 8.891sec(train) 2.147sec(infer)\n",
      "Epoch 67 tst: l 0.450 a 0.866 clct[np.int64(4), np.int64(8), np.int64(4), np.int64(24)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 68 tr: l 0.331 a 0.898 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 8.769sec(train) 2.144sec(infer)\n",
      "Epoch 68 tst: l 0.449 a 0.867 clct[np.int64(4), np.int64(8), np.int64(4), np.int64(24)]  0.146sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 69 tr: l 0.328 a 0.899 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.719sec(train) 2.475sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 69 tst: l 0.448 a 0.867 clct[np.int64(4), np.int64(8), np.int64(4), np.int64(24)]  0.228sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 70 tr: l 0.326 a 0.899 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 8.831sec(train) 2.145sec(infer)\n",
      "Epoch 70 tst: l 0.447 a 0.868 clct[np.int64(4), np.int64(8), np.int64(4), np.int64(24)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 71 tr: l 0.323 a 0.900 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.695sec(train) 2.144sec(infer)\n",
      "Epoch 71 tst: l 0.446 a 0.868 clct[np.int64(4), np.int64(8), np.int64(4), np.int64(24)]  0.146sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 72 tr: l 0.321 a 0.901 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.888sec(train) 2.421sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 72 tst: l 0.445 a 0.868 clct[np.int64(4), np.int64(8), np.int64(4), np.int64(24)]  0.230sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 73 tr: l 0.319 a 0.901 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 8.665sec(train) 2.145sec(infer)\n",
      "Epoch 73 tst: l 0.444 a 0.869 clct[np.int64(4), np.int64(8), np.int64(4), np.int64(24)]  0.146sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 74 tr: l 0.317 a 0.902 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.693sec(train) 2.147sec(infer)\n",
      "Epoch 74 tst: l 0.443 a 0.871 clct[np.int64(4), np.int64(8), np.int64(4), np.int64(24)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 75 tr: l 0.315 a 0.903 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.873sec(train) 2.465sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 75 tst: l 0.442 a 0.871 clct[np.int64(4), np.int64(8), np.int64(4), np.int64(24)]  0.225sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 76 tr: l 0.313 a 0.903 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 8.685sec(train) 2.150sec(infer)\n",
      "Epoch 76 tst: l 0.441 a 0.871 clct[np.int64(4), np.int64(8), np.int64(4), np.int64(24)]  0.148sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 77 tr: l 0.310 a 0.904 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 8.312sec(train) 2.146sec(infer)\n",
      "Epoch 77 tst: l 0.440 a 0.871 clct[np.int64(4), np.int64(8), np.int64(4), np.int64(24)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 78 tr: l 0.309 a 0.904 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.673sec(train) 2.499sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 78 tst: l 0.440 a 0.872 clct[np.int64(4), np.int64(8), np.int64(4), np.int64(24)]  0.231sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 79 tr: l 0.306 a 0.905 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 8.641sec(train) 2.142sec(infer)\n",
      "Epoch 79 tst: l 0.439 a 0.872 clct[np.int64(4), np.int64(8), np.int64(4), np.int64(24)]  0.143sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 80 tr: l 0.305 a 0.905 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.864sec(train) 2.148sec(infer)\n",
      "Epoch 80 tst: l 0.438 a 0.871 clct[np.int64(4), np.int64(8), np.int64(4), np.int64(24)]  0.143sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 81 tr: l 0.303 a 0.906 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.680sec(train) 2.458sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 81 tst: l 0.437 a 0.873 clct[np.int64(3), np.int64(8), np.int64(4), np.int64(25)]  0.224sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 82 tr: l 0.301 a 0.906 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 8.792sec(train) 2.145sec(infer)\n",
      "Epoch 82 tst: l 0.436 a 0.872 clct[np.int64(4), np.int64(8), np.int64(4), np.int64(24)]  0.143sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 83 tr: l 0.299 a 0.907 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.676sec(train) 2.134sec(infer)\n",
      "Epoch 83 tst: l 0.436 a 0.873 clct[np.int64(3), np.int64(8), np.int64(4), np.int64(25)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 84 tr: l 0.297 a 0.907 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.685sec(train) 2.115sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 84 tst: l 0.435 a 0.873 clct[np.int64(3), np.int64(8), np.int64(4), np.int64(25)]  0.224sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 85 tr: l 0.295 a 0.908 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 9.026sec(train) 2.147sec(infer)\n",
      "Epoch 85 tst: l 0.435 a 0.873 clct[np.int64(3), np.int64(8), np.int64(4), np.int64(25)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 86 tr: l 0.293 a 0.908 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.691sec(train) 2.142sec(infer)\n",
      "Epoch 86 tst: l 0.434 a 0.873 clct[np.int64(3), np.int64(8), np.int64(4), np.int64(25)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 87 tr: l 0.292 a 0.909 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.877sec(train) 1.918sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 87 tst: l 0.433 a 0.873 clct[np.int64(3), np.int64(8), np.int64(4), np.int64(25)]  0.256sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 88 tr: l 0.290 a 0.909 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 8.962sec(train) 2.148sec(infer)\n",
      "Epoch 88 tst: l 0.433 a 0.873 clct[np.int64(3), np.int64(8), np.int64(4), np.int64(25)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 89 tr: l 0.288 a 0.910 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.886sec(train) 2.144sec(infer)\n",
      "Epoch 89 tst: l 0.432 a 0.873 clct[np.int64(3), np.int64(8), np.int64(4), np.int64(25)]  0.143sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 90 tr: l 0.287 a 0.910 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.699sec(train) 1.983sec(infer)\n",
      "Epoch 90 tst: l 0.432 a 0.874 clct[np.int64(3), np.int64(8), np.int64(4), np.int64(25)]  0.160sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 91 tr: l 0.285 a 0.911 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 8.947sec(train) 2.127sec(infer)\n",
      "Epoch 91 tst: l 0.431 a 0.874 clct[np.int64(3), np.int64(8), np.int64(4), np.int64(25)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 92 tr: l 0.283 a 0.911 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.895sec(train) 2.148sec(infer)\n",
      "Epoch 92 tst: l 0.430 a 0.874 clct[np.int64(3), np.int64(8), np.int64(4), np.int64(25)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 93 tr: l 0.281 a 0.912 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.617sec(train) 2.143sec(infer)\n",
      "Epoch 93 tst: l 0.430 a 0.874 clct[np.int64(3), np.int64(8), np.int64(4), np.int64(25)]  0.156sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 94 tr: l 0.280 a 0.912 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 9.142sec(train) 2.157sec(infer)\n",
      "Epoch 94 tst: l 0.429 a 0.874 clct[np.int64(3), np.int64(8), np.int64(4), np.int64(25)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 95 tr: l 0.278 a 0.912 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.608sec(train) 2.142sec(infer)\n",
      "Epoch 95 tst: l 0.429 a 0.874 clct[np.int64(3), np.int64(8), np.int64(4), np.int64(25)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 96 tr: l 0.277 a 0.913 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.613sec(train) 2.223sec(infer)\n",
      "Epoch 96 tst: l 0.428 a 0.872 clct[np.int64(3), np.int64(8), np.int64(3), np.int64(26)]  0.161sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 97 tr: l 0.275 a 0.913 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 9.022sec(train) 2.302sec(infer)\n",
      "Epoch 97 tst: l 0.428 a 0.873 clct[np.int64(3), np.int64(8), np.int64(4), np.int64(25)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 98 tr: l 0.274 a 0.914 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.640sec(train) 2.146sec(infer)\n",
      "Epoch 98 tst: l 0.427 a 0.873 clct[np.int64(3), np.int64(8), np.int64(4), np.int64(25)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 99 tr: l 0.272 a 0.914 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.815sec(train) 2.239sec(infer)\n",
      "Epoch 99 tst: l 0.427 a 0.875 clct[np.int64(3), np.int64(8), np.int64(3), np.int64(26)]  0.159sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 100 tr: l 0.271 a 0.915 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 8.909sec(train) 2.284sec(infer)\n",
      "Epoch 100 tst: l 0.426 a 0.872 clct[np.int64(3), np.int64(8), np.int64(3), np.int64(26)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 101 tr: l 0.270 a 0.915 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.824sec(train) 2.143sec(infer)\n",
      "Epoch 101 tst: l 0.427 a 0.874 clct[np.int64(3), np.int64(8), np.int64(3), np.int64(26)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 102 tr: l 0.268 a 0.915 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.621sec(train) 2.212sec(infer)\n",
      "Epoch 102 tst: l 0.425 a 0.874 clct[np.int64(3), np.int64(8), np.int64(4), np.int64(25)]  0.158sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 103 tr: l 0.267 a 0.916 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 8.997sec(train) 2.241sec(infer)\n",
      "Epoch 103 tst: l 0.425 a 0.875 clct[np.int64(3), np.int64(8), np.int64(4), np.int64(25)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 104 tr: l 0.265 a 0.916 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.822sec(train) 2.140sec(infer)\n",
      "Epoch 104 tst: l 0.425 a 0.873 clct[np.int64(3), np.int64(8), np.int64(4), np.int64(25)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 105 tr: l 0.264 a 0.917 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.625sec(train) 2.220sec(infer)\n",
      "Epoch 105 tst: l 0.424 a 0.875 clct[np.int64(3), np.int64(8), np.int64(3), np.int64(26)]  0.161sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 106 tr: l 0.263 a 0.917 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 9.206sec(train) 2.166sec(infer)\n",
      "Epoch 106 tst: l 0.424 a 0.873 clct[np.int64(3), np.int64(8), np.int64(4), np.int64(25)]  0.148sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 107 tr: l 0.261 a 0.917 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.613sec(train) 2.145sec(infer)\n",
      "Epoch 107 tst: l 0.424 a 0.875 clct[np.int64(3), np.int64(8), np.int64(3), np.int64(26)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 108 tr: l 0.260 a 0.918 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.600sec(train) 2.264sec(infer)\n",
      "Epoch 108 tst: l 0.423 a 0.874 clct[np.int64(3), np.int64(8), np.int64(4), np.int64(25)]  0.159sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 109 tr: l 0.259 a 0.918 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 8.978sec(train) 2.338sec(infer)\n",
      "Epoch 109 tst: l 0.423 a 0.875 clct[np.int64(3), np.int64(8), np.int64(2), np.int64(27)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 110 tr: l 0.257 a 0.919 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.623sec(train) 2.150sec(infer)\n",
      "Epoch 110 tst: l 0.422 a 0.873 clct[np.int64(3), np.int64(8), np.int64(4), np.int64(25)]  0.143sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 111 tr: l 0.256 a 0.919 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.975sec(train) 2.185sec(infer)\n",
      "Epoch 111 tst: l 0.422 a 0.875 clct[np.int64(3), np.int64(8), np.int64(2), np.int64(27)]  0.159sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 112 tr: l 0.255 a 0.919 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 8.879sec(train) 2.286sec(infer)\n",
      "Epoch 112 tst: l 0.422 a 0.873 clct[np.int64(3), np.int64(8), np.int64(4), np.int64(25)]  0.146sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 113 tr: l 0.253 a 0.919 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.816sec(train) 2.145sec(infer)\n",
      "Epoch 113 tst: l 0.422 a 0.875 clct[np.int64(3), np.int64(8), np.int64(3), np.int64(26)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 114 tr: l 0.252 a 0.920 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.623sec(train) 2.228sec(infer)\n",
      "Epoch 114 tst: l 0.421 a 0.874 clct[np.int64(3), np.int64(8), np.int64(4), np.int64(25)]  0.160sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 115 tr: l 0.251 a 0.920 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 8.955sec(train) 2.254sec(infer)\n",
      "Epoch 115 tst: l 0.421 a 0.875 clct[np.int64(3), np.int64(8), np.int64(3), np.int64(26)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 116 tr: l 0.250 a 0.921 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.799sec(train) 2.147sec(infer)\n",
      "Epoch 116 tst: l 0.421 a 0.874 clct[np.int64(3), np.int64(8), np.int64(4), np.int64(25)]  0.146sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 117 tr: l 0.248 a 0.921 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.612sec(train) 2.287sec(infer)\n",
      "Epoch 117 tst: l 0.420 a 0.875 clct[np.int64(3), np.int64(8), np.int64(3), np.int64(26)]  0.159sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 118 tr: l 0.248 a 0.921 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 8.948sec(train) 2.281sec(infer)\n",
      "Epoch 118 tst: l 0.420 a 0.871 clct[np.int64(3), np.int64(8), np.int64(3), np.int64(26)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 119 tr: l 0.246 a 0.921 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.801sec(train) 2.144sec(infer)\n",
      "Epoch 119 tst: l 0.420 a 0.874 clct[np.int64(3), np.int64(8), np.int64(3), np.int64(26)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 120 tr: l 0.245 a 0.922 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.644sec(train) 2.231sec(infer)\n",
      "Epoch 120 tst: l 0.419 a 0.873 clct[np.int64(3), np.int64(8), np.int64(3), np.int64(26)]  0.160sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 121 tr: l 0.244 a 0.922 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 9.184sec(train) 2.145sec(infer)\n",
      "Epoch 121 tst: l 0.419 a 0.875 clct[np.int64(3), np.int64(8), np.int64(3), np.int64(26)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 122 tr: l 0.243 a 0.923 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.599sec(train) 2.142sec(infer)\n",
      "Epoch 122 tst: l 0.419 a 0.873 clct[np.int64(3), np.int64(8), np.int64(3), np.int64(26)]  0.143sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 123 tr: l 0.242 a 0.923 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.832sec(train) 2.097sec(infer)\n",
      "Epoch 123 tst: l 0.419 a 0.875 clct[np.int64(3), np.int64(8), np.int64(2), np.int64(27)]  0.161sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 124 tr: l 0.241 a 0.923 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 8.944sec(train) 2.205sec(infer)\n",
      "Epoch 124 tst: l 0.418 a 0.874 clct[np.int64(3), np.int64(8), np.int64(3), np.int64(26)]  0.146sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 125 tr: l 0.240 a 0.923 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.635sec(train) 2.148sec(infer)\n",
      "Epoch 125 tst: l 0.419 a 0.875 clct[np.int64(3), np.int64(8), np.int64(2), np.int64(27)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 126 tr: l 0.238 a 0.924 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.827sec(train) 2.175sec(infer)\n",
      "Epoch 126 tst: l 0.418 a 0.873 clct[np.int64(3), np.int64(8), np.int64(3), np.int64(26)]  0.159sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 127 tr: l 0.237 a 0.924 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 9.136sec(train) 2.141sec(infer)\n",
      "Epoch 127 tst: l 0.418 a 0.875 clct[np.int64(3), np.int64(8), np.int64(3), np.int64(26)]  0.143sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 128 tr: l 0.236 a 0.925 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 8.298sec(train) 2.142sec(infer)\n",
      "Epoch 128 tst: l 0.418 a 0.875 clct[np.int64(3), np.int64(8), np.int64(3), np.int64(26)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 129 tr: l 0.235 a 0.924 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.817sec(train) 2.047sec(infer)\n",
      "Epoch 129 tst: l 0.418 a 0.876 clct[np.int64(3), np.int64(8), np.int64(3), np.int64(26)]  0.159sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 130 tr: l 0.234 a 0.925 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 9.172sec(train) 2.147sec(infer)\n",
      "Epoch 130 tst: l 0.418 a 0.876 clct[np.int64(3), np.int64(8), np.int64(3), np.int64(26)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 131 tr: l 0.233 a 0.925 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.809sec(train) 2.144sec(infer)\n",
      "Epoch 131 tst: l 0.417 a 0.876 clct[np.int64(3), np.int64(8), np.int64(3), np.int64(26)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 132 tr: l 0.232 a 0.926 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.623sec(train) 2.014sec(infer)\n",
      "Epoch 132 tst: l 0.417 a 0.875 clct[np.int64(3), np.int64(8), np.int64(3), np.int64(26)]  0.159sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 133 tr: l 0.231 a 0.926 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 9.252sec(train) 2.144sec(infer)\n",
      "Epoch 133 tst: l 0.416 a 0.876 clct[np.int64(3), np.int64(8), np.int64(3), np.int64(26)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 134 tr: l 0.230 a 0.926 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 8.577sec(train) 2.143sec(infer)\n",
      "Epoch 134 tst: l 0.417 a 0.875 clct[np.int64(3), np.int64(8), np.int64(3), np.int64(26)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 135 tr: l 0.229 a 0.926 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.813sec(train) 2.127sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 135 tst: l 0.416 a 0.877 clct[np.int64(3), np.int64(8), np.int64(3), np.int64(26)]  0.223sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 136 tr: l 0.228 a 0.927 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 8.979sec(train) 2.146sec(infer)\n",
      "Epoch 136 tst: l 0.417 a 0.875 clct[np.int64(3), np.int64(8), np.int64(2), np.int64(27)]  0.146sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 137 tr: l 0.227 a 0.927 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.616sec(train) 2.146sec(infer)\n",
      "Epoch 137 tst: l 0.416 a 0.878 clct[np.int64(3), np.int64(8), np.int64(3), np.int64(26)]  0.143sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 138 tr: l 0.227 a 0.927 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 8.287sec(train) 2.175sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 138 tst: l 0.417 a 0.875 clct[np.int64(3), np.int64(8), np.int64(3), np.int64(26)]  0.221sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 139 tr: l 0.226 a 0.927 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 8.887sec(train) 2.147sec(infer)\n",
      "Epoch 139 tst: l 0.415 a 0.878 clct[np.int64(3), np.int64(8), np.int64(3), np.int64(26)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 140 tr: l 0.225 a 0.928 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.613sec(train) 2.144sec(infer)\n",
      "Epoch 140 tst: l 0.416 a 0.876 clct[np.int64(3), np.int64(8), np.int64(3), np.int64(26)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 141 tr: l 0.223 a 0.928 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.791sec(train) 1.952sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 141 tst: l 0.415 a 0.878 clct[np.int64(3), np.int64(8), np.int64(3), np.int64(26)]  0.247sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 142 tr: l 0.222 a 0.929 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 8.981sec(train) 2.148sec(infer)\n",
      "Epoch 142 tst: l 0.415 a 0.876 clct[np.int64(3), np.int64(8), np.int64(3), np.int64(26)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 143 tr: l 0.221 a 0.929 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.804sec(train) 2.146sec(infer)\n",
      "Epoch 143 tst: l 0.415 a 0.877 clct[np.int64(3), np.int64(8), np.int64(3), np.int64(26)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 144 tr: l 0.220 a 0.929 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.606sec(train) 2.086sec(infer)\n",
      "Epoch 144 tst: l 0.415 a 0.876 clct[np.int64(3), np.int64(8), np.int64(3), np.int64(26)]  0.161sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 145 tr: l 0.219 a 0.929 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 9.232sec(train) 2.144sec(infer)\n",
      "Epoch 145 tst: l 0.415 a 0.878 clct[np.int64(3), np.int64(8), np.int64(3), np.int64(26)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 146 tr: l 0.218 a 0.930 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 8.102sec(train) 2.143sec(infer)\n",
      "Epoch 146 tst: l 0.415 a 0.876 clct[np.int64(3), np.int64(8), np.int64(3), np.int64(26)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 147 tr: l 0.218 a 0.930 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.642sec(train) 2.036sec(infer)\n",
      "Epoch 147 tst: l 0.415 a 0.877 clct[np.int64(3), np.int64(8), np.int64(3), np.int64(26)]  0.158sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 148 tr: l 0.217 a 0.930 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 9.146sec(train) 2.150sec(infer)\n",
      "Epoch 148 tst: l 0.415 a 0.877 clct[np.int64(3), np.int64(8), np.int64(3), np.int64(26)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 149 tr: l 0.216 a 0.931 clct[np.int64(35), np.int64(130), np.int64(55), np.int64(180)]  lr 0.100000 7.629sec(train) 2.149sec(infer)\n",
      "Epoch 149 tst: l 0.414 a 0.877 clct[np.int64(3), np.int64(8), np.int64(3), np.int64(26)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "---train cluster Ended in 0.45 hour (1634.428 sec) \n",
      "---------------------------------IFCA, lr: 0.1, seed: 4012---------------------------------\n",
      "config: {'m': 400, 'm_test': 40, 'p': 4, 'n': 2000, 'uneven': False, 'local_model_init': False, 'Gp': 0.2, 'graph': 'fixed', 'h1': 512, 'num_epochs': 150, 'batch_size': 100, 'tau': 5, 'lr': 0.1, 'data_seed': 4012, 'train_seed': 4012, 'config_override': '', 'project_dir': 'output_dfca_gi'}\n",
      "Using device: cuda:3\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      "Generating partition_id_to_indices: 0it [00:00, ?it/s]"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      "Generating partition_id_to_indices: 129732it [00:00, 1297277.94it/s]"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      "Generating partition_id_to_indices: 267958it [00:00, 1347231.57it/s]"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      "Generating partition_id_to_indices: 407054it [00:00, 1367167.80it/s]"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      "Generating partition_id_to_indices: 545508it [00:00, 1374000.62it/s]"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      "Generating partition_id_to_indices: 685645it [00:00, 1383844.24it/s]"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      "Generating partition_id_to_indices: 814277it [00:00, 1373089.48it/s]"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch -1 tr: l 4.095 a 0.025 clct[np.int64(265), np.int64(5), np.int64(128), np.int64(2)]  2.178sec\n",
      "Epoch -1 tst: l 4.086 a 0.026 clct[np.int64(27), np.int64(2), np.int64(10), np.int64(1)]  0.148sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0 tr: l 3.471 a 0.305 clct[np.int64(151), np.int64(40), np.int64(95), np.int64(114)]  lr 0.100000 7.509sec(train) 2.146sec(infer)\n",
      "Epoch 0 tst: l 3.445 a 0.303 clct[np.int64(15), np.int64(4), np.int64(9), np.int64(12)]  0.145sec\n",
      "result written at output_dfca_gi/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1 tr: l 2.624 a 0.467 clct[np.int64(266), np.int64(7), np.int64(3), np.int64(124)]  lr 0.100000 6.826sec(train) 2.810sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1 tst: l 2.588 a 0.471 clct[np.int64(31), np.int64(0), np.int64(0), np.int64(9)]  0.478sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2 tr: l 2.104 a 0.559 clct[np.int64(218), np.int64(46), np.int64(3), np.int64(133)]  lr 0.100000 8.570sec(train) 2.139sec(infer)\n",
      "Epoch 2 tst: l 2.080 a 0.566 clct[np.int64(23), np.int64(5), np.int64(0), np.int64(12)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3 tr: l 1.685 a 0.639 clct[np.int64(221), np.int64(56), np.int64(4), np.int64(119)]  lr 0.100000 7.723sec(train) 2.142sec(infer)\n",
      "Epoch 3 tst: l 1.649 a 0.645 clct[np.int64(24), np.int64(6), np.int64(0), np.int64(10)]  0.147sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4 tr: l 1.454 a 0.679 clct[np.int64(211), np.int64(66), np.int64(4), np.int64(119)]  lr 0.100000 6.884sec(train) 1.994sec(infer)\n",
      "Epoch 4 tst: l 1.432 a 0.680 clct[np.int64(24), np.int64(6), np.int64(0), np.int64(10)]  0.160sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5 tr: l 1.283 a 0.702 clct[np.int64(203), np.int64(77), np.int64(4), np.int64(116)]  lr 0.100000 8.866sec(train) 2.179sec(infer)\n",
      "Epoch 5 tst: l 1.262 a 0.705 clct[np.int64(23), np.int64(7), np.int64(0), np.int64(10)]  0.149sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6 tr: l 1.164 a 0.722 clct[np.int64(190), np.int64(88), np.int64(4), np.int64(118)]  lr 0.100000 7.659sec(train) 2.146sec(infer)\n",
      "Epoch 6 tst: l 1.153 a 0.721 clct[np.int64(22), np.int64(8), np.int64(0), np.int64(10)]  0.148sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7 tr: l 1.066 a 0.738 clct[np.int64(191), np.int64(91), np.int64(4), np.int64(114)]  lr 0.100000 7.255sec(train) 2.332sec(infer)\n",
      "Epoch 7 tst: l 1.058 a 0.740 clct[np.int64(23), np.int64(8), np.int64(0), np.int64(9)]  0.160sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8 tr: l 0.992 a 0.752 clct[np.int64(187), np.int64(93), np.int64(4), np.int64(116)]  lr 0.100000 7.358sec(train) 2.978sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8 tst: l 0.986 a 0.750 clct[np.int64(23), np.int64(8), np.int64(0), np.int64(9)]  0.220sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9 tr: l 0.927 a 0.765 clct[np.int64(183), np.int64(97), np.int64(4), np.int64(116)]  lr 0.100000 7.822sec(train) 2.146sec(infer)\n",
      "Epoch 9 tst: l 0.928 a 0.761 clct[np.int64(23), np.int64(8), np.int64(0), np.int64(9)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10 tr: l 0.877 a 0.773 clct[np.int64(183), np.int64(96), np.int64(4), np.int64(117)]  lr 0.100000 7.525sec(train) 2.108sec(infer)\n",
      "Epoch 10 tst: l 0.875 a 0.770 clct[np.int64(23), np.int64(8), np.int64(0), np.int64(9)]  0.197sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11 tr: l 0.831 a 0.783 clct[np.int64(178), np.int64(101), np.int64(4), np.int64(117)]  lr 0.100000 6.432sec(train) 2.965sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11 tst: l 0.838 a 0.775 clct[np.int64(23), np.int64(8), np.int64(0), np.int64(9)]  0.224sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12 tr: l 0.794 a 0.789 clct[np.int64(178), np.int64(101), np.int64(4), np.int64(117)]  lr 0.100000 9.028sec(train) 2.149sec(infer)\n",
      "Epoch 12 tst: l 0.799 a 0.784 clct[np.int64(23), np.int64(8), np.int64(0), np.int64(9)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13 tr: l 0.761 a 0.797 clct[np.int64(175), np.int64(104), np.int64(4), np.int64(117)]  lr 0.100000 7.933sec(train) 2.146sec(infer)\n",
      "Epoch 13 tst: l 0.772 a 0.788 clct[np.int64(22), np.int64(9), np.int64(0), np.int64(9)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14 tr: l 0.732 a 0.801 clct[np.int64(176), np.int64(103), np.int64(4), np.int64(117)]  lr 0.100000 7.870sec(train) 2.916sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14 tst: l 0.743 a 0.795 clct[np.int64(23), np.int64(8), np.int64(0), np.int64(9)]  0.219sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15 tr: l 0.707 a 0.808 clct[np.int64(174), np.int64(104), np.int64(4), np.int64(118)]  lr 0.100000 8.294sec(train) 2.146sec(infer)\n",
      "Epoch 15 tst: l 0.722 a 0.798 clct[np.int64(22), np.int64(9), np.int64(0), np.int64(9)]  0.147sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16 tr: l 0.684 a 0.812 clct[np.int64(174), np.int64(104), np.int64(4), np.int64(118)]  lr 0.100000 7.845sec(train) 2.140sec(infer)\n",
      "Epoch 16 tst: l 0.699 a 0.802 clct[np.int64(22), np.int64(8), np.int64(0), np.int64(10)]  0.143sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17 tr: l 0.664 a 0.816 clct[np.int64(174), np.int64(104), np.int64(4), np.int64(118)]  lr 0.100000 7.685sec(train) 2.907sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17 tst: l 0.683 a 0.807 clct[np.int64(21), np.int64(8), np.int64(0), np.int64(11)]  0.227sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18 tr: l 0.645 a 0.820 clct[np.int64(174), np.int64(104), np.int64(4), np.int64(118)]  lr 0.100000 8.537sec(train) 2.149sec(infer)\n",
      "Epoch 18 tst: l 0.664 a 0.812 clct[np.int64(21), np.int64(8), np.int64(0), np.int64(11)]  0.146sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19 tr: l 0.629 a 0.824 clct[np.int64(174), np.int64(104), np.int64(4), np.int64(118)]  lr 0.100000 7.640sec(train) 2.145sec(infer)\n",
      "Epoch 19 tst: l 0.650 a 0.815 clct[np.int64(21), np.int64(8), np.int64(0), np.int64(11)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20 tr: l 0.613 a 0.827 clct[np.int64(174), np.int64(104), np.int64(4), np.int64(118)]  lr 0.100000 7.616sec(train) 2.927sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20 tst: l 0.635 a 0.817 clct[np.int64(21), np.int64(8), np.int64(0), np.int64(11)]  0.219sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21 tr: l 0.600 a 0.830 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 8.569sec(train) 2.146sec(infer)\n",
      "Epoch 21 tst: l 0.624 a 0.821 clct[np.int64(21), np.int64(8), np.int64(0), np.int64(11)]  0.148sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22 tr: l 0.587 a 0.833 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 8.015sec(train) 2.144sec(infer)\n",
      "Epoch 22 tst: l 0.611 a 0.822 clct[np.int64(19), np.int64(8), np.int64(0), np.int64(13)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23 tr: l 0.575 a 0.836 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 7.970sec(train) 2.919sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23 tst: l 0.602 a 0.822 clct[np.int64(20), np.int64(8), np.int64(0), np.int64(12)]  0.214sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24 tr: l 0.563 a 0.838 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 8.233sec(train) 2.148sec(infer)\n",
      "Epoch 24 tst: l 0.591 a 0.826 clct[np.int64(18), np.int64(8), np.int64(0), np.int64(14)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25 tr: l 0.554 a 0.841 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 7.635sec(train) 2.146sec(infer)\n",
      "Epoch 25 tst: l 0.583 a 0.828 clct[np.int64(18), np.int64(8), np.int64(0), np.int64(14)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 26 tr: l 0.543 a 0.843 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 7.973sec(train) 2.900sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 26 tst: l 0.573 a 0.829 clct[np.int64(18), np.int64(8), np.int64(0), np.int64(14)]  0.224sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 27 tr: l 0.535 a 0.845 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 8.275sec(train) 2.147sec(infer)\n",
      "Epoch 27 tst: l 0.566 a 0.833 clct[np.int64(18), np.int64(8), np.int64(0), np.int64(14)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 28 tr: l 0.525 a 0.847 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 7.849sec(train) 2.146sec(infer)\n",
      "Epoch 28 tst: l 0.558 a 0.833 clct[np.int64(18), np.int64(8), np.int64(0), np.int64(14)]  0.147sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 29 tr: l 0.518 a 0.849 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 7.673sec(train) 2.911sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 29 tst: l 0.552 a 0.836 clct[np.int64(18), np.int64(8), np.int64(0), np.int64(14)]  0.227sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 30 tr: l 0.509 a 0.851 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 8.506sec(train) 2.144sec(infer)\n",
      "Epoch 30 tst: l 0.545 a 0.836 clct[np.int64(18), np.int64(8), np.int64(0), np.int64(14)]  0.145sec\n",
      "result written at output_dfca_gi/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 31 tr: l 0.502 a 0.853 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 8.331sec(train) 2.141sec(infer)\n",
      "Epoch 31 tst: l 0.539 a 0.840 clct[np.int64(17), np.int64(8), np.int64(0), np.int64(15)]  0.143sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 32 tr: l 0.495 a 0.854 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 7.743sec(train) 2.911sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 32 tst: l 0.534 a 0.838 clct[np.int64(18), np.int64(8), np.int64(0), np.int64(14)]  0.213sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 33 tr: l 0.488 a 0.856 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 8.864sec(train) 2.148sec(infer)\n",
      "Epoch 33 tst: l 0.527 a 0.842 clct[np.int64(17), np.int64(8), np.int64(0), np.int64(15)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 34 tr: l 0.482 a 0.857 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 7.614sec(train) 2.143sec(infer)\n",
      "Epoch 34 tst: l 0.523 a 0.840 clct[np.int64(17), np.int64(8), np.int64(0), np.int64(15)]  0.143sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 35 tr: l 0.476 a 0.859 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 8.112sec(train) 2.905sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 35 tst: l 0.517 a 0.844 clct[np.int64(17), np.int64(8), np.int64(0), np.int64(15)]  0.218sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 36 tr: l 0.469 a 0.860 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 8.147sec(train) 2.149sec(infer)\n",
      "Epoch 36 tst: l 0.514 a 0.843 clct[np.int64(17), np.int64(8), np.int64(0), np.int64(15)]  0.146sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 37 tr: l 0.464 a 0.862 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 7.630sec(train) 2.146sec(infer)\n",
      "Epoch 37 tst: l 0.508 a 0.846 clct[np.int64(17), np.int64(8), np.int64(0), np.int64(15)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 38 tr: l 0.458 a 0.862 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 8.105sec(train) 2.898sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 38 tst: l 0.505 a 0.844 clct[np.int64(17), np.int64(8), np.int64(0), np.int64(15)]  0.213sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 39 tr: l 0.453 a 0.864 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 8.204sec(train) 2.147sec(infer)\n",
      "Epoch 39 tst: l 0.500 a 0.848 clct[np.int64(17), np.int64(8), np.int64(0), np.int64(15)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 40 tr: l 0.448 a 0.865 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 7.817sec(train) 2.146sec(infer)\n",
      "Epoch 40 tst: l 0.497 a 0.846 clct[np.int64(17), np.int64(8), np.int64(0), np.int64(15)]  0.146sec\n",
      "result written at output_dfca_gi/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 41 tr: l 0.443 a 0.866 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 7.814sec(train) 2.903sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 41 tst: l 0.493 a 0.849 clct[np.int64(17), np.int64(8), np.int64(0), np.int64(15)]  0.216sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 42 tr: l 0.438 a 0.867 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 8.415sec(train) 2.152sec(infer)\n",
      "Epoch 42 tst: l 0.490 a 0.847 clct[np.int64(17), np.int64(8), np.int64(0), np.int64(15)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 43 tr: l 0.434 a 0.868 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 8.477sec(train) 2.156sec(infer)\n",
      "Epoch 43 tst: l 0.486 a 0.850 clct[np.int64(17), np.int64(8), np.int64(0), np.int64(15)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 44 tr: l 0.429 a 0.870 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 8.000sec(train) 2.919sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 44 tst: l 0.483 a 0.851 clct[np.int64(17), np.int64(8), np.int64(0), np.int64(15)]  0.223sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 45 tr: l 0.425 a 0.871 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 8.270sec(train) 2.146sec(infer)\n",
      "Epoch 45 tst: l 0.480 a 0.852 clct[np.int64(17), np.int64(8), np.int64(0), np.int64(15)]  0.146sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 46 tr: l 0.421 a 0.872 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 7.632sec(train) 2.147sec(infer)\n",
      "Epoch 46 tst: l 0.477 a 0.852 clct[np.int64(17), np.int64(8), np.int64(0), np.int64(15)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 47 tr: l 0.417 a 0.873 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 8.325sec(train) 2.920sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 47 tst: l 0.474 a 0.853 clct[np.int64(17), np.int64(8), np.int64(0), np.int64(15)]  0.227sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 48 tr: l 0.413 a 0.874 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 7.929sec(train) 2.151sec(infer)\n",
      "Epoch 48 tst: l 0.472 a 0.854 clct[np.int64(17), np.int64(8), np.int64(0), np.int64(15)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 49 tr: l 0.410 a 0.875 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 8.572sec(train) 2.110sec(infer)\n",
      "Epoch 49 tst: l 0.469 a 0.855 clct[np.int64(17), np.int64(8), np.int64(0), np.int64(15)]  0.193sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 50 tr: l 0.406 a 0.876 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 8.326sec(train) 2.943sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 50 tst: l 0.467 a 0.854 clct[np.int64(17), np.int64(8), np.int64(0), np.int64(15)]  0.219sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 51 tr: l 0.402 a 0.877 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 7.738sec(train) 2.146sec(infer)\n",
      "Epoch 51 tst: l 0.464 a 0.854 clct[np.int64(17), np.int64(8), np.int64(0), np.int64(15)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 52 tr: l 0.399 a 0.878 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 7.822sec(train) 2.165sec(infer)\n",
      "Epoch 52 tst: l 0.462 a 0.855 clct[np.int64(17), np.int64(8), np.int64(0), np.int64(15)]  0.196sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 53 tr: l 0.396 a 0.879 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 8.661sec(train) 2.929sec(infer)\n",
      "Epoch 53 tst: l 0.460 a 0.856 clct[np.int64(17), np.int64(8), np.int64(0), np.int64(15)]  0.148sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 54 tr: l 0.392 a 0.879 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 7.835sec(train) 2.144sec(infer)\n",
      "Epoch 54 tst: l 0.458 a 0.856 clct[np.int64(17), np.int64(8), np.int64(0), np.int64(15)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 55 tr: l 0.389 a 0.880 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 7.619sec(train) 2.266sec(infer)\n",
      "Epoch 55 tst: l 0.456 a 0.857 clct[np.int64(17), np.int64(8), np.int64(0), np.int64(15)]  0.196sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 56 tr: l 0.386 a 0.881 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 8.669sec(train) 2.690sec(infer)\n",
      "Epoch 56 tst: l 0.454 a 0.858 clct[np.int64(17), np.int64(8), np.int64(0), np.int64(15)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 57 tr: l 0.383 a 0.882 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 7.856sec(train) 2.146sec(infer)\n",
      "Epoch 57 tst: l 0.452 a 0.859 clct[np.int64(17), np.int64(8), np.int64(0), np.int64(15)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 58 tr: l 0.380 a 0.882 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 7.649sec(train) 2.427sec(infer)\n",
      "Epoch 58 tst: l 0.451 a 0.861 clct[np.int64(17), np.int64(8), np.int64(0), np.int64(15)]  0.160sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 59 tr: l 0.377 a 0.883 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 8.973sec(train) 2.458sec(infer)\n",
      "Epoch 59 tst: l 0.448 a 0.861 clct[np.int64(17), np.int64(8), np.int64(0), np.int64(15)]  0.147sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 60 tr: l 0.374 a 0.884 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 7.661sec(train) 2.146sec(infer)\n",
      "Epoch 60 tst: l 0.447 a 0.862 clct[np.int64(17), np.int64(8), np.int64(0), np.int64(15)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 61 tr: l 0.372 a 0.885 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 7.656sec(train) 2.315sec(infer)\n",
      "Epoch 61 tst: l 0.446 a 0.861 clct[np.int64(17), np.int64(8), np.int64(0), np.int64(15)]  0.160sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 62 tr: l 0.369 a 0.886 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 9.302sec(train) 2.177sec(infer)\n",
      "Epoch 62 tst: l 0.444 a 0.864 clct[np.int64(18), np.int64(8), np.int64(0), np.int64(14)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 63 tr: l 0.366 a 0.886 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 7.687sec(train) 2.142sec(infer)\n",
      "Epoch 63 tst: l 0.442 a 0.863 clct[np.int64(17), np.int64(8), np.int64(0), np.int64(15)]  0.143sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 64 tr: l 0.363 a 0.887 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 7.832sec(train) 2.167sec(infer)\n",
      "Epoch 64 tst: l 0.441 a 0.865 clct[np.int64(18), np.int64(8), np.int64(0), np.int64(14)]  0.160sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 65 tr: l 0.361 a 0.887 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 9.207sec(train) 2.148sec(infer)\n",
      "Epoch 65 tst: l 0.439 a 0.865 clct[np.int64(18), np.int64(8), np.int64(0), np.int64(14)]  0.146sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 66 tr: l 0.358 a 0.888 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 7.843sec(train) 2.146sec(infer)\n",
      "Epoch 66 tst: l 0.438 a 0.865 clct[np.int64(18), np.int64(8), np.int64(0), np.int64(14)]  0.146sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 67 tr: l 0.356 a 0.888 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 7.679sec(train) 2.110sec(infer)\n",
      "Epoch 67 tst: l 0.436 a 0.865 clct[np.int64(18), np.int64(8), np.int64(0), np.int64(14)]  0.161sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 68 tr: l 0.353 a 0.889 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 9.145sec(train) 2.144sec(infer)\n",
      "Epoch 68 tst: l 0.435 a 0.867 clct[np.int64(18), np.int64(8), np.int64(0), np.int64(14)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 69 tr: l 0.351 a 0.890 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 7.851sec(train) 2.140sec(infer)\n",
      "Epoch 69 tst: l 0.434 a 0.865 clct[np.int64(18), np.int64(8), np.int64(0), np.int64(14)]  0.143sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 70 tr: l 0.349 a 0.891 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 7.658sec(train) 2.135sec(infer)\n",
      "Epoch 70 tst: l 0.433 a 0.867 clct[np.int64(18), np.int64(8), np.int64(0), np.int64(14)]  0.158sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 71 tr: l 0.346 a 0.891 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 9.270sec(train) 2.150sec(infer)\n",
      "Epoch 71 tst: l 0.432 a 0.866 clct[np.int64(18), np.int64(8), np.int64(0), np.int64(14)]  0.143sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 72 tr: l 0.344 a 0.892 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 7.666sec(train) 2.147sec(infer)\n",
      "Epoch 72 tst: l 0.430 a 0.868 clct[np.int64(18), np.int64(8), np.int64(0), np.int64(14)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 73 tr: l 0.342 a 0.892 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 7.670sec(train) 2.061sec(infer)\n",
      "Epoch 73 tst: l 0.429 a 0.867 clct[np.int64(18), np.int64(8), np.int64(0), np.int64(14)]  0.160sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 74 tr: l 0.340 a 0.893 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 9.380sec(train) 2.148sec(infer)\n",
      "Epoch 74 tst: l 0.428 a 0.869 clct[np.int64(18), np.int64(8), np.int64(0), np.int64(14)]  0.148sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 75 tr: l 0.338 a 0.893 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 7.656sec(train) 2.146sec(infer)\n",
      "Epoch 75 tst: l 0.427 a 0.868 clct[np.int64(18), np.int64(8), np.int64(0), np.int64(14)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 76 tr: l 0.335 a 0.894 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 7.870sec(train) 1.978sec(infer)\n",
      "Epoch 76 tst: l 0.426 a 0.870 clct[np.int64(18), np.int64(8), np.int64(0), np.int64(14)]  0.159sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 77 tr: l 0.333 a 0.894 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 9.118sec(train) 2.148sec(infer)\n",
      "Epoch 77 tst: l 0.425 a 0.869 clct[np.int64(18), np.int64(8), np.int64(0), np.int64(14)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 78 tr: l 0.331 a 0.895 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 7.652sec(train) 2.145sec(infer)\n",
      "Epoch 78 tst: l 0.424 a 0.870 clct[np.int64(19), np.int64(7), np.int64(0), np.int64(14)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 79 tr: l 0.329 a 0.895 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 7.863sec(train) 1.974sec(infer)\n",
      "Epoch 79 tst: l 0.423 a 0.870 clct[np.int64(19), np.int64(7), np.int64(0), np.int64(14)]  0.159sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 80 tr: l 0.327 a 0.896 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 9.193sec(train) 2.150sec(infer)\n",
      "Epoch 80 tst: l 0.422 a 0.870 clct[np.int64(19), np.int64(7), np.int64(0), np.int64(14)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 81 tr: l 0.326 a 0.896 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 7.841sec(train) 2.149sec(infer)\n",
      "Epoch 81 tst: l 0.421 a 0.870 clct[np.int64(19), np.int64(7), np.int64(0), np.int64(14)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 82 tr: l 0.323 a 0.897 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 7.657sec(train) 1.947sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 82 tst: l 0.420 a 0.871 clct[np.int64(19), np.int64(7), np.int64(0), np.int64(14)]  0.203sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 83 tr: l 0.322 a 0.897 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 9.128sec(train) 2.149sec(infer)\n",
      "Epoch 83 tst: l 0.419 a 0.870 clct[np.int64(20), np.int64(7), np.int64(0), np.int64(13)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 84 tr: l 0.320 a 0.898 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 7.875sec(train) 2.148sec(infer)\n",
      "Epoch 84 tst: l 0.418 a 0.871 clct[np.int64(19), np.int64(7), np.int64(0), np.int64(14)]  0.147sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 85 tr: l 0.318 a 0.898 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 7.683sec(train) 1.928sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 85 tst: l 0.418 a 0.870 clct[np.int64(20), np.int64(7), np.int64(0), np.int64(13)]  0.241sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 86 tr: l 0.316 a 0.899 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 9.069sec(train) 2.148sec(infer)\n",
      "Epoch 86 tst: l 0.417 a 0.870 clct[np.int64(19), np.int64(7), np.int64(0), np.int64(14)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 87 tr: l 0.315 a 0.899 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 7.887sec(train) 2.143sec(infer)\n",
      "Epoch 87 tst: l 0.416 a 0.870 clct[np.int64(19), np.int64(7), np.int64(0), np.int64(14)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 88 tr: l 0.313 a 0.900 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 7.876sec(train) 1.917sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 88 tst: l 0.415 a 0.870 clct[np.int64(19), np.int64(7), np.int64(0), np.int64(14)]  0.255sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 89 tr: l 0.311 a 0.900 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 8.983sec(train) 2.150sec(infer)\n",
      "Epoch 89 tst: l 0.414 a 0.871 clct[np.int64(20), np.int64(7), np.int64(0), np.int64(13)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 90 tr: l 0.309 a 0.901 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 8.910sec(train) 2.149sec(infer)\n",
      "Epoch 90 tst: l 0.414 a 0.871 clct[np.int64(19), np.int64(7), np.int64(0), np.int64(14)]  0.146sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 91 tr: l 0.308 a 0.901 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 7.852sec(train) 2.323sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 91 tst: l 0.413 a 0.871 clct[np.int64(20), np.int64(7), np.int64(0), np.int64(13)]  0.228sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 92 tr: l 0.306 a 0.902 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 8.800sec(train) 2.149sec(infer)\n",
      "Epoch 92 tst: l 0.412 a 0.871 clct[np.int64(19), np.int64(7), np.int64(0), np.int64(14)]  0.147sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 93 tr: l 0.305 a 0.902 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 7.872sec(train) 2.144sec(infer)\n",
      "Epoch 93 tst: l 0.411 a 0.871 clct[np.int64(20), np.int64(7), np.int64(0), np.int64(13)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 94 tr: l 0.302 a 0.903 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 7.657sec(train) 2.144sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 94 tst: l 0.411 a 0.872 clct[np.int64(19), np.int64(7), np.int64(0), np.int64(14)]  0.227sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 95 tr: l 0.301 a 0.903 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 9.174sec(train) 2.150sec(infer)\n",
      "Epoch 95 tst: l 0.410 a 0.872 clct[np.int64(19), np.int64(8), np.int64(0), np.int64(13)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 96 tr: l 0.299 a 0.904 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 7.660sec(train) 2.148sec(infer)\n",
      "Epoch 96 tst: l 0.409 a 0.871 clct[np.int64(19), np.int64(8), np.int64(0), np.int64(13)]  0.143sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 97 tr: l 0.298 a 0.904 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 7.819sec(train) 1.818sec(infer)\n",
      "Epoch 97 tst: l 0.409 a 0.870 clct[np.int64(20), np.int64(7), np.int64(0), np.int64(13)]  0.100sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 98 tr: l 0.296 a 0.905 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 9.292sec(train) 2.149sec(infer)\n",
      "Epoch 98 tst: l 0.408 a 0.871 clct[np.int64(18), np.int64(8), np.int64(0), np.int64(14)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 99 tr: l 0.295 a 0.905 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 7.659sec(train) 2.144sec(infer)\n",
      "Epoch 99 tst: l 0.408 a 0.871 clct[np.int64(20), np.int64(7), np.int64(0), np.int64(13)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 100 tr: l 0.293 a 0.906 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 7.848sec(train) 1.920sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 100 tst: l 0.407 a 0.872 clct[np.int64(18), np.int64(8), np.int64(0), np.int64(14)]  0.251sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 101 tr: l 0.292 a 0.906 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 8.890sec(train) 2.147sec(infer)\n",
      "Epoch 101 tst: l 0.407 a 0.871 clct[np.int64(20), np.int64(7), np.int64(0), np.int64(13)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 102 tr: l 0.290 a 0.907 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 7.657sec(train) 2.145sec(infer)\n",
      "Epoch 102 tst: l 0.405 a 0.872 clct[np.int64(19), np.int64(8), np.int64(0), np.int64(13)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 103 tr: l 0.289 a 0.907 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 7.837sec(train) 2.016sec(infer)\n",
      "Epoch 103 tst: l 0.405 a 0.871 clct[np.int64(20), np.int64(7), np.int64(0), np.int64(13)]  0.160sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 104 tr: l 0.287 a 0.908 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 9.121sec(train) 2.145sec(infer)\n",
      "Epoch 104 tst: l 0.405 a 0.872 clct[np.int64(19), np.int64(9), np.int64(0), np.int64(12)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 105 tr: l 0.286 a 0.908 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 7.845sec(train) 2.147sec(infer)\n",
      "Epoch 105 tst: l 0.405 a 0.870 clct[np.int64(20), np.int64(7), np.int64(0), np.int64(13)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 106 tr: l 0.284 a 0.908 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 7.613sec(train) 2.097sec(infer)\n",
      "Epoch 106 tst: l 0.404 a 0.872 clct[np.int64(19), np.int64(8), np.int64(0), np.int64(13)]  0.161sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 107 tr: l 0.284 a 0.908 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 9.171sec(train) 2.147sec(infer)\n",
      "Epoch 107 tst: l 0.403 a 0.870 clct[np.int64(20), np.int64(8), np.int64(0), np.int64(12)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 108 tr: l 0.282 a 0.909 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 7.845sec(train) 2.143sec(infer)\n",
      "Epoch 108 tst: l 0.403 a 0.873 clct[np.int64(19), np.int64(9), np.int64(0), np.int64(12)]  0.143sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 109 tr: l 0.281 a 0.909 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 8.693sec(train) 2.129sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 109 tst: l 0.403 a 0.871 clct[np.int64(19), np.int64(9), np.int64(0), np.int64(12)]  0.225sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 110 tr: l 0.279 a 0.910 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 9.018sec(train) 2.149sec(infer)\n",
      "Epoch 110 tst: l 0.402 a 0.873 clct[np.int64(19), np.int64(9), np.int64(0), np.int64(12)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 111 tr: l 0.278 a 0.910 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 7.624sec(train) 2.144sec(infer)\n",
      "Epoch 111 tst: l 0.402 a 0.873 clct[np.int64(19), np.int64(9), np.int64(0), np.int64(12)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 112 tr: l 0.276 a 0.911 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 7.643sec(train) 1.926sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 112 tst: l 0.401 a 0.873 clct[np.int64(19), np.int64(9), np.int64(0), np.int64(12)]  0.243sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 113 tr: l 0.275 a 0.911 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 9.126sec(train) 2.151sec(infer)\n",
      "Epoch 113 tst: l 0.401 a 0.873 clct[np.int64(19), np.int64(9), np.int64(0), np.int64(12)]  0.146sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 114 tr: l 0.274 a 0.912 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 7.626sec(train) 2.149sec(infer)\n",
      "Epoch 114 tst: l 0.400 a 0.874 clct[np.int64(19), np.int64(9), np.int64(0), np.int64(12)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 115 tr: l 0.273 a 0.912 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 7.849sec(train) 2.015sec(infer)\n",
      "Epoch 115 tst: l 0.400 a 0.872 clct[np.int64(19), np.int64(9), np.int64(0), np.int64(12)]  0.160sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 116 tr: l 0.271 a 0.912 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 9.029sec(train) 2.144sec(infer)\n",
      "Epoch 116 tst: l 0.399 a 0.873 clct[np.int64(19), np.int64(9), np.int64(0), np.int64(12)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 117 tr: l 0.270 a 0.912 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 7.840sec(train) 2.142sec(infer)\n",
      "Epoch 117 tst: l 0.400 a 0.873 clct[np.int64(18), np.int64(9), np.int64(0), np.int64(13)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 118 tr: l 0.268 a 0.913 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 7.631sec(train) 2.105sec(infer)\n",
      "Epoch 118 tst: l 0.399 a 0.874 clct[np.int64(19), np.int64(9), np.int64(0), np.int64(12)]  0.160sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 119 tr: l 0.268 a 0.913 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 9.152sec(train) 2.147sec(infer)\n",
      "Epoch 119 tst: l 0.399 a 0.874 clct[np.int64(19), np.int64(9), np.int64(0), np.int64(12)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 120 tr: l 0.266 a 0.914 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 7.817sec(train) 2.144sec(infer)\n",
      "Epoch 120 tst: l 0.398 a 0.874 clct[np.int64(20), np.int64(9), np.int64(0), np.int64(11)]  0.146sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 121 tr: l 0.265 a 0.914 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 7.644sec(train) 2.062sec(infer)\n",
      "Epoch 121 tst: l 0.398 a 0.874 clct[np.int64(19), np.int64(9), np.int64(0), np.int64(12)]  0.161sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 122 tr: l 0.264 a 0.915 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 9.218sec(train) 2.147sec(infer)\n",
      "Epoch 122 tst: l 0.397 a 0.875 clct[np.int64(20), np.int64(9), np.int64(0), np.int64(11)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 123 tr: l 0.263 a 0.915 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 7.632sec(train) 2.143sec(infer)\n",
      "Epoch 123 tst: l 0.397 a 0.874 clct[np.int64(19), np.int64(9), np.int64(0), np.int64(12)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 124 tr: l 0.261 a 0.916 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 7.837sec(train) 2.017sec(infer)\n",
      "Epoch 124 tst: l 0.397 a 0.875 clct[np.int64(19), np.int64(9), np.int64(0), np.int64(12)]  0.161sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 125 tr: l 0.260 a 0.915 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 9.179sec(train) 2.145sec(infer)\n",
      "Epoch 125 tst: l 0.397 a 0.875 clct[np.int64(19), np.int64(9), np.int64(0), np.int64(12)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 126 tr: l 0.259 a 0.916 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 7.629sec(train) 2.143sec(infer)\n",
      "Epoch 126 tst: l 0.396 a 0.876 clct[np.int64(19), np.int64(9), np.int64(0), np.int64(12)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 127 tr: l 0.258 a 0.916 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 8.086sec(train) 1.980sec(infer)\n",
      "Epoch 127 tst: l 0.396 a 0.876 clct[np.int64(19), np.int64(9), np.int64(0), np.int64(12)]  0.160sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 128 tr: l 0.256 a 0.917 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 9.096sec(train) 2.149sec(infer)\n",
      "Epoch 128 tst: l 0.395 a 0.876 clct[np.int64(19), np.int64(9), np.int64(0), np.int64(12)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 129 tr: l 0.256 a 0.917 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 7.830sec(train) 2.144sec(infer)\n",
      "Epoch 129 tst: l 0.395 a 0.876 clct[np.int64(19), np.int64(9), np.int64(0), np.int64(12)]  0.143sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 130 tr: l 0.254 a 0.918 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 7.628sec(train) 2.062sec(infer)\n",
      "Epoch 130 tst: l 0.394 a 0.877 clct[np.int64(19), np.int64(9), np.int64(0), np.int64(12)]  0.160sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 131 tr: l 0.254 a 0.918 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 9.178sec(train) 2.150sec(infer)\n",
      "Epoch 131 tst: l 0.394 a 0.876 clct[np.int64(19), np.int64(9), np.int64(0), np.int64(12)]  0.142sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 132 tr: l 0.252 a 0.919 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 7.847sec(train) 2.145sec(infer)\n",
      "Epoch 132 tst: l 0.394 a 0.876 clct[np.int64(19), np.int64(9), np.int64(0), np.int64(12)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 133 tr: l 0.251 a 0.918 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 7.641sec(train) 1.963sec(infer)\n",
      "Epoch 133 tst: l 0.394 a 0.877 clct[np.int64(19), np.int64(9), np.int64(0), np.int64(12)]  0.159sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 134 tr: l 0.250 a 0.919 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 9.361sec(train) 2.147sec(infer)\n",
      "Epoch 134 tst: l 0.393 a 0.876 clct[np.int64(19), np.int64(9), np.int64(0), np.int64(12)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 135 tr: l 0.249 a 0.919 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 7.641sec(train) 2.146sec(infer)\n",
      "Epoch 135 tst: l 0.394 a 0.878 clct[np.int64(19), np.int64(9), np.int64(0), np.int64(12)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 136 tr: l 0.248 a 0.920 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 8.066sec(train) 2.129sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 136 tst: l 0.393 a 0.875 clct[np.int64(19), np.int64(9), np.int64(0), np.int64(12)]  0.227sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 137 tr: l 0.247 a 0.920 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 8.856sec(train) 2.148sec(infer)\n",
      "Epoch 137 tst: l 0.393 a 0.878 clct[np.int64(19), np.int64(9), np.int64(0), np.int64(12)]  0.146sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 138 tr: l 0.245 a 0.921 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 7.627sec(train) 2.144sec(infer)\n",
      "Epoch 138 tst: l 0.392 a 0.876 clct[np.int64(19), np.int64(9), np.int64(0), np.int64(12)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 139 tr: l 0.245 a 0.920 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 7.813sec(train) 1.974sec(infer)\n",
      "Epoch 139 tst: l 0.392 a 0.879 clct[np.int64(19), np.int64(9), np.int64(0), np.int64(12)]  0.160sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 140 tr: l 0.243 a 0.921 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 9.162sec(train) 2.142sec(infer)\n",
      "Epoch 140 tst: l 0.392 a 0.877 clct[np.int64(19), np.int64(9), np.int64(0), np.int64(12)]  0.147sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 141 tr: l 0.243 a 0.921 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 8.431sec(train) 2.142sec(infer)\n",
      "Epoch 141 tst: l 0.392 a 0.879 clct[np.int64(19), np.int64(9), np.int64(0), np.int64(12)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 142 tr: l 0.241 a 0.922 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 7.637sec(train) 2.083sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 142 tst: l 0.391 a 0.877 clct[np.int64(19), np.int64(9), np.int64(0), np.int64(12)]  0.221sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 143 tr: l 0.241 a 0.922 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 8.880sec(train) 2.147sec(infer)\n",
      "Epoch 143 tst: l 0.391 a 0.878 clct[np.int64(19), np.int64(9), np.int64(0), np.int64(12)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 144 tr: l 0.239 a 0.922 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 7.826sec(train) 2.145sec(infer)\n",
      "Epoch 144 tst: l 0.391 a 0.878 clct[np.int64(19), np.int64(9), np.int64(0), np.int64(12)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 145 tr: l 0.239 a 0.922 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 7.621sec(train) 1.995sec(infer)\n",
      "Epoch 145 tst: l 0.390 a 0.879 clct[np.int64(19), np.int64(9), np.int64(0), np.int64(12)]  0.160sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 146 tr: l 0.237 a 0.923 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 9.155sec(train) 2.148sec(infer)\n",
      "Epoch 146 tst: l 0.390 a 0.878 clct[np.int64(19), np.int64(9), np.int64(0), np.int64(12)]  0.143sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 147 tr: l 0.237 a 0.923 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 7.806sec(train) 2.147sec(infer)\n",
      "Epoch 147 tst: l 0.390 a 0.879 clct[np.int64(19), np.int64(9), np.int64(0), np.int64(12)]  0.146sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 148 tr: l 0.235 a 0.924 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 7.630sec(train) 2.009sec(infer)\n",
      "Epoch 148 tst: l 0.390 a 0.879 clct[np.int64(19), np.int64(9), np.int64(0), np.int64(12)]  0.158sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 149 tr: l 0.235 a 0.923 clct[np.int64(173), np.int64(104), np.int64(4), np.int64(119)]  lr 0.100000 9.244sec(train) 2.147sec(infer)\n",
      "Epoch 149 tst: l 0.390 a 0.879 clct[np.int64(19), np.int64(9), np.int64(0), np.int64(12)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "---train cluster Ended in 0.45 hour (1628.488 sec) \n",
      "---------------------------------IFCA, lr: 0.1, seed: 3657---------------------------------\n",
      "config: {'m': 400, 'm_test': 40, 'p': 4, 'n': 2000, 'uneven': False, 'local_model_init': False, 'Gp': 0.2, 'graph': 'fixed', 'h1': 512, 'num_epochs': 150, 'batch_size': 100, 'tau': 5, 'lr': 0.1, 'data_seed': 3657, 'train_seed': 3657, 'config_override': '', 'project_dir': 'output_dfca_gi'}\n",
      "Using device: cuda:3\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      "Generating partition_id_to_indices: 0it [00:00, ?it/s]"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      "Generating partition_id_to_indices: 126186it [00:00, 1261819.09it/s]"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      "Generating partition_id_to_indices: 264237it [00:00, 1331605.34it/s]"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      "Generating partition_id_to_indices: 404381it [00:00, 1363466.55it/s]"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      "Generating partition_id_to_indices: 543464it [00:00, 1374241.14it/s]"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      "Generating partition_id_to_indices: 682813it [00:00, 1381160.14it/s]"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      "Generating partition_id_to_indices: 814277it [00:00, 1370038.01it/s]"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch -1 tr: l 4.116 a 0.014 clct[np.int64(19), np.int64(13), np.int64(364), np.int64(4)]  3.307sec\n",
      "Epoch -1 tst: l 4.112 a 0.019 clct[np.int64(9), np.int64(5), np.int64(25), np.int64(1)]  0.149sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0 tr: l 3.495 a 0.286 clct[np.int64(16), np.int64(101), np.int64(282), np.int64(1)]  lr 0.100000 7.862sec(train) 2.148sec(infer)\n",
      "Epoch 0 tst: l 3.495 a 0.284 clct[np.int64(6), np.int64(9), np.int64(24), np.int64(1)]  0.145sec\n",
      "result written at output_dfca_gi/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1 tr: l 2.667 a 0.449 clct[np.int64(30), np.int64(91), np.int64(278), np.int64(1)]  lr 0.100000 8.659sec(train) 2.047sec(infer)\n",
      "Epoch 1 tst: l 2.635 a 0.450 clct[np.int64(4), np.int64(8), np.int64(28), np.int64(0)]  0.159sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2 tr: l 2.063 a 0.577 clct[np.int64(65), np.int64(96), np.int64(238), np.int64(1)]  lr 0.100000 8.952sec(train) 2.212sec(infer)\n",
      "Epoch 2 tst: l 2.012 a 0.576 clct[np.int64(11), np.int64(8), np.int64(21), np.int64(0)]  0.146sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3 tr: l 1.714 a 0.632 clct[np.int64(49), np.int64(99), np.int64(251), np.int64(1)]  lr 0.100000 7.904sec(train) 2.149sec(infer)\n",
      "Epoch 3 tst: l 1.649 a 0.639 clct[np.int64(8), np.int64(8), np.int64(24), np.int64(0)]  0.146sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4 tr: l 1.470 a 0.670 clct[np.int64(53), np.int64(101), np.int64(245), np.int64(1)]  lr 0.100000 7.652sec(train) 2.181sec(infer)\n",
      "Epoch 4 tst: l 1.411 a 0.683 clct[np.int64(9), np.int64(9), np.int64(22), np.int64(0)]  0.159sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5 tr: l 1.303 a 0.697 clct[np.int64(65), np.int64(97), np.int64(237), np.int64(1)]  lr 0.100000 9.325sec(train) 2.146sec(infer)\n",
      "Epoch 5 tst: l 1.234 a 0.713 clct[np.int64(10), np.int64(9), np.int64(21), np.int64(0)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6 tr: l 1.185 a 0.718 clct[np.int64(65), np.int64(99), np.int64(235), np.int64(1)]  lr 0.100000 7.651sec(train) 2.146sec(infer)\n",
      "Epoch 6 tst: l 1.129 a 0.729 clct[np.int64(10), np.int64(10), np.int64(20), np.int64(0)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7 tr: l 1.090 a 0.731 clct[np.int64(66), np.int64(98), np.int64(235), np.int64(1)]  lr 0.100000 7.673sec(train) 2.141sec(infer)\n",
      "Epoch 7 tst: l 1.027 a 0.744 clct[np.int64(9), np.int64(9), np.int64(22), np.int64(0)]  0.161sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8 tr: l 1.016 a 0.747 clct[np.int64(69), np.int64(99), np.int64(231), np.int64(1)]  lr 0.100000 9.168sec(train) 2.170sec(infer)\n",
      "Epoch 8 tst: l 0.965 a 0.752 clct[np.int64(11), np.int64(10), np.int64(19), np.int64(0)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9 tr: l 0.953 a 0.757 clct[np.int64(73), np.int64(98), np.int64(228), np.int64(1)]  lr 0.100000 7.699sec(train) 2.146sec(infer)\n",
      "Epoch 9 tst: l 0.901 a 0.769 clct[np.int64(9), np.int64(9), np.int64(22), np.int64(0)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10 tr: l 0.901 a 0.768 clct[np.int64(74), np.int64(99), np.int64(226), np.int64(1)]  lr 0.100000 8.309sec(train) 2.057sec(infer)\n",
      "Epoch 10 tst: l 0.854 a 0.774 clct[np.int64(11), np.int64(10), np.int64(19), np.int64(0)]  0.159sec\n",
      "result written at output_dfca_gi/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11 tr: l 0.856 a 0.775 clct[np.int64(78), np.int64(99), np.int64(222), np.int64(1)]  lr 0.100000 9.112sec(train) 2.149sec(infer)\n",
      "Epoch 11 tst: l 0.812 a 0.782 clct[np.int64(11), np.int64(9), np.int64(20), np.int64(0)]  0.146sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12 tr: l 0.818 a 0.784 clct[np.int64(78), np.int64(99), np.int64(222), np.int64(1)]  lr 0.100000 7.681sec(train) 2.145sec(infer)\n",
      "Epoch 12 tst: l 0.777 a 0.784 clct[np.int64(11), np.int64(10), np.int64(19), np.int64(0)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13 tr: l 0.786 a 0.789 clct[np.int64(79), np.int64(99), np.int64(221), np.int64(1)]  lr 0.100000 7.892sec(train) 1.989sec(infer)\n",
      "Epoch 13 tst: l 0.747 a 0.795 clct[np.int64(11), np.int64(9), np.int64(20), np.int64(0)]  0.159sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14 tr: l 0.756 a 0.796 clct[np.int64(80), np.int64(99), np.int64(220), np.int64(1)]  lr 0.100000 9.185sec(train) 2.145sec(infer)\n",
      "Epoch 14 tst: l 0.721 a 0.794 clct[np.int64(12), np.int64(10), np.int64(18), np.int64(0)]  0.146sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15 tr: l 0.730 a 0.801 clct[np.int64(81), np.int64(99), np.int64(219), np.int64(1)]  lr 0.100000 8.624sec(train) 2.142sec(infer)\n",
      "Epoch 15 tst: l 0.696 a 0.807 clct[np.int64(10), np.int64(10), np.int64(20), np.int64(0)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16 tr: l 0.707 a 0.806 clct[np.int64(81), np.int64(100), np.int64(218), np.int64(1)]  lr 0.100000 7.697sec(train) 2.102sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16 tst: l 0.677 a 0.808 clct[np.int64(13), np.int64(11), np.int64(16), np.int64(0)]  0.224sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17 tr: l 0.686 a 0.811 clct[np.int64(83), np.int64(100), np.int64(216), np.int64(1)]  lr 0.100000 9.074sec(train) 2.146sec(infer)\n",
      "Epoch 17 tst: l 0.656 a 0.818 clct[np.int64(10), np.int64(11), np.int64(19), np.int64(0)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18 tr: l 0.667 a 0.814 clct[np.int64(82), np.int64(101), np.int64(216), np.int64(1)]  lr 0.100000 7.700sec(train) 2.145sec(infer)\n",
      "Epoch 18 tst: l 0.642 a 0.816 clct[np.int64(13), np.int64(11), np.int64(16), np.int64(0)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19 tr: l 0.650 a 0.819 clct[np.int64(86), np.int64(101), np.int64(212), np.int64(1)]  lr 0.100000 7.691sec(train) 1.939sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19 tst: l 0.625 a 0.824 clct[np.int64(10), np.int64(11), np.int64(19), np.int64(0)]  0.225sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20 tr: l 0.634 a 0.822 clct[np.int64(87), np.int64(102), np.int64(210), np.int64(1)]  lr 0.100000 9.289sec(train) 2.145sec(infer)\n",
      "Epoch 20 tst: l 0.612 a 0.825 clct[np.int64(12), np.int64(12), np.int64(16), np.int64(0)]  0.148sec\n",
      "result written at output_dfca_gi/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21 tr: l 0.619 a 0.826 clct[np.int64(87), np.int64(101), np.int64(211), np.int64(1)]  lr 0.100000 7.624sec(train) 2.145sec(infer)\n",
      "Epoch 21 tst: l 0.598 a 0.831 clct[np.int64(10), np.int64(11), np.int64(19), np.int64(0)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22 tr: l 0.605 a 0.829 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 8.429sec(train) 2.290sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22 tst: l 0.587 a 0.829 clct[np.int64(11), np.int64(12), np.int64(17), np.int64(0)]  0.224sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23 tr: l 0.593 a 0.832 clct[np.int64(87), np.int64(101), np.int64(211), np.int64(1)]  lr 0.100000 8.797sec(train) 2.149sec(infer)\n",
      "Epoch 23 tst: l 0.577 a 0.834 clct[np.int64(9), np.int64(11), np.int64(20), np.int64(0)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24 tr: l 0.581 a 0.835 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 7.642sec(train) 2.150sec(infer)\n",
      "Epoch 24 tst: l 0.567 a 0.835 clct[np.int64(11), np.int64(12), np.int64(17), np.int64(0)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25 tr: l 0.571 a 0.837 clct[np.int64(87), np.int64(102), np.int64(210), np.int64(1)]  lr 0.100000 7.850sec(train) 2.116sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25 tst: l 0.558 a 0.839 clct[np.int64(11), np.int64(11), np.int64(18), np.int64(0)]  0.230sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 26 tr: l 0.560 a 0.839 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 8.845sec(train) 2.148sec(infer)\n",
      "Epoch 26 tst: l 0.550 a 0.840 clct[np.int64(11), np.int64(12), np.int64(17), np.int64(0)]  0.146sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 27 tr: l 0.551 a 0.841 clct[np.int64(86), np.int64(102), np.int64(211), np.int64(1)]  lr 0.100000 7.858sec(train) 2.142sec(infer)\n",
      "Epoch 27 tst: l 0.542 a 0.842 clct[np.int64(11), np.int64(11), np.int64(18), np.int64(0)]  0.146sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 28 tr: l 0.541 a 0.844 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 7.641sec(train) 1.976sec(infer)\n",
      "Epoch 28 tst: l 0.535 a 0.845 clct[np.int64(11), np.int64(12), np.int64(17), np.int64(0)]  0.158sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 29 tr: l 0.533 a 0.845 clct[np.int64(86), np.int64(102), np.int64(211), np.int64(1)]  lr 0.100000 9.341sec(train) 2.146sec(infer)\n",
      "Epoch 29 tst: l 0.528 a 0.847 clct[np.int64(11), np.int64(11), np.int64(18), np.int64(0)]  0.146sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 30 tr: l 0.525 a 0.847 clct[np.int64(87), np.int64(102), np.int64(210), np.int64(1)]  lr 0.100000 7.623sec(train) 2.147sec(infer)\n",
      "Epoch 30 tst: l 0.523 a 0.847 clct[np.int64(11), np.int64(12), np.int64(17), np.int64(0)]  0.147sec\n",
      "result written at output_dfca_gi/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 31 tr: l 0.517 a 0.849 clct[np.int64(86), np.int64(102), np.int64(211), np.int64(1)]  lr 0.100000 7.793sec(train) 1.927sec(infer)\n",
      "Epoch 31 tst: l 0.516 a 0.849 clct[np.int64(11), np.int64(12), np.int64(17), np.int64(0)]  0.116sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 32 tr: l 0.510 a 0.851 clct[np.int64(87), np.int64(102), np.int64(210), np.int64(1)]  lr 0.100000 9.270sec(train) 2.149sec(infer)\n",
      "Epoch 32 tst: l 0.511 a 0.850 clct[np.int64(11), np.int64(12), np.int64(17), np.int64(0)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 33 tr: l 0.503 a 0.853 clct[np.int64(87), np.int64(102), np.int64(210), np.int64(1)]  lr 0.100000 7.620sec(train) 2.142sec(infer)\n",
      "Epoch 33 tst: l 0.505 a 0.852 clct[np.int64(11), np.int64(12), np.int64(17), np.int64(0)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 34 tr: l 0.496 a 0.854 clct[np.int64(87), np.int64(102), np.int64(210), np.int64(1)]  lr 0.100000 7.858sec(train) 2.118sec(infer)\n",
      "Epoch 34 tst: l 0.501 a 0.850 clct[np.int64(11), np.int64(12), np.int64(17), np.int64(0)]  0.159sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 35 tr: l 0.490 a 0.856 clct[np.int64(87), np.int64(102), np.int64(210), np.int64(1)]  lr 0.100000 8.872sec(train) 2.250sec(infer)\n",
      "Epoch 35 tst: l 0.496 a 0.853 clct[np.int64(11), np.int64(12), np.int64(17), np.int64(0)]  0.146sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 36 tr: l 0.484 a 0.857 clct[np.int64(87), np.int64(102), np.int64(210), np.int64(1)]  lr 0.100000 7.650sec(train) 2.145sec(infer)\n",
      "Epoch 36 tst: l 0.493 a 0.852 clct[np.int64(11), np.int64(12), np.int64(17), np.int64(0)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 37 tr: l 0.478 a 0.858 clct[np.int64(87), np.int64(102), np.int64(210), np.int64(1)]  lr 0.100000 7.842sec(train) 2.208sec(infer)\n",
      "Epoch 37 tst: l 0.488 a 0.854 clct[np.int64(11), np.int64(12), np.int64(17), np.int64(0)]  0.159sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 38 tr: l 0.472 a 0.859 clct[np.int64(87), np.int64(102), np.int64(210), np.int64(1)]  lr 0.100000 9.016sec(train) 2.201sec(infer)\n",
      "Epoch 38 tst: l 0.484 a 0.855 clct[np.int64(11), np.int64(12), np.int64(17), np.int64(0)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 39 tr: l 0.467 a 0.861 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 7.892sec(train) 2.144sec(infer)\n",
      "Epoch 39 tst: l 0.480 a 0.856 clct[np.int64(11), np.int64(12), np.int64(17), np.int64(0)]  0.146sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 40 tr: l 0.462 a 0.862 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 7.652sec(train) 2.167sec(infer)\n",
      "Epoch 40 tst: l 0.477 a 0.858 clct[np.int64(11), np.int64(12), np.int64(17), np.int64(0)]  0.160sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 41 tr: l 0.457 a 0.863 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 9.070sec(train) 2.152sec(infer)\n",
      "Epoch 41 tst: l 0.474 a 0.857 clct[np.int64(11), np.int64(12), np.int64(17), np.int64(0)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 42 tr: l 0.452 a 0.865 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 7.946sec(train) 2.145sec(infer)\n",
      "Epoch 42 tst: l 0.471 a 0.860 clct[np.int64(11), np.int64(12), np.int64(17), np.int64(0)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 43 tr: l 0.447 a 0.866 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 7.663sec(train) 2.069sec(infer)\n",
      "Epoch 43 tst: l 0.467 a 0.858 clct[np.int64(11), np.int64(12), np.int64(17), np.int64(0)]  0.160sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 44 tr: l 0.443 a 0.867 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 9.129sec(train) 2.152sec(infer)\n",
      "Epoch 44 tst: l 0.465 a 0.862 clct[np.int64(11), np.int64(12), np.int64(17), np.int64(0)]  0.148sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 45 tr: l 0.439 a 0.868 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 7.626sec(train) 2.146sec(infer)\n",
      "Epoch 45 tst: l 0.462 a 0.862 clct[np.int64(11), np.int64(12), np.int64(17), np.int64(0)]  0.143sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 46 tr: l 0.434 a 0.869 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 7.866sec(train) 2.120sec(infer)\n",
      "Epoch 46 tst: l 0.460 a 0.861 clct[np.int64(11), np.int64(12), np.int64(17), np.int64(0)]  0.159sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 47 tr: l 0.430 a 0.870 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 9.148sec(train) 2.149sec(infer)\n",
      "Epoch 47 tst: l 0.456 a 0.863 clct[np.int64(11), np.int64(12), np.int64(17), np.int64(0)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 48 tr: l 0.426 a 0.871 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 7.654sec(train) 2.147sec(infer)\n",
      "Epoch 48 tst: l 0.454 a 0.864 clct[np.int64(11), np.int64(12), np.int64(17), np.int64(0)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 49 tr: l 0.423 a 0.872 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 7.765sec(train) 2.171sec(infer)\n",
      "Epoch 49 tst: l 0.452 a 0.863 clct[np.int64(11), np.int64(12), np.int64(17), np.int64(0)]  0.158sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 50 tr: l 0.419 a 0.873 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 9.300sec(train) 2.152sec(infer)\n",
      "Epoch 50 tst: l 0.450 a 0.863 clct[np.int64(11), np.int64(12), np.int64(17), np.int64(0)]  0.144sec\n",
      "result written at output_dfca_gi/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 51 tr: l 0.415 a 0.874 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 7.840sec(train) 2.146sec(infer)\n",
      "Epoch 51 tst: l 0.448 a 0.863 clct[np.int64(11), np.int64(12), np.int64(17), np.int64(0)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 52 tr: l 0.412 a 0.874 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 8.253sec(train) 2.335sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 52 tst: l 0.447 a 0.864 clct[np.int64(11), np.int64(12), np.int64(17), np.int64(0)]  0.298sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 53 tr: l 0.408 a 0.876 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 9.039sec(train) 2.149sec(infer)\n",
      "Epoch 53 tst: l 0.444 a 0.863 clct[np.int64(11), np.int64(12), np.int64(17), np.int64(0)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 54 tr: l 0.405 a 0.876 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 7.845sec(train) 2.148sec(infer)\n",
      "Epoch 54 tst: l 0.443 a 0.862 clct[np.int64(11), np.int64(12), np.int64(17), np.int64(0)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 55 tr: l 0.402 a 0.878 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 7.611sec(train) 3.289sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 55 tst: l 0.440 a 0.864 clct[np.int64(10), np.int64(12), np.int64(18), np.int64(0)]  0.288sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 56 tr: l 0.399 a 0.878 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 8.708sec(train) 2.146sec(infer)\n",
      "Epoch 56 tst: l 0.440 a 0.863 clct[np.int64(11), np.int64(11), np.int64(18), np.int64(0)]  0.146sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 57 tr: l 0.395 a 0.879 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 7.631sec(train) 2.142sec(infer)\n",
      "Epoch 57 tst: l 0.437 a 0.866 clct[np.int64(10), np.int64(12), np.int64(18), np.int64(0)]  0.146sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 58 tr: l 0.393 a 0.879 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 7.746sec(train) 1.100sec(infer)\n",
      "Epoch 58 tst: l 0.437 a 0.863 clct[np.int64(11), np.int64(11), np.int64(18), np.int64(0)]  0.100sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 59 tr: l 0.390 a 0.881 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 7.581sec(train) 1.101sec(infer)\n",
      "Epoch 59 tst: l 0.434 a 0.866 clct[np.int64(10), np.int64(12), np.int64(18), np.int64(0)]  0.100sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 60 tr: l 0.387 a 0.881 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 7.539sec(train) 1.101sec(infer)\n",
      "Epoch 60 tst: l 0.434 a 0.864 clct[np.int64(10), np.int64(11), np.int64(19), np.int64(0)]  0.100sec\n",
      "result written at output_dfca_gi/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 61 tr: l 0.384 a 0.882 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 8.294sec(train) 1.103sec(infer)\n",
      "Epoch 61 tst: l 0.431 a 0.866 clct[np.int64(10), np.int64(12), np.int64(18), np.int64(0)]  0.101sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 62 tr: l 0.381 a 0.882 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 7.466sec(train) 1.104sec(infer)\n",
      "Epoch 62 tst: l 0.431 a 0.864 clct[np.int64(10), np.int64(11), np.int64(19), np.int64(0)]  0.100sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 63 tr: l 0.378 a 0.884 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 7.765sec(train) 1.103sec(infer)\n",
      "Epoch 63 tst: l 0.429 a 0.866 clct[np.int64(10), np.int64(12), np.int64(18), np.int64(0)]  0.100sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 64 tr: l 0.376 a 0.884 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 6.087sec(train) 2.148sec(infer)\n",
      "Epoch 64 tst: l 0.429 a 0.866 clct[np.int64(10), np.int64(11), np.int64(19), np.int64(0)]  0.160sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 65 tr: l 0.373 a 0.885 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 8.550sec(train) 2.500sec(infer)\n",
      "Epoch 65 tst: l 0.426 a 0.867 clct[np.int64(10), np.int64(12), np.int64(18), np.int64(0)]  0.148sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 66 tr: l 0.370 a 0.886 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 7.393sec(train) 2.145sec(infer)\n",
      "Epoch 66 tst: l 0.427 a 0.867 clct[np.int64(10), np.int64(10), np.int64(20), np.int64(0)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 67 tr: l 0.368 a 0.887 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 7.529sec(train) 2.321sec(infer)\n",
      "Epoch 67 tst: l 0.424 a 0.868 clct[np.int64(10), np.int64(12), np.int64(18), np.int64(0)]  0.159sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 68 tr: l 0.365 a 0.887 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 9.007sec(train) 2.339sec(infer)\n",
      "Epoch 68 tst: l 0.424 a 0.867 clct[np.int64(11), np.int64(9), np.int64(20), np.int64(0)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 69 tr: l 0.363 a 0.888 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 7.647sec(train) 2.144sec(infer)\n",
      "Epoch 69 tst: l 0.422 a 0.869 clct[np.int64(11), np.int64(10), np.int64(19), np.int64(0)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 70 tr: l 0.360 a 0.888 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 7.822sec(train) 2.229sec(infer)\n",
      "Epoch 70 tst: l 0.422 a 0.868 clct[np.int64(11), np.int64(9), np.int64(20), np.int64(0)]  0.158sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 71 tr: l 0.358 a 0.889 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 9.124sec(train) 2.146sec(infer)\n",
      "Epoch 71 tst: l 0.420 a 0.870 clct[np.int64(11), np.int64(10), np.int64(19), np.int64(0)]  0.148sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 72 tr: l 0.356 a 0.890 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 7.643sec(train) 2.141sec(infer)\n",
      "Epoch 72 tst: l 0.419 a 0.868 clct[np.int64(11), np.int64(9), np.int64(20), np.int64(0)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 73 tr: l 0.353 a 0.891 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 8.105sec(train) 2.052sec(infer)\n",
      "Epoch 73 tst: l 0.417 a 0.871 clct[np.int64(11), np.int64(10), np.int64(19), np.int64(0)]  0.160sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 74 tr: l 0.351 a 0.891 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 9.096sec(train) 2.146sec(infer)\n",
      "Epoch 74 tst: l 0.417 a 0.870 clct[np.int64(11), np.int64(9), np.int64(20), np.int64(0)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 75 tr: l 0.349 a 0.892 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 7.839sec(train) 2.147sec(infer)\n",
      "Epoch 75 tst: l 0.415 a 0.872 clct[np.int64(11), np.int64(10), np.int64(19), np.int64(0)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 76 tr: l 0.347 a 0.892 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 7.652sec(train) 2.077sec(infer)\n",
      "Epoch 76 tst: l 0.415 a 0.871 clct[np.int64(11), np.int64(9), np.int64(20), np.int64(0)]  0.157sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 77 tr: l 0.345 a 0.893 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 9.260sec(train) 2.147sec(infer)\n",
      "Epoch 77 tst: l 0.413 a 0.872 clct[np.int64(11), np.int64(9), np.int64(20), np.int64(0)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 78 tr: l 0.342 a 0.893 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 8.534sec(train) 2.144sec(infer)\n",
      "Epoch 78 tst: l 0.413 a 0.872 clct[np.int64(11), np.int64(9), np.int64(20), np.int64(0)]  0.143sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 79 tr: l 0.340 a 0.894 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 8.353sec(train) 2.486sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 79 tst: l 0.411 a 0.873 clct[np.int64(11), np.int64(9), np.int64(20), np.int64(0)]  0.226sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 80 tr: l 0.338 a 0.894 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 8.807sec(train) 2.151sec(infer)\n",
      "Epoch 80 tst: l 0.412 a 0.873 clct[np.int64(11), np.int64(9), np.int64(20), np.int64(0)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 81 tr: l 0.336 a 0.895 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 7.632sec(train) 2.146sec(infer)\n",
      "Epoch 81 tst: l 0.410 a 0.874 clct[np.int64(11), np.int64(9), np.int64(20), np.int64(0)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 82 tr: l 0.334 a 0.895 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 7.793sec(train) 2.451sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 82 tst: l 0.410 a 0.874 clct[np.int64(11), np.int64(9), np.int64(20), np.int64(0)]  0.223sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 83 tr: l 0.332 a 0.896 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 8.676sec(train) 2.152sec(infer)\n",
      "Epoch 83 tst: l 0.409 a 0.876 clct[np.int64(11), np.int64(9), np.int64(20), np.int64(0)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 84 tr: l 0.330 a 0.897 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 7.982sec(train) 2.147sec(infer)\n",
      "Epoch 84 tst: l 0.408 a 0.874 clct[np.int64(11), np.int64(9), np.int64(20), np.int64(0)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 85 tr: l 0.328 a 0.897 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 7.844sec(train) 2.358sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 85 tst: l 0.407 a 0.877 clct[np.int64(11), np.int64(9), np.int64(20), np.int64(0)]  0.218sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 86 tr: l 0.327 a 0.897 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 9.031sec(train) 2.148sec(infer)\n",
      "Epoch 86 tst: l 0.407 a 0.877 clct[np.int64(11), np.int64(9), np.int64(20), np.int64(0)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 87 tr: l 0.325 a 0.898 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 7.832sec(train) 2.145sec(infer)\n",
      "Epoch 87 tst: l 0.405 a 0.877 clct[np.int64(11), np.int64(9), np.int64(20), np.int64(0)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 88 tr: l 0.323 a 0.898 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 7.630sec(train) 2.430sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 88 tst: l 0.406 a 0.877 clct[np.int64(11), np.int64(9), np.int64(20), np.int64(0)]  0.216sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 89 tr: l 0.321 a 0.899 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 8.763sec(train) 2.150sec(infer)\n",
      "Epoch 89 tst: l 0.404 a 0.878 clct[np.int64(11), np.int64(9), np.int64(20), np.int64(0)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 90 tr: l 0.319 a 0.899 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 7.852sec(train) 2.152sec(infer)\n",
      "Epoch 90 tst: l 0.405 a 0.878 clct[np.int64(11), np.int64(9), np.int64(20), np.int64(0)]  0.146sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 91 tr: l 0.317 a 0.900 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 7.622sec(train) 2.432sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 91 tst: l 0.403 a 0.879 clct[np.int64(11), np.int64(9), np.int64(20), np.int64(0)]  0.225sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 92 tr: l 0.316 a 0.900 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 9.101sec(train) 2.147sec(infer)\n",
      "Epoch 92 tst: l 0.404 a 0.879 clct[np.int64(11), np.int64(9), np.int64(20), np.int64(0)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 93 tr: l 0.314 a 0.901 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 7.635sec(train) 2.146sec(infer)\n",
      "Epoch 93 tst: l 0.402 a 0.880 clct[np.int64(11), np.int64(9), np.int64(20), np.int64(0)]  0.143sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 94 tr: l 0.312 a 0.901 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 7.602sec(train) 2.469sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 94 tst: l 0.403 a 0.879 clct[np.int64(11), np.int64(9), np.int64(20), np.int64(0)]  0.233sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 95 tr: l 0.311 a 0.901 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 8.826sec(train) 2.148sec(infer)\n",
      "Epoch 95 tst: l 0.401 a 0.881 clct[np.int64(11), np.int64(9), np.int64(20), np.int64(0)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 96 tr: l 0.309 a 0.902 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 7.643sec(train) 2.146sec(infer)\n",
      "Epoch 96 tst: l 0.402 a 0.880 clct[np.int64(11), np.int64(9), np.int64(20), np.int64(0)]  0.146sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 97 tr: l 0.307 a 0.902 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 7.809sec(train) 2.344sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 97 tst: l 0.400 a 0.880 clct[np.int64(11), np.int64(9), np.int64(20), np.int64(0)]  0.217sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 98 tr: l 0.306 a 0.903 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 8.690sec(train) 2.153sec(infer)\n",
      "Epoch 98 tst: l 0.401 a 0.880 clct[np.int64(11), np.int64(8), np.int64(21), np.int64(0)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 99 tr: l 0.304 a 0.903 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 7.664sec(train) 2.146sec(infer)\n",
      "Epoch 99 tst: l 0.399 a 0.880 clct[np.int64(11), np.int64(9), np.int64(20), np.int64(0)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 100 tr: l 0.303 a 0.904 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 7.814sec(train) 2.086sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 100 tst: l 0.400 a 0.881 clct[np.int64(11), np.int64(8), np.int64(21), np.int64(0)]  0.223sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 101 tr: l 0.301 a 0.904 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 8.799sec(train) 2.149sec(infer)\n",
      "Epoch 101 tst: l 0.398 a 0.882 clct[np.int64(11), np.int64(9), np.int64(20), np.int64(0)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 102 tr: l 0.300 a 0.905 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 7.884sec(train) 2.146sec(infer)\n",
      "Epoch 102 tst: l 0.399 a 0.881 clct[np.int64(11), np.int64(8), np.int64(21), np.int64(0)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 103 tr: l 0.298 a 0.905 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 7.659sec(train) 1.950sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 103 tst: l 0.398 a 0.882 clct[np.int64(11), np.int64(9), np.int64(20), np.int64(0)]  0.204sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 104 tr: l 0.297 a 0.906 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 9.152sec(train) 2.153sec(infer)\n",
      "Epoch 104 tst: l 0.398 a 0.881 clct[np.int64(11), np.int64(8), np.int64(21), np.int64(0)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 105 tr: l 0.295 a 0.906 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 7.663sec(train) 2.148sec(infer)\n",
      "Epoch 105 tst: l 0.397 a 0.883 clct[np.int64(11), np.int64(9), np.int64(20), np.int64(0)]  0.143sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 106 tr: l 0.294 a 0.906 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 7.675sec(train) 2.065sec(infer)\n",
      "Epoch 106 tst: l 0.398 a 0.882 clct[np.int64(11), np.int64(8), np.int64(21), np.int64(0)]  0.160sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 107 tr: l 0.292 a 0.906 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 9.186sec(train) 2.151sec(infer)\n",
      "Epoch 107 tst: l 0.396 a 0.884 clct[np.int64(11), np.int64(9), np.int64(20), np.int64(0)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 108 tr: l 0.291 a 0.907 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 7.672sec(train) 2.149sec(infer)\n",
      "Epoch 108 tst: l 0.397 a 0.882 clct[np.int64(11), np.int64(8), np.int64(21), np.int64(0)]  0.146sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 109 tr: l 0.290 a 0.907 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 7.877sec(train) 2.105sec(infer)\n",
      "Epoch 109 tst: l 0.396 a 0.884 clct[np.int64(11), np.int64(8), np.int64(21), np.int64(0)]  0.159sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 110 tr: l 0.288 a 0.907 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 9.222sec(train) 2.153sec(infer)\n",
      "Epoch 110 tst: l 0.396 a 0.883 clct[np.int64(11), np.int64(8), np.int64(21), np.int64(0)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 111 tr: l 0.287 a 0.908 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 7.662sec(train) 2.148sec(infer)\n",
      "Epoch 111 tst: l 0.395 a 0.883 clct[np.int64(11), np.int64(8), np.int64(21), np.int64(0)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 112 tr: l 0.285 a 0.908 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 8.064sec(train) 1.954sec(infer)\n",
      "Epoch 112 tst: l 0.396 a 0.883 clct[np.int64(11), np.int64(8), np.int64(21), np.int64(0)]  0.187sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 113 tr: l 0.284 a 0.909 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 9.231sec(train) 2.148sec(infer)\n",
      "Epoch 113 tst: l 0.394 a 0.884 clct[np.int64(11), np.int64(8), np.int64(21), np.int64(0)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 114 tr: l 0.283 a 0.909 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 7.855sec(train) 2.148sec(infer)\n",
      "Epoch 114 tst: l 0.395 a 0.883 clct[np.int64(11), np.int64(8), np.int64(21), np.int64(0)]  0.146sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 115 tr: l 0.282 a 0.909 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 8.791sec(train) 2.593sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 115 tst: l 0.394 a 0.884 clct[np.int64(11), np.int64(8), np.int64(21), np.int64(0)]  0.221sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 116 tr: l 0.280 a 0.910 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 8.624sec(train) 2.152sec(infer)\n",
      "Epoch 116 tst: l 0.394 a 0.884 clct[np.int64(11), np.int64(8), np.int64(21), np.int64(0)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 117 tr: l 0.279 a 0.910 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 8.915sec(train) 2.151sec(infer)\n",
      "Epoch 117 tst: l 0.394 a 0.884 clct[np.int64(11), np.int64(8), np.int64(21), np.int64(0)]  0.146sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 118 tr: l 0.277 a 0.911 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 7.630sec(train) 2.969sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 118 tst: l 0.394 a 0.884 clct[np.int64(11), np.int64(8), np.int64(21), np.int64(0)]  0.229sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 119 tr: l 0.276 a 0.911 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 8.651sec(train) 2.149sec(infer)\n",
      "Epoch 119 tst: l 0.393 a 0.884 clct[np.int64(11), np.int64(8), np.int64(21), np.int64(0)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 120 tr: l 0.275 a 0.911 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 8.930sec(train) 2.143sec(infer)\n",
      "Epoch 120 tst: l 0.393 a 0.884 clct[np.int64(11), np.int64(8), np.int64(21), np.int64(0)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 121 tr: l 0.274 a 0.911 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 8.046sec(train) 2.807sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 121 tst: l 0.393 a 0.885 clct[np.int64(11), np.int64(8), np.int64(21), np.int64(0)]  0.212sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 122 tr: l 0.273 a 0.912 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 8.227sec(train) 2.150sec(infer)\n",
      "Epoch 122 tst: l 0.393 a 0.885 clct[np.int64(11), np.int64(8), np.int64(21), np.int64(0)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 123 tr: l 0.272 a 0.912 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 7.668sec(train) 2.149sec(infer)\n",
      "Epoch 123 tst: l 0.392 a 0.887 clct[np.int64(11), np.int64(7), np.int64(22), np.int64(0)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 124 tr: l 0.270 a 0.913 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 8.111sec(train) 2.839sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 124 tst: l 0.393 a 0.885 clct[np.int64(11), np.int64(8), np.int64(21), np.int64(0)]  0.214sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 125 tr: l 0.269 a 0.913 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 8.174sec(train) 2.147sec(infer)\n",
      "Epoch 125 tst: l 0.392 a 0.885 clct[np.int64(11), np.int64(8), np.int64(21), np.int64(0)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 126 tr: l 0.268 a 0.914 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 7.848sec(train) 2.146sec(infer)\n",
      "Epoch 126 tst: l 0.392 a 0.884 clct[np.int64(11), np.int64(8), np.int64(21), np.int64(0)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 127 tr: l 0.267 a 0.914 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 7.836sec(train) 2.953sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 127 tst: l 0.391 a 0.885 clct[np.int64(11), np.int64(8), np.int64(21), np.int64(0)]  0.209sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 128 tr: l 0.265 a 0.914 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 8.210sec(train) 2.149sec(infer)\n",
      "Epoch 128 tst: l 0.392 a 0.884 clct[np.int64(11), np.int64(8), np.int64(21), np.int64(0)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 129 tr: l 0.264 a 0.914 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 7.842sec(train) 2.148sec(infer)\n",
      "Epoch 129 tst: l 0.391 a 0.885 clct[np.int64(11), np.int64(8), np.int64(21), np.int64(0)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 130 tr: l 0.263 a 0.915 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 7.840sec(train) 2.828sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 130 tst: l 0.391 a 0.885 clct[np.int64(11), np.int64(8), np.int64(21), np.int64(0)]  0.215sec\n",
      "result written at output_dfca_gi/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 131 tr: l 0.262 a 0.915 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 8.371sec(train) 2.153sec(infer)\n",
      "Epoch 131 tst: l 0.390 a 0.886 clct[np.int64(11), np.int64(8), np.int64(21), np.int64(0)]  0.143sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 132 tr: l 0.261 a 0.916 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 7.676sec(train) 2.149sec(infer)\n",
      "Epoch 132 tst: l 0.391 a 0.886 clct[np.int64(11), np.int64(8), np.int64(21), np.int64(0)]  0.146sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 133 tr: l 0.259 a 0.916 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 8.116sec(train) 2.842sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 133 tst: l 0.390 a 0.885 clct[np.int64(11), np.int64(8), np.int64(21), np.int64(0)]  0.220sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 134 tr: l 0.259 a 0.916 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 8.932sec(train) 2.145sec(infer)\n",
      "Epoch 134 tst: l 0.390 a 0.886 clct[np.int64(11), np.int64(8), np.int64(21), np.int64(0)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 135 tr: l 0.257 a 0.917 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 7.656sec(train) 2.145sec(infer)\n",
      "Epoch 135 tst: l 0.390 a 0.885 clct[np.int64(11), np.int64(8), np.int64(21), np.int64(0)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 136 tr: l 0.256 a 0.917 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 8.851sec(train) 2.953sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 136 tst: l 0.390 a 0.886 clct[np.int64(11), np.int64(8), np.int64(21), np.int64(0)]  0.223sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 137 tr: l 0.255 a 0.917 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 7.892sec(train) 2.154sec(infer)\n",
      "Epoch 137 tst: l 0.390 a 0.885 clct[np.int64(11), np.int64(8), np.int64(21), np.int64(0)]  0.146sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 138 tr: l 0.254 a 0.917 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 7.904sec(train) 2.116sec(infer)\n",
      "Epoch 138 tst: l 0.389 a 0.886 clct[np.int64(11), np.int64(8), np.int64(21), np.int64(0)]  0.196sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 139 tr: l 0.253 a 0.918 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 8.328sec(train) 2.888sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 139 tst: l 0.390 a 0.887 clct[np.int64(11), np.int64(7), np.int64(22), np.int64(0)]  0.216sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 140 tr: l 0.252 a 0.918 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 7.823sec(train) 2.152sec(infer)\n",
      "Epoch 140 tst: l 0.390 a 0.885 clct[np.int64(11), np.int64(8), np.int64(21), np.int64(0)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 141 tr: l 0.251 a 0.919 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 8.093sec(train) 2.214sec(infer)\n",
      "Epoch 141 tst: l 0.390 a 0.887 clct[np.int64(11), np.int64(7), np.int64(22), np.int64(0)]  0.191sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 142 tr: l 0.250 a 0.919 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 8.559sec(train) 2.967sec(infer)\n",
      "Epoch 142 tst: l 0.389 a 0.886 clct[np.int64(11), np.int64(8), np.int64(21), np.int64(0)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 143 tr: l 0.249 a 0.919 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 7.846sec(train) 2.147sec(infer)\n",
      "Epoch 143 tst: l 0.390 a 0.886 clct[np.int64(11), np.int64(7), np.int64(22), np.int64(0)]  0.147sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 144 tr: l 0.248 a 0.919 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 8.008sec(train) 2.350sec(infer)\n",
      "Epoch 144 tst: l 0.389 a 0.887 clct[np.int64(11), np.int64(8), np.int64(21), np.int64(0)]  0.161sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 145 tr: l 0.247 a 0.920 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 8.932sec(train) 2.364sec(infer)\n",
      "Epoch 145 tst: l 0.389 a 0.887 clct[np.int64(11), np.int64(7), np.int64(22), np.int64(0)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 146 tr: l 0.246 a 0.920 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 7.861sec(train) 2.146sec(infer)\n",
      "Epoch 146 tst: l 0.389 a 0.886 clct[np.int64(11), np.int64(8), np.int64(21), np.int64(0)]  0.144sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 147 tr: l 0.245 a 0.920 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 7.670sec(train) 2.258sec(infer)\n",
      "Epoch 147 tst: l 0.389 a 0.887 clct[np.int64(11), np.int64(7), np.int64(22), np.int64(0)]  0.158sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 148 tr: l 0.244 a 0.920 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 9.238sec(train) 2.228sec(infer)\n",
      "Epoch 148 tst: l 0.389 a 0.888 clct[np.int64(11), np.int64(7), np.int64(22), np.int64(0)]  0.146sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 149 tr: l 0.243 a 0.921 clct[np.int64(88), np.int64(102), np.int64(209), np.int64(1)]  lr 0.100000 7.634sec(train) 2.148sec(infer)\n",
      "Epoch 149 tst: l 0.389 a 0.887 clct[np.int64(11), np.int64(7), np.int64(22), np.int64(0)]  0.145sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "---train cluster Ended in 0.45 hour (1633.185 sec) \n"
     ]
    }
   ],
   "source": [
    "import ifca as IFCA\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\"---------------------------------IFCA, 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:3\" if torch.cuda.is_available() else \"cpu\")\n",
    "        print(f\"Using device: {device}\")\n",
    "\n",
    "        exp = IFCA.TrainFEMNISTCluster(config, device)\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['train']['loss'] 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",
    "    ifca.append(res_mean)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-16T09:31:48.254117Z",
     "iopub.status.busy": "2025-09-16T09:31:48.253871Z",
     "iopub.status.idle": "2025-09-16T09:31:48.258607Z",
     "shell.execute_reply": "2025-09-16T09:31:48.257990Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Average Test Accuracy (Last Epoch): 0.8817\n"
     ]
    }
   ],
   "source": [
    "r_ifca = {}\n",
    "\n",
    "r_ifca['test_acc'] = []\n",
    "r_ifca['test_acc'].append(ifca[0][1])\n",
    "\n",
    "avg_test_acc = np.mean([acc[-1] for acc in r_ifca['test_acc']])\n",
    "\n",
    "print(f\"Average Test Accuracy (Last Epoch): {avg_test_acc:.4f}\")"
   ]
  }
 ],
 "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": {
     "06079bda584f4f89a5104252a95c9a90": {
      "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
      }
     },
     "07112d1690854e328787acdfb3e551bf": {
      "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": ""
      }
     },
     "08bee8146e634d2ba77a26bc205e8e71": {
      "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
      }
     },
     "0b1725bbe7c244f2951b043a91ac8a0c": {
      "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
      }
     },
     "0e9a111e25084689b9c6b0160e44cd4e": {
      "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_bf32bb7e009e41c09463dd55cc00d885",
       "max": 3,
       "min": 0,
       "orientation": "horizontal",
       "style": "IPY_MODEL_a58df40c6d114fb382d8de958b79d14e",
       "tabbable": null,
       "tooltip": null,
       "value": 3
      }
     },
     "464b0390a7524180b92f675534b8192c": {
      "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
      }
     },
     "4cda6092f259418da9e591cc5c6d70bd": {
      "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_08bee8146e634d2ba77a26bc205e8e71",
       "placeholder": "​",
       "style": "IPY_MODEL_0b1725bbe7c244f2951b043a91ac8a0c",
       "tabbable": null,
       "tooltip": null,
       "value": " 3/3 [00:05&lt;00:00,  5.47s/engine]"
      }
     },
     "5181b9cb1ed14577a2838bd63b325db0": {
      "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
      }
     },
     "5363145f262140c4a45a323baf6563ab": {
      "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_f2ef308f16774099834926e11170f232",
       "max": 3,
       "min": 0,
       "orientation": "horizontal",
       "style": "IPY_MODEL_07112d1690854e328787acdfb3e551bf",
       "tabbable": null,
       "tooltip": null,
       "value": 3
      }
     },
     "6963fdde64e34c2d9947ea291553d41a": {
      "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
      }
     },
     "72868277090a4185907ce4f10b59d181": {
      "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_e54192ae2bb04a6bb45477a116056aab",
        "IPY_MODEL_5363145f262140c4a45a323baf6563ab",
        "IPY_MODEL_cd52befdffb949139dfd53b3bafcc8ee"
       ],
       "layout": "IPY_MODEL_d55d63c64d584f8aae020ed5bcf305ea",
       "tabbable": null,
       "tooltip": null
      }
     },
     "7bf6b228c459460080a0e06949d59a81": {
      "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
      }
     },
     "7e85fa53b2cc44728fc075ebf4e0d505": {
      "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
      }
     },
     "a58df40c6d114fb382d8de958b79d14e": {
      "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": ""
      }
     },
     "bf32bb7e009e41c09463dd55cc00d885": {
      "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
      }
     },
     "cd52befdffb949139dfd53b3bafcc8ee": {
      "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_06079bda584f4f89a5104252a95c9a90",
       "placeholder": "​",
       "style": "IPY_MODEL_7e85fa53b2cc44728fc075ebf4e0d505",
       "tabbable": null,
       "tooltip": null,
       "value": " 3/3 [19:56:59&lt;00:00, 5885.19s/tasks]"
      }
     },
     "d55d63c64d584f8aae020ed5bcf305ea": {
      "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
      }
     },
     "dd26b71b2bc14f699c2f7adbdc23f8bf": {
      "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
      }
     },
     "ddfe01500a4e4b238b9c11db5cbaaf45": {
      "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_e312fda974794893a762cb193b34460f",
        "IPY_MODEL_0e9a111e25084689b9c6b0160e44cd4e",
        "IPY_MODEL_4cda6092f259418da9e591cc5c6d70bd"
       ],
       "layout": "IPY_MODEL_dd26b71b2bc14f699c2f7adbdc23f8bf",
       "tabbable": null,
       "tooltip": null
      }
     },
     "e312fda974794893a762cb193b34460f": {
      "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_464b0390a7524180b92f675534b8192c",
       "placeholder": "​",
       "style": "IPY_MODEL_7bf6b228c459460080a0e06949d59a81",
       "tabbable": null,
       "tooltip": null,
       "value": "100%"
      }
     },
     "e54192ae2bb04a6bb45477a116056aab": {
      "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_6963fdde64e34c2d9947ea291553d41a",
       "placeholder": "​",
       "style": "IPY_MODEL_5181b9cb1ed14577a2838bd63b325db0",
       "tabbable": null,
       "tooltip": null,
       "value": "unknown: 100%"
      }
     },
     "f2ef308f16774099834926e11170f232": {
      "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
      }
     }
    },
    "version_major": 2,
    "version_minor": 0
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
