{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-19T01:49:21.888274Z",
     "iopub.status.busy": "2025-09-19T01:49:21.887779Z",
     "iopub.status.idle": "2025-09-19T01:49:26.471860Z",
     "shell.execute_reply": "2025-09-19T01:49:26.470868Z"
    },
    "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-19T01:49:26.475721Z",
     "iopub.status.busy": "2025-09-19T01:49:26.475380Z",
     "iopub.status.idle": "2025-09-19T01:49:33.363378Z",
     "shell.execute_reply": "2025-09-19T01:49:33.362209Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Starting 3 engines with <class 'ipyparallel.cluster.launcher.LocalEngineSetLauncher'>\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "0c04380779b84f9ea9f58639f8449b1a",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/3 [00:00<?, ?engine/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "rc = ipp.Cluster(n=3).start_and_connect_sync()\n",
    "rc.activate()\n",
    "\n",
    "rc.ids \n",
    "\n",
    "dview = rc[:]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-19T01:49:33.367279Z",
     "iopub.status.busy": "2025-09-19T01:49:33.366835Z",
     "iopub.status.idle": "2025-09-19T01:49:33.372722Z",
     "shell.execute_reply": "2025-09-19T01:49:33.371665Z"
    }
   },
   "outputs": [],
   "source": [
    "learning_rates = [0.1]\n",
    "\n",
    "dfca_gi = []\n",
    "ifca = []\n",
    "dfca_li = []"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-19T01:49:33.376047Z",
     "iopub.status.busy": "2025-09-19T01:49:33.375621Z",
     "iopub.status.idle": "2025-09-19T01:49:33.397288Z",
     "shell.execute_reply": "2025-09-19T01:49:33.396242Z"
    }
   },
   "outputs": [],
   "source": [
    "%%px --targets all\n",
    "\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",
    "dfca_gi = []\n",
    "dfca_li = []\n",
    "ifca = []"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 1000
    },
    "execution": {
     "iopub.execute_input": "2025-09-19T01:49:33.400825Z",
     "iopub.status.busy": "2025-09-19T01:49:33.400414Z",
     "iopub.status.idle": "2025-09-19T01:49:33.412034Z",
     "shell.execute_reply": "2025-09-19T01:49:33.410531Z"
    },
    "id": "T_XDv25r-tqf",
    "outputId": "9c8f4300-c792-4e49-be40-c694fa066e6f"
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<AsyncResult(%px): pending>"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "%%px --target 0 --noblock\n",
    "import dfca as DFCA\n",
    "import json\n",
    "import time\n",
    "import torch\n",
    "import numpy as np\n",
    "\n",
    "\n",
    "with open(\"config.json\", \"r\") as read_file:\n",
    "    config = json.load(read_file)\n",
    "\n",
    "for lr in learning_rates:\n",
    "    config['lr'] = lr\n",
    "    res_final = []\n",
    "\n",
    "    for seed in seeds:\n",
    "        print(f\"---------------------------------DFCA-GI, lr: {lr}, seed: {seed}---------------------------------\")\n",
    "        start_time = time.time()\n",
    "        config['data_seed'] = seed\n",
    "        config['train_seed'] = config['data_seed']\n",
    "\n",
    "        print(\"config:\",config)\n",
    "        device = torch.device(\"cuda:2\" if torch.cuda.is_available() else \"cpu\")\n",
    "        print(f\"Using device: {device}\")\n",
    "\n",
    "        exp = DFCA.TrainEMNISTCluster(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['test']['cl_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",
    "    last_accs = [run[1][-1] * 100 for run in res_final]\n",
    "    res_std = np.std(last_accs)\n",
    "    dfca_gi.append(res_mean)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-19T01:49:33.415426Z",
     "iopub.status.busy": "2025-09-19T01:49:33.415008Z",
     "iopub.status.idle": "2025-09-19T01:49:33.425336Z",
     "shell.execute_reply": "2025-09-19T01:49:33.424432Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<AsyncResult(%px): pending>"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "%%px --target 1 --noblock\n",
    "import dfca as DFCA\n",
    "import json\n",
    "import time\n",
    "import torch\n",
    "import numpy as np\n",
    "\n",
    "\n",
    "with open(\"config.json\", \"r\") as read_file:\n",
    "    config = json.load(read_file)\n",
    "\n",
    "for lr in learning_rates:\n",
    "    config['lr'] = lr\n",
    "    config['local_model_init'] = True\n",
    "    res_final = []\n",
    "\n",
    "    for seed in seeds:\n",
    "        print(f\"---------------------------------DFCA-LI, lr: {lr}, seed: {seed}---------------------------------\")\n",
    "        start_time = time.time()\n",
    "        config['data_seed'] = seed\n",
    "        config['train_seed'] = config['data_seed']\n",
    "\n",
    "        print(\"config:\",config)\n",
    "        device = torch.device(\"cuda:2\" if torch.cuda.is_available() else \"cpu\")\n",
    "        print(f\"Using device: {device}\")\n",
    "\n",
    "        exp = DFCA.TrainEMNISTCluster(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['test']['cl_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",
    "    last_accs = [run[1][-1] * 100 for run in res_final]\n",
    "    res_std = np.std(last_accs)\n",
    "    dfca_li.append(res_mean)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-19T01:49:33.428700Z",
     "iopub.status.busy": "2025-09-19T01:49:33.428293Z",
     "iopub.status.idle": "2025-09-19T01:49:33.439381Z",
     "shell.execute_reply": "2025-09-19T01:49:33.438499Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<AsyncResult(%px): pending>"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "%%px --target 2 --noblock\n",
    "import ifca as IFCA\n",
    "import json\n",
    "import time\n",
    "import torch\n",
    "import numpy as np\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:2\" if torch.cuda.is_available() else \"cpu\")\n",
    "        print(f\"Using device: {device}\")\n",
    "\n",
    "        exp = IFCA.TrainEMNISTCluster(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['test']['cl_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",
    "    last_accs = [run[1][-1] * 100 for run in res_final]\n",
    "    res_std = np.std(last_accs)\n",
    "    ifca.append(res_mean)\n",
    "\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-19T01:49:33.442820Z",
     "iopub.status.busy": "2025-09-19T01:49:33.442410Z",
     "iopub.status.idle": "2025-09-19T12:04:35.656795Z",
     "shell.execute_reply": "2025-09-19T12:04:35.655531Z"
    }
   },
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "6f76821bdd464d9c96016c48dc84e2d5",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "unknown:   0%|          | 0/3 [00:00<?, ?tasks/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "---------------------------------IFCA, lr: 0.1, seed: 1824---------------------------------\n",
      "config: {'m': 200, 'm_test': 40, 'p': 4, 'n': 1500, 'uneven': True, 'local_model_init': False, 'Gp': 0.15, 'graph': 'er', 'agg': 'seq', '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:2\n",
      "Epoch -1 tr: l 3.860 a 0.027 clct[np.int64(76), np.int64(14), np.int64(92), np.int64(18)] cl_acc 0.490  5.857sec\n",
      "Epoch -1 tst: l 3.861 a 0.026 clct[np.int64(10), np.int64(5), np.int64(18), np.int64(7)] cl_acc 0.500  1.229sec\n",
      "Epoch 0 tr: l 3.472 a 0.173 clct[np.int64(51), np.int64(51), np.int64(49), np.int64(49)] cl_acc 0.990  lr 0.100000 19.611sec(train) 7.440sec(infer)\n",
      "Epoch 0 tst: l 3.480 a 0.171 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.384sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 1 tr: l 2.585 a 0.479 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.099500 17.932sec(train) 9.739sec(infer)\n",
      "Epoch 1 tst: l 2.609 a 0.476 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.095sec\n",
      "Epoch 2 tr: l 1.901 a 0.600 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.099003 26.675sec(train) 9.798sec(infer)\n",
      "Epoch 2 tst: l 1.941 a 0.595 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.776sec\n",
      "Epoch 3 tr: l 1.495 a 0.654 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.098507 26.047sec(train) 10.179sec(infer)\n",
      "Epoch 3 tst: l 1.543 a 0.648 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.966sec\n",
      "Epoch 4 tr: l 1.270 a 0.680 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.098015 25.492sec(train) 10.222sec(infer)\n",
      "Epoch 4 tst: l 1.323 a 0.675 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.284sec\n",
      "Epoch 5 tr: l 1.147 a 0.691 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.097525 26.502sec(train) 9.536sec(infer)\n",
      "Epoch 5 tst: l 1.206 a 0.685 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.030sec\n",
      "Epoch 6 tr: l 1.037 a 0.713 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.097037 27.350sec(train) 9.922sec(infer)\n",
      "Epoch 6 tst: l 1.097 a 0.706 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.087sec\n",
      "Epoch 7 tr: l 0.943 a 0.735 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.096552 25.720sec(train) 10.672sec(infer)\n",
      "Epoch 7 tst: l 1.006 a 0.730 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.017sec\n",
      "Epoch 8 tr: l 0.879 a 0.747 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.096069 25.466sec(train) 9.950sec(infer)\n",
      "Epoch 8 tst: l 0.943 a 0.740 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.093sec\n",
      "Epoch 9 tr: l 0.825 a 0.760 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.095589 26.506sec(train) 9.835sec(infer)\n",
      "Epoch 9 tst: l 0.891 a 0.755 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.990sec\n",
      "Epoch 10 tr: l 0.784 a 0.768 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.095111 26.712sec(train) 9.732sec(infer)\n",
      "Epoch 10 tst: l 0.850 a 0.759 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.008sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 11 tr: l 0.747 a 0.777 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.094635 25.777sec(train) 10.715sec(infer)\n",
      "Epoch 11 tst: l 0.816 a 0.771 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.020sec\n",
      "Epoch 12 tr: l 0.717 a 0.783 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.094162 25.596sec(train) 9.753sec(infer)\n",
      "Epoch 12 tst: l 0.787 a 0.774 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.023sec\n",
      "Epoch 13 tr: l 0.691 a 0.790 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.093691 26.554sec(train) 9.933sec(infer)\n",
      "Epoch 13 tst: l 0.763 a 0.783 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.952sec\n",
      "Epoch 14 tr: l 0.668 a 0.794 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.093223 26.311sec(train) 9.899sec(infer)\n",
      "Epoch 14 tst: l 0.742 a 0.784 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.010sec\n",
      "Epoch 15 tr: l 0.650 a 0.800 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.092757 25.760sec(train) 10.093sec(infer)\n",
      "Epoch 15 tst: l 0.725 a 0.792 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.312sec\n",
      "Epoch 16 tr: l 0.633 a 0.802 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.092293 26.191sec(train) 9.724sec(infer)\n",
      "Epoch 16 tst: l 0.710 a 0.792 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.037sec\n",
      "Epoch 17 tr: l 0.617 a 0.807 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.091832 26.477sec(train) 9.925sec(infer)\n",
      "Epoch 17 tst: l 0.695 a 0.798 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.076sec\n",
      "Epoch 18 tr: l 0.602 a 0.810 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.091372 26.188sec(train) 10.420sec(infer)\n",
      "Epoch 18 tst: l 0.681 a 0.799 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.010sec\n",
      "Epoch 19 tr: l 0.587 a 0.815 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.090916 25.889sec(train) 9.982sec(infer)\n",
      "Epoch 19 tst: l 0.668 a 0.804 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.088sec\n",
      "Epoch 20 tr: l 0.576 a 0.816 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.090461 26.384sec(train) 10.074sec(infer)\n",
      "Epoch 20 tst: l 0.657 a 0.806 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.015sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 21 tr: l 0.564 a 0.820 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.090009 26.459sec(train) 9.825sec(infer)\n",
      "Epoch 21 tst: l 0.648 a 0.810 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.081sec\n",
      "Epoch 22 tr: l 0.554 a 0.822 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.089559 26.282sec(train) 10.584sec(infer)\n",
      "Epoch 22 tst: l 0.638 a 0.810 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.032sec\n",
      "Epoch 23 tr: l 0.544 a 0.824 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.089111 26.100sec(train) 9.835sec(infer)\n",
      "Epoch 23 tst: l 0.630 a 0.815 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.060sec\n",
      "Epoch 24 tr: l 0.534 a 0.827 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.088665 26.509sec(train) 10.201sec(infer)\n",
      "Epoch 24 tst: l 0.620 a 0.815 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.025sec\n",
      "Epoch 25 tr: l 0.525 a 0.829 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.088222 26.359sec(train) 9.891sec(infer)\n",
      "Epoch 25 tst: l 0.614 a 0.818 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.025sec\n",
      "Epoch 26 tr: l 0.517 a 0.831 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.087781 26.066sec(train) 10.316sec(infer)\n",
      "Epoch 26 tst: l 0.606 a 0.820 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.324sec\n",
      "Epoch 27 tr: l 0.510 a 0.833 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.087342 26.260sec(train) 9.937sec(infer)\n",
      "Epoch 27 tst: l 0.601 a 0.821 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.012sec\n",
      "Epoch 28 tr: l 0.503 a 0.835 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.086905 26.459sec(train) 10.124sec(infer)\n",
      "Epoch 28 tst: l 0.594 a 0.823 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.093sec\n",
      "Epoch 29 tr: l 0.497 a 0.836 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.086471 26.051sec(train) 10.300sec(infer)\n",
      "Epoch 29 tst: l 0.589 a 0.824 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.981sec\n",
      "Epoch 30 tr: l 0.490 a 0.839 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.086038 26.061sec(train) 10.041sec(infer)\n",
      "Epoch 30 tst: l 0.582 a 0.826 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.113sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 31 tr: l 0.485 a 0.839 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.085608 26.400sec(train) 10.035sec(infer)\n",
      "Epoch 31 tst: l 0.579 a 0.826 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.001sec\n",
      "Epoch 32 tr: l 0.480 a 0.841 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.085180 26.574sec(train) 9.915sec(infer)\n",
      "Epoch 32 tst: l 0.574 a 0.827 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.110sec\n",
      "Epoch 33 tr: l 0.475 a 0.842 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.084754 26.139sec(train) 10.380sec(infer)\n",
      "Epoch 33 tst: l 0.572 a 0.828 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.983sec\n",
      "Epoch 34 tr: l 0.468 a 0.844 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.084331 26.095sec(train) 9.839sec(infer)\n",
      "Epoch 34 tst: l 0.564 a 0.830 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.116sec\n",
      "Epoch 35 tr: l 0.464 a 0.845 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.083909 26.617sec(train) 10.285sec(infer)\n",
      "Epoch 35 tst: l 0.563 a 0.830 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.013sec\n",
      "Epoch 36 tr: l 0.460 a 0.846 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.083489 26.335sec(train) 9.737sec(infer)\n",
      "Epoch 36 tst: l 0.558 a 0.831 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.004sec\n",
      "Epoch 37 tr: l 0.456 a 0.847 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.083072 26.317sec(train) 10.562sec(infer)\n",
      "Epoch 37 tst: l 0.556 a 0.831 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.045sec\n",
      "Epoch 38 tr: l 0.451 a 0.848 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.082657 26.006sec(train) 9.878sec(infer)\n",
      "Epoch 38 tst: l 0.550 a 0.832 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.998sec\n",
      "Epoch 39 tr: l 0.446 a 0.850 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.082243 26.374sec(train) 10.134sec(infer)\n",
      "Epoch 39 tst: l 0.548 a 0.834 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.146sec\n",
      "Epoch 40 tr: l 0.442 a 0.850 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.081832 26.174sec(train) 10.078sec(infer)\n",
      "Epoch 40 tst: l 0.543 a 0.834 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.974sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 41 tr: l 0.439 a 0.852 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.081423 26.079sec(train) 10.165sec(infer)\n",
      "Epoch 41 tst: l 0.544 a 0.835 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.167sec\n",
      "Epoch 42 tr: l 0.436 a 0.852 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.081016 26.554sec(train) 9.890sec(infer)\n",
      "Epoch 42 tst: l 0.538 a 0.835 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.020sec\n",
      "Epoch 43 tr: l 0.431 a 0.854 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.080611 26.460sec(train) 9.987sec(infer)\n",
      "Epoch 43 tst: l 0.536 a 0.837 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.104sec\n",
      "Epoch 44 tr: l 0.427 a 0.855 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.080208 26.160sec(train) 10.401sec(infer)\n",
      "Epoch 44 tst: l 0.531 a 0.838 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.003sec\n",
      "Epoch 45 tr: l 0.424 a 0.856 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.079807 26.128sec(train) 9.952sec(infer)\n",
      "Epoch 45 tst: l 0.531 a 0.838 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.095sec\n",
      "Epoch 46 tr: l 0.421 a 0.856 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.079408 26.673sec(train) 10.144sec(infer)\n",
      "Epoch 46 tst: l 0.527 a 0.840 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.011sec\n",
      "Epoch 47 tr: l 0.418 a 0.858 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.079010 26.390sec(train) 9.823sec(infer)\n",
      "Epoch 47 tst: l 0.526 a 0.839 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.058sec\n",
      "Epoch 48 tr: l 0.415 a 0.858 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.078615 26.160sec(train) 10.620sec(infer)\n",
      "Epoch 48 tst: l 0.522 a 0.840 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.056sec\n",
      "Epoch 49 tr: l 0.412 a 0.859 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.078222 25.827sec(train) 9.763sec(infer)\n",
      "Epoch 49 tst: l 0.521 a 0.840 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.023sec\n",
      "Epoch 50 tr: l 0.408 a 0.860 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.077831 26.783sec(train) 10.102sec(infer)\n",
      "Epoch 50 tst: l 0.516 a 0.842 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.086sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 51 tr: l 0.405 a 0.861 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.077442 26.378sec(train) 9.908sec(infer)\n",
      "Epoch 51 tst: l 0.516 a 0.841 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.994sec\n",
      "Epoch 52 tr: l 0.402 a 0.862 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.077055 25.981sec(train) 10.268sec(infer)\n",
      "Epoch 52 tst: l 0.512 a 0.843 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.330sec\n",
      "Epoch 53 tr: l 0.399 a 0.862 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.076670 26.177sec(train) 9.829sec(infer)\n",
      "Epoch 53 tst: l 0.512 a 0.842 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.044sec\n",
      "Epoch 54 tr: l 0.397 a 0.863 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.076286 26.564sec(train) 10.037sec(infer)\n",
      "Epoch 54 tst: l 0.508 a 0.844 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.112sec\n",
      "Epoch 55 tr: l 0.394 a 0.864 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.075905 26.237sec(train) 10.362sec(infer)\n",
      "Epoch 55 tst: l 0.508 a 0.843 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.032sec\n",
      "Epoch 56 tr: l 0.392 a 0.864 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.075525 26.021sec(train) 10.032sec(infer)\n",
      "Epoch 56 tst: l 0.504 a 0.845 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.131sec\n",
      "Epoch 57 tr: l 0.389 a 0.865 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.075148 26.371sec(train) 10.000sec(infer)\n",
      "Epoch 57 tst: l 0.504 a 0.845 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.009sec\n",
      "Epoch 58 tr: l 0.387 a 0.866 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.074772 26.491sec(train) 9.867sec(infer)\n",
      "Epoch 58 tst: l 0.502 a 0.845 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.103sec\n",
      "Epoch 59 tr: l 0.385 a 0.866 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.074398 26.067sec(train) 10.537sec(infer)\n",
      "Epoch 59 tst: l 0.501 a 0.845 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.952sec\n",
      "Epoch 60 tr: l 0.383 a 0.867 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.074026 26.283sec(train) 9.856sec(infer)\n",
      "Epoch 60 tst: l 0.499 a 0.846 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.091sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 61 tr: l 0.381 a 0.868 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.073656 26.421sec(train) 10.209sec(infer)\n",
      "Epoch 61 tst: l 0.498 a 0.846 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.008sec\n",
      "Epoch 62 tr: l 0.379 a 0.868 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.073288 26.415sec(train) 9.845sec(infer)\n",
      "Epoch 62 tst: l 0.496 a 0.847 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.007sec\n",
      "Epoch 63 tr: l 0.376 a 0.869 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.072921 26.036sec(train) 10.446sec(infer)\n",
      "Epoch 63 tst: l 0.495 a 0.847 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.227sec\n",
      "Epoch 64 tr: l 0.374 a 0.869 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.072557 26.433sec(train) 9.839sec(infer)\n",
      "Epoch 64 tst: l 0.493 a 0.848 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.991sec\n",
      "Epoch 65 tr: l 0.372 a 0.870 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.072194 26.443sec(train) 10.167sec(infer)\n",
      "Epoch 65 tst: l 0.491 a 0.848 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.075sec\n",
      "Epoch 66 tr: l 0.370 a 0.871 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.071833 26.233sec(train) 10.156sec(infer)\n",
      "Epoch 66 tst: l 0.490 a 0.848 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.989sec\n",
      "Epoch 67 tr: l 0.368 a 0.871 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.071474 26.064sec(train) 10.130sec(infer)\n",
      "Epoch 67 tst: l 0.488 a 0.848 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.085sec\n",
      "Epoch 68 tr: l 0.366 a 0.872 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.071116 26.714sec(train) 9.984sec(infer)\n",
      "Epoch 68 tst: l 0.487 a 0.849 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.006sec\n",
      "Epoch 69 tr: l 0.364 a 0.872 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.070761 26.539sec(train) 9.937sec(infer)\n",
      "Epoch 69 tst: l 0.486 a 0.849 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.106sec\n",
      "Epoch 70 tr: l 0.362 a 0.873 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.070407 26.125sec(train) 10.471sec(infer)\n",
      "Epoch 70 tst: l 0.485 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.967sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 71 tr: l 0.360 a 0.873 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.070055 26.033sec(train) 9.937sec(infer)\n",
      "Epoch 71 tst: l 0.483 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.076sec\n",
      "Epoch 72 tr: l 0.359 a 0.874 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.069705 26.372sec(train) 10.239sec(infer)\n",
      "Epoch 72 tst: l 0.483 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.956sec\n",
      "Epoch 73 tr: l 0.357 a 0.874 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.069356 26.646sec(train) 9.819sec(infer)\n",
      "Epoch 73 tst: l 0.481 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.040sec\n",
      "Epoch 74 tr: l 0.355 a 0.875 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.069009 25.972sec(train) 10.640sec(infer)\n",
      "Epoch 74 tst: l 0.481 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.041sec\n",
      "Epoch 75 tr: l 0.353 a 0.876 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.068664 26.069sec(train) 9.800sec(infer)\n",
      "Epoch 75 tst: l 0.479 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.993sec\n",
      "Epoch 76 tr: l 0.352 a 0.876 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.068321 26.638sec(train) 10.166sec(infer)\n",
      "Epoch 76 tst: l 0.479 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.928sec\n",
      "Epoch 77 tr: l 0.350 a 0.876 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.067979 26.502sec(train) 10.066sec(infer)\n",
      "Epoch 77 tst: l 0.476 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.966sec\n",
      "Epoch 78 tr: l 0.349 a 0.877 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.067639 25.907sec(train) 10.159sec(infer)\n",
      "Epoch 78 tst: l 0.477 a 0.852 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.252sec\n",
      "Epoch 79 tr: l 0.347 a 0.877 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.067301 26.236sec(train) 9.790sec(infer)\n",
      "Epoch 79 tst: l 0.475 a 0.852 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.012sec\n",
      "Epoch 80 tr: l 0.346 a 0.877 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.066965 26.603sec(train) 9.908sec(infer)\n",
      "Epoch 80 tst: l 0.475 a 0.852 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.109sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 81 tr: l 0.344 a 0.878 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.066630 25.912sec(train) 10.406sec(infer)\n",
      "Epoch 81 tst: l 0.473 a 0.852 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.006sec\n",
      "Epoch 82 tr: l 0.343 a 0.878 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.066297 26.023sec(train) 9.876sec(infer)\n",
      "Epoch 82 tst: l 0.474 a 0.852 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.115sec\n",
      "Epoch 83 tr: l 0.341 a 0.878 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.065965 26.236sec(train) 9.957sec(infer)\n",
      "Epoch 83 tst: l 0.471 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.923sec\n",
      "Epoch 84 tr: l 0.340 a 0.879 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.065635 26.427sec(train) 9.824sec(infer)\n",
      "Epoch 84 tst: l 0.472 a 0.852 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.007sec\n",
      "Epoch 85 tr: l 0.339 a 0.879 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.065307 26.030sec(train) 10.614sec(infer)\n",
      "Epoch 85 tst: l 0.470 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.021sec\n",
      "Epoch 86 tr: l 0.338 a 0.879 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064981 26.212sec(train) 9.795sec(infer)\n",
      "Epoch 86 tst: l 0.471 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.013sec\n",
      "Epoch 87 tr: l 0.336 a 0.880 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064656 26.862sec(train) 10.150sec(infer)\n",
      "Epoch 87 tst: l 0.468 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.096sec\n",
      "Epoch 88 tr: l 0.335 a 0.880 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064333 26.453sec(train) 10.000sec(infer)\n",
      "Epoch 88 tst: l 0.469 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.034sec\n",
      "Epoch 89 tr: l 0.333 a 0.881 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064011 25.855sec(train) 10.190sec(infer)\n",
      "Epoch 89 tst: l 0.467 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.241sec\n",
      "Epoch 90 tr: l 0.332 a 0.881 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.063691 26.538sec(train) 9.908sec(infer)\n",
      "Epoch 90 tst: l 0.467 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.000sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 91 tr: l 0.330 a 0.882 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.063372 26.586sec(train) 10.039sec(infer)\n",
      "Epoch 91 tst: l 0.466 a 0.855 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.139sec\n",
      "Epoch 92 tr: l 0.329 a 0.882 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.063056 26.185sec(train) 10.304sec(infer)\n",
      "Epoch 92 tst: l 0.466 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.030sec\n",
      "Epoch 93 tr: l 0.328 a 0.882 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.062740 26.264sec(train) 9.987sec(infer)\n",
      "Epoch 93 tst: l 0.464 a 0.855 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.110sec\n",
      "Epoch 94 tr: l 0.327 a 0.882 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.062427 26.566sec(train) 10.069sec(infer)\n",
      "Epoch 94 tst: l 0.464 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.009sec\n",
      "Epoch 95 tr: l 0.326 a 0.883 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.062114 26.916sec(train) 9.840sec(infer)\n",
      "Epoch 95 tst: l 0.463 a 0.855 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.059sec\n",
      "Epoch 96 tr: l 0.325 a 0.883 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.061804 26.324sec(train) 10.647sec(infer)\n",
      "Epoch 96 tst: l 0.463 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.999sec\n",
      "Epoch 97 tr: l 0.323 a 0.883 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.061495 26.079sec(train) 9.833sec(infer)\n",
      "Epoch 97 tst: l 0.462 a 0.855 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.055sec\n",
      "Epoch 98 tr: l 0.322 a 0.884 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.061187 26.919sec(train) 10.140sec(infer)\n",
      "Epoch 98 tst: l 0.462 a 0.855 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.097sec\n",
      "Epoch 99 tr: l 0.321 a 0.884 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.060881 26.454sec(train) 9.896sec(infer)\n",
      "Epoch 99 tst: l 0.461 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.023sec\n",
      "Epoch 100 tr: l 0.320 a 0.884 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.006058 26.234sec(train) 10.277sec(infer)\n",
      "Epoch 100 tst: l 0.460 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.323sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 101 tr: l 0.320 a 0.884 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.006027 26.230sec(train) 9.839sec(infer)\n",
      "Epoch 101 tst: l 0.460 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.041sec\n",
      "Epoch 102 tr: l 0.320 a 0.884 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005997 26.508sec(train) 10.081sec(infer)\n",
      "Epoch 102 tst: l 0.460 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.145sec\n",
      "Epoch 103 tr: l 0.320 a 0.885 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005967 26.376sec(train) 10.454sec(infer)\n",
      "Epoch 103 tst: l 0.459 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.005sec\n",
      "Epoch 104 tr: l 0.319 a 0.885 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005937 26.065sec(train) 10.077sec(infer)\n",
      "Epoch 104 tst: l 0.459 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.140sec\n",
      "Epoch 105 tr: l 0.319 a 0.885 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005908 26.848sec(train) 10.015sec(infer)\n",
      "Epoch 105 tst: l 0.459 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.025sec\n",
      "Epoch 106 tr: l 0.319 a 0.885 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005878 26.680sec(train) 9.869sec(infer)\n",
      "Epoch 106 tst: l 0.459 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.115sec\n",
      "Epoch 107 tr: l 0.319 a 0.885 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005849 26.312sec(train) 10.569sec(infer)\n",
      "Epoch 107 tst: l 0.459 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.991sec\n",
      "Epoch 108 tr: l 0.319 a 0.885 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005820 26.217sec(train) 9.853sec(infer)\n",
      "Epoch 108 tst: l 0.459 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.125sec\n",
      "Epoch 109 tr: l 0.319 a 0.885 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005790 26.681sec(train) 10.238sec(infer)\n",
      "Epoch 109 tst: l 0.459 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.003sec\n",
      "Epoch 110 tr: l 0.318 a 0.885 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005762 26.792sec(train) 9.827sec(infer)\n",
      "Epoch 110 tst: l 0.459 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.015sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 111 tr: l 0.318 a 0.885 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005733 26.190sec(train) 10.594sec(infer)\n",
      "Epoch 111 tst: l 0.459 a 0.857 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.106sec\n",
      "Epoch 112 tr: l 0.318 a 0.885 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005704 26.198sec(train) 9.855sec(infer)\n",
      "Epoch 112 tst: l 0.459 a 0.857 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.975sec\n",
      "Epoch 113 tr: l 0.318 a 0.885 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005676 26.455sec(train) 10.171sec(infer)\n",
      "Epoch 113 tst: l 0.458 a 0.857 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.086sec\n",
      "Epoch 114 tr: l 0.318 a 0.885 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005647 26.160sec(train) 10.124sec(infer)\n",
      "Epoch 114 tst: l 0.458 a 0.857 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.000sec\n",
      "Epoch 115 tr: l 0.318 a 0.885 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005619 26.405sec(train) 10.173sec(infer)\n",
      "Epoch 115 tst: l 0.458 a 0.857 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.189sec\n",
      "Epoch 116 tr: l 0.318 a 0.885 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005591 26.577sec(train) 10.072sec(infer)\n",
      "Epoch 116 tst: l 0.458 a 0.857 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.020sec\n",
      "Epoch 117 tr: l 0.317 a 0.885 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005563 26.505sec(train) 9.995sec(infer)\n",
      "Epoch 117 tst: l 0.458 a 0.857 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.095sec\n",
      "Epoch 118 tr: l 0.317 a 0.885 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005535 26.093sec(train) 10.354sec(infer)\n",
      "Epoch 118 tst: l 0.458 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.019sec\n",
      "Epoch 119 tr: l 0.317 a 0.885 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005507 26.174sec(train) 9.916sec(infer)\n",
      "Epoch 119 tst: l 0.458 a 0.857 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.091sec\n",
      "Epoch 120 tr: l 0.317 a 0.885 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005480 26.725sec(train) 10.269sec(infer)\n",
      "Epoch 120 tst: l 0.458 a 0.857 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.003sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 121 tr: l 0.317 a 0.885 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005452 26.453sec(train) 10.061sec(infer)\n",
      "Epoch 121 tst: l 0.458 a 0.857 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.113sec\n",
      "Epoch 122 tr: l 0.317 a 0.885 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005425 26.310sec(train) 10.638sec(infer)\n",
      "Epoch 122 tst: l 0.458 a 0.857 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.063sec\n",
      "Epoch 123 tr: l 0.317 a 0.885 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005398 26.188sec(train) 9.826sec(infer)\n",
      "Epoch 123 tst: l 0.458 a 0.857 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.046sec\n",
      "Epoch 124 tr: l 0.317 a 0.885 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005371 26.730sec(train) 10.075sec(infer)\n",
      "Epoch 124 tst: l 0.458 a 0.857 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.090sec\n",
      "Epoch 125 tr: l 0.316 a 0.885 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005344 26.612sec(train) 9.911sec(infer)\n",
      "Epoch 125 tst: l 0.458 a 0.857 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.010sec\n",
      "Epoch 126 tr: l 0.316 a 0.885 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005318 26.344sec(train) 10.332sec(infer)\n",
      "Epoch 126 tst: l 0.458 a 0.857 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.339sec\n",
      "Epoch 127 tr: l 0.316 a 0.885 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005291 26.226sec(train) 9.939sec(infer)\n",
      "Epoch 127 tst: l 0.457 a 0.857 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.012sec\n",
      "Epoch 128 tr: l 0.316 a 0.885 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005264 26.378sec(train) 10.084sec(infer)\n",
      "Epoch 128 tst: l 0.457 a 0.857 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.099sec\n",
      "Epoch 129 tr: l 0.316 a 0.886 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005238 26.606sec(train) 10.326sec(infer)\n",
      "Epoch 129 tst: l 0.457 a 0.857 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.985sec\n",
      "Epoch 130 tr: l 0.316 a 0.886 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005212 26.253sec(train) 10.051sec(infer)\n",
      "Epoch 130 tst: l 0.457 a 0.857 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.123sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 131 tr: l 0.316 a 0.886 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005186 26.487sec(train) 10.101sec(infer)\n",
      "Epoch 131 tst: l 0.457 a 0.857 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.997sec\n",
      "Epoch 132 tr: l 0.316 a 0.886 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005160 26.603sec(train) 9.987sec(infer)\n",
      "Epoch 132 tst: l 0.457 a 0.857 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.126sec\n",
      "Epoch 133 tr: l 0.315 a 0.886 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005134 26.410sec(train) 10.491sec(infer)\n",
      "Epoch 133 tst: l 0.457 a 0.857 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.993sec\n",
      "Epoch 134 tr: l 0.315 a 0.886 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005108 26.546sec(train) 9.928sec(infer)\n",
      "Epoch 134 tst: l 0.457 a 0.857 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.119sec\n",
      "Epoch 135 tr: l 0.315 a 0.886 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005083 26.538sec(train) 10.247sec(infer)\n",
      "Epoch 135 tst: l 0.457 a 0.857 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.982sec\n",
      "Epoch 136 tr: l 0.315 a 0.886 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005058 26.702sec(train) 9.872sec(infer)\n",
      "Epoch 136 tst: l 0.457 a 0.857 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.990sec\n",
      "Epoch 137 tr: l 0.315 a 0.886 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005032 26.228sec(train) 10.766sec(infer)\n",
      "Epoch 137 tst: l 0.457 a 0.857 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.027sec\n",
      "Epoch 138 tr: l 0.315 a 0.886 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005007 26.055sec(train) 9.851sec(infer)\n",
      "Epoch 138 tst: l 0.457 a 0.857 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.009sec\n",
      "Epoch 139 tr: l 0.315 a 0.886 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004982 26.805sec(train) 10.151sec(infer)\n",
      "Epoch 139 tst: l 0.457 a 0.857 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.013sec\n",
      "Epoch 140 tr: l 0.315 a 0.886 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004957 26.345sec(train) 10.134sec(infer)\n",
      "Epoch 140 tst: l 0.457 a 0.857 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.001sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 141 tr: l 0.315 a 0.886 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004932 26.289sec(train) 10.224sec(infer)\n",
      "Epoch 141 tst: l 0.457 a 0.857 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.226sec\n",
      "Epoch 142 tr: l 0.314 a 0.886 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004908 26.374sec(train) 9.982sec(infer)\n",
      "Epoch 142 tst: l 0.457 a 0.857 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.992sec\n",
      "Epoch 143 tr: l 0.314 a 0.886 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004883 26.607sec(train) 10.014sec(infer)\n",
      "Epoch 143 tst: l 0.457 a 0.857 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.084sec\n",
      "Epoch 144 tr: l 0.314 a 0.886 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004859 26.556sec(train) 10.418sec(infer)\n",
      "Epoch 144 tst: l 0.456 a 0.857 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.007sec\n",
      "Epoch 145 tr: l 0.314 a 0.886 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004834 26.173sec(train) 10.039sec(infer)\n",
      "Epoch 145 tst: l 0.456 a 0.857 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.055sec\n",
      "Epoch 146 tr: l 0.314 a 0.886 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004810 26.535sec(train) 10.175sec(infer)\n",
      "Epoch 146 tst: l 0.456 a 0.857 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.975sec\n",
      "Epoch 147 tr: l 0.314 a 0.886 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004786 26.432sec(train) 9.839sec(infer)\n",
      "Epoch 147 tst: l 0.456 a 0.857 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.087sec\n",
      "Epoch 148 tr: l 0.314 a 0.886 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004762 26.265sec(train) 10.594sec(infer)\n",
      "Epoch 148 tst: l 0.456 a 0.857 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.058sec\n",
      "Epoch 149 tr: l 0.314 a 0.886 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004738 26.333sec(train) 9.785sec(infer)\n",
      "Epoch 149 tst: l 0.456 a 0.857 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.107sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "---train cluster Ended in 1.60 hour (5762.722 sec) \n",
      "---------------------------------IFCA, lr: 0.1, seed: 409---------------------------------\n",
      "config: {'m': 200, 'm_test': 40, 'p': 4, 'n': 1500, 'uneven': True, 'local_model_init': False, 'Gp': 0.15, 'graph': 'er', 'agg': 'seq', '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:2\n",
      "Epoch -1 tr: l 3.870 a 0.019 clct[np.int64(79), np.int64(8), np.int64(8), np.int64(105)] cl_acc 0.480  10.564sec\n",
      "Epoch -1 tst: l 3.870 a 0.019 clct[np.int64(13), np.int64(2), np.int64(1), np.int64(24)] cl_acc 0.525  1.946sec\n",
      "Epoch 0 tr: l 3.390 a 0.192 clct[np.int64(99), np.int64(3), np.int64(50), np.int64(48)] cl_acc 0.745  lr 0.100000 26.146sec(train) 9.789sec(infer)\n",
      "Epoch 0 tst: l 3.410 a 0.190 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  2.034sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 1 tr: l 2.639 a 0.400 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.099500 26.551sec(train) 9.962sec(infer)\n",
      "Epoch 1 tst: l 2.665 a 0.398 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  2.021sec\n",
      "Epoch 2 tr: l 2.115 a 0.498 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.099003 26.391sec(train) 9.798sec(infer)\n",
      "Epoch 2 tst: l 2.143 a 0.495 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.961sec\n",
      "Epoch 3 tr: l 1.791 a 0.552 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.098507 26.140sec(train) 10.100sec(infer)\n",
      "Epoch 3 tst: l 1.821 a 0.547 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  2.261sec\n",
      "Epoch 4 tr: l 1.640 a 0.558 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.098015 26.238sec(train) 9.699sec(infer)\n",
      "Epoch 4 tst: l 1.673 a 0.552 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.960sec\n",
      "Epoch 5 tr: l 1.480 a 0.590 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.097525 26.456sec(train) 9.891sec(infer)\n",
      "Epoch 5 tst: l 1.517 a 0.585 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  2.051sec\n",
      "Epoch 6 tr: l 1.359 a 0.624 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.097037 26.177sec(train) 10.289sec(infer)\n",
      "Epoch 6 tst: l 1.394 a 0.616 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.985sec\n",
      "Epoch 7 tr: l 1.275 a 0.633 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.096552 25.958sec(train) 9.884sec(infer)\n",
      "Epoch 7 tst: l 1.316 a 0.627 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  2.024sec\n",
      "Epoch 8 tr: l 1.192 a 0.659 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.096069 26.713sec(train) 10.059sec(infer)\n",
      "Epoch 8 tst: l 1.232 a 0.651 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.893sec\n",
      "Epoch 9 tr: l 1.133 a 0.670 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.095589 26.506sec(train) 9.798sec(infer)\n",
      "Epoch 9 tst: l 1.175 a 0.663 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.988sec\n",
      "Epoch 10 tr: l 1.085 a 0.679 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.095111 26.254sec(train) 10.644sec(infer)\n",
      "Epoch 10 tst: l 1.129 a 0.672 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.955sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 11 tr: l 1.048 a 0.689 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.094635 26.251sec(train) 9.885sec(infer)\n",
      "Epoch 11 tst: l 1.093 a 0.680 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.949sec\n",
      "Epoch 12 tr: l 1.013 a 0.692 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.094162 27.020sec(train) 10.061sec(infer)\n",
      "Epoch 12 tst: l 1.059 a 0.685 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  2.038sec\n",
      "Epoch 13 tr: l 0.965 a 0.711 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.093691 26.446sec(train) 9.865sec(infer)\n",
      "Epoch 13 tst: l 1.013 a 0.702 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.946sec\n",
      "Epoch 14 tr: l 0.942 a 0.712 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.093223 26.245sec(train) 10.173sec(infer)\n",
      "Epoch 14 tst: l 0.991 a 0.703 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  2.286sec\n",
      "Epoch 15 tr: l 0.916 a 0.721 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.092757 26.371sec(train) 9.654sec(infer)\n",
      "Epoch 15 tst: l 0.967 a 0.712 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.983sec\n",
      "Epoch 16 tr: l 0.896 a 0.723 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.092293 26.866sec(train) 9.910sec(infer)\n",
      "Epoch 16 tst: l 0.947 a 0.714 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  2.037sec\n",
      "Epoch 17 tr: l 0.875 a 0.730 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.091832 26.020sec(train) 10.292sec(infer)\n",
      "Epoch 17 tst: l 0.927 a 0.722 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.935sec\n",
      "Epoch 18 tr: l 0.870 a 0.729 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.091372 26.007sec(train) 9.846sec(infer)\n",
      "Epoch 18 tst: l 0.924 a 0.719 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  2.056sec\n",
      "Epoch 19 tr: l 0.844 a 0.737 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.090916 26.478sec(train) 10.031sec(infer)\n",
      "Epoch 19 tst: l 0.897 a 0.729 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.924sec\n",
      "Epoch 20 tr: l 0.824 a 0.742 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.090461 26.693sec(train) 9.733sec(infer)\n",
      "Epoch 20 tst: l 0.881 a 0.731 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.982sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 21 tr: l 0.807 a 0.747 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.090009 26.025sec(train) 10.536sec(infer)\n",
      "Epoch 21 tst: l 0.863 a 0.739 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.965sec\n",
      "Epoch 22 tr: l 0.801 a 0.747 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.089559 25.906sec(train) 9.718sec(infer)\n",
      "Epoch 22 tst: l 0.859 a 0.738 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.916sec\n",
      "Epoch 23 tr: l 0.789 a 0.749 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.089111 26.783sec(train) 10.159sec(infer)\n",
      "Epoch 23 tst: l 0.846 a 0.742 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.969sec\n",
      "Epoch 24 tr: l 0.779 a 0.753 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.088665 26.408sec(train) 10.024sec(infer)\n",
      "Epoch 24 tst: l 0.839 a 0.744 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.951sec\n",
      "Epoch 25 tr: l 0.764 a 0.756 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.088222 26.418sec(train) 10.143sec(infer)\n",
      "Epoch 25 tst: l 0.823 a 0.749 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  2.206sec\n",
      "Epoch 26 tr: l 0.755 a 0.759 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.087781 26.464sec(train) 9.927sec(infer)\n",
      "Epoch 26 tst: l 0.817 a 0.749 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.965sec\n",
      "Epoch 27 tr: l 0.744 a 0.762 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.087342 26.595sec(train) 9.943sec(infer)\n",
      "Epoch 27 tst: l 0.805 a 0.755 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  2.024sec\n",
      "Epoch 28 tr: l 0.737 a 0.763 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.086905 26.314sec(train) 10.411sec(infer)\n",
      "Epoch 28 tst: l 0.800 a 0.754 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.932sec\n",
      "Epoch 29 tr: l 0.730 a 0.766 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.086471 26.417sec(train) 9.863sec(infer)\n",
      "Epoch 29 tst: l 0.793 a 0.758 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  2.044sec\n",
      "Epoch 30 tr: l 0.724 a 0.766 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.086038 26.982sec(train) 10.171sec(infer)\n",
      "Epoch 30 tst: l 0.788 a 0.755 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.933sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 31 tr: l 0.720 a 0.768 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.085608 26.630sec(train) 9.793sec(infer)\n",
      "Epoch 31 tst: l 0.785 a 0.757 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  2.009sec\n",
      "Epoch 32 tr: l 0.709 a 0.769 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.085180 26.410sec(train) 10.564sec(infer)\n",
      "Epoch 32 tst: l 0.774 a 0.759 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  2.026sec\n",
      "Epoch 33 tr: l 0.707 a 0.770 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.084754 26.201sec(train) 9.815sec(infer)\n",
      "Epoch 33 tst: l 0.774 a 0.760 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.963sec\n",
      "Epoch 34 tr: l 0.700 a 0.770 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.084331 26.464sec(train) 10.239sec(infer)\n",
      "Epoch 34 tst: l 0.768 a 0.760 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  2.019sec\n",
      "Epoch 35 tr: l 0.699 a 0.771 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.083909 26.706sec(train) 9.898sec(infer)\n",
      "Epoch 35 tst: l 0.767 a 0.760 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.928sec\n",
      "Epoch 36 tr: l 0.692 a 0.772 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.083489 26.243sec(train) 10.118sec(infer)\n",
      "Epoch 36 tst: l 0.761 a 0.761 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  2.213sec\n",
      "Epoch 37 tr: l 0.692 a 0.772 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.083072 26.462sec(train) 9.860sec(infer)\n",
      "Epoch 37 tst: l 0.762 a 0.760 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.968sec\n",
      "Epoch 38 tr: l 0.688 a 0.771 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.082657 26.695sec(train) 9.885sec(infer)\n",
      "Epoch 38 tst: l 0.760 a 0.760 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  2.048sec\n",
      "Epoch 39 tr: l 0.689 a 0.772 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.082243 26.528sec(train) 10.360sec(infer)\n",
      "Epoch 39 tst: l 0.759 a 0.760 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.966sec\n",
      "Epoch 40 tr: l 0.674 a 0.776 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.081832 26.134sec(train) 9.884sec(infer)\n",
      "Epoch 40 tst: l 0.747 a 0.764 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  2.025sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 41 tr: l 0.671 a 0.778 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.081423 26.552sec(train) 10.136sec(infer)\n",
      "Epoch 41 tst: l 0.743 a 0.765 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.934sec\n",
      "Epoch 42 tr: l 0.660 a 0.781 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.081016 26.613sec(train) 9.811sec(infer)\n",
      "Epoch 42 tst: l 0.734 a 0.769 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.966sec\n",
      "Epoch 43 tr: l 0.659 a 0.782 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.080611 26.066sec(train) 10.642sec(infer)\n",
      "Epoch 43 tst: l 0.732 a 0.769 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  2.013sec\n",
      "Epoch 44 tr: l 0.650 a 0.784 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.080208 26.401sec(train) 9.789sec(infer)\n",
      "Epoch 44 tst: l 0.725 a 0.771 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.944sec\n",
      "Epoch 45 tr: l 0.650 a 0.783 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.079807 26.687sec(train) 10.168sec(infer)\n",
      "Epoch 45 tst: l 0.725 a 0.771 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.909sec\n",
      "Epoch 46 tr: l 0.648 a 0.784 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.079408 26.473sec(train) 10.119sec(infer)\n",
      "Epoch 46 tst: l 0.724 a 0.770 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.911sec\n",
      "Epoch 47 tr: l 0.647 a 0.784 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.079010 25.962sec(train) 10.159sec(infer)\n",
      "Epoch 47 tst: l 0.724 a 0.771 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  2.060sec\n",
      "Epoch 48 tr: l 0.640 a 0.786 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.078615 26.490sec(train) 9.875sec(infer)\n",
      "Epoch 48 tst: l 0.717 a 0.771 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.936sec\n",
      "Epoch 49 tr: l 0.634 a 0.788 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.078222 26.772sec(train) 9.893sec(infer)\n",
      "Epoch 49 tst: l 0.713 a 0.774 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  2.034sec\n",
      "Epoch 50 tr: l 0.630 a 0.789 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.077831 26.134sec(train) 10.439sec(infer)\n",
      "Epoch 50 tst: l 0.707 a 0.775 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.927sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 51 tr: l 0.627 a 0.790 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.077442 25.988sec(train) 9.865sec(infer)\n",
      "Epoch 51 tst: l 0.707 a 0.776 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  2.043sec\n",
      "Epoch 52 tr: l 0.622 a 0.792 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.077055 26.559sec(train) 10.157sec(infer)\n",
      "Epoch 52 tst: l 0.700 a 0.777 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.956sec\n",
      "Epoch 53 tr: l 0.618 a 0.793 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.076670 26.714sec(train) 9.764sec(infer)\n",
      "Epoch 53 tst: l 0.699 a 0.778 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.963sec\n",
      "Epoch 54 tr: l 0.613 a 0.794 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.076286 26.302sec(train) 10.642sec(infer)\n",
      "Epoch 54 tst: l 0.693 a 0.779 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  2.028sec\n",
      "Epoch 55 tr: l 0.612 a 0.795 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.075905 25.351sec(train) 7.948sec(infer)\n",
      "Epoch 55 tst: l 0.695 a 0.779 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.630sec\n",
      "Epoch 56 tr: l 0.607 a 0.796 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.075525 26.985sec(train) 11.378sec(infer)\n",
      "Epoch 56 tst: l 0.688 a 0.780 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  2.083sec\n",
      "Epoch 57 tr: l 0.606 a 0.796 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.075148 23.093sec(train) 7.544sec(infer)\n",
      "Epoch 57 tst: l 0.689 a 0.780 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.498sec\n",
      "Epoch 58 tr: l 0.601 a 0.798 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.074772 19.147sec(train) 6.176sec(infer)\n",
      "Epoch 58 tst: l 0.684 a 0.780 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.327sec\n",
      "Epoch 59 tr: l 0.600 a 0.798 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.074398 20.866sec(train) 7.190sec(infer)\n",
      "Epoch 59 tst: l 0.684 a 0.782 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.640sec\n",
      "Epoch 60 tr: l 0.595 a 0.800 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.074026 25.302sec(train) 11.371sec(infer)\n",
      "Epoch 60 tst: l 0.680 a 0.782 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  2.248sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 61 tr: l 0.596 a 0.799 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.073656 24.028sec(train) 10.398sec(infer)\n",
      "Epoch 61 tst: l 0.681 a 0.782 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  2.267sec\n",
      "Epoch 62 tr: l 0.590 a 0.801 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.073288 27.931sec(train) 8.222sec(infer)\n",
      "Epoch 62 tst: l 0.675 a 0.783 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.723sec\n",
      "Epoch 63 tr: l 0.590 a 0.801 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.072921 28.039sec(train) 10.925sec(infer)\n",
      "Epoch 63 tst: l 0.676 a 0.784 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.615sec\n",
      "Epoch 64 tr: l 0.583 a 0.804 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.072557 23.898sec(train) 11.390sec(infer)\n",
      "Epoch 64 tst: l 0.670 a 0.785 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  2.233sec\n",
      "Epoch 65 tr: l 0.584 a 0.803 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.072194 25.538sec(train) 9.177sec(infer)\n",
      "Epoch 65 tst: l 0.672 a 0.785 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  2.154sec\n",
      "Epoch 66 tr: l 0.578 a 0.805 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.071833 29.040sec(train) 8.457sec(infer)\n",
      "Epoch 66 tst: l 0.665 a 0.786 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.610sec\n",
      "Epoch 67 tr: l 0.577 a 0.805 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.071474 26.350sec(train) 11.359sec(infer)\n",
      "Epoch 67 tst: l 0.667 a 0.787 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  2.179sec\n",
      "Epoch 68 tr: l 0.573 a 0.807 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.071116 23.880sec(train) 11.027sec(infer)\n",
      "Epoch 68 tst: l 0.661 a 0.788 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  2.250sec\n",
      "Epoch 69 tr: l 0.574 a 0.805 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.070761 26.837sec(train) 8.450sec(infer)\n",
      "Epoch 69 tst: l 0.665 a 0.787 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.905sec\n",
      "Epoch 70 tr: l 0.570 a 0.807 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.070407 28.630sec(train) 9.762sec(infer)\n",
      "Epoch 70 tst: l 0.659 a 0.788 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.617sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 71 tr: l 0.570 a 0.806 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.070055 25.032sec(train) 11.367sec(infer)\n",
      "Epoch 71 tst: l 0.663 a 0.787 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  2.266sec\n",
      "Epoch 72 tr: l 0.566 a 0.808 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.069705 24.721sec(train) 10.164sec(infer)\n",
      "Epoch 72 tst: l 0.655 a 0.789 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  2.283sec\n",
      "Epoch 73 tr: l 0.566 a 0.807 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.069356 28.336sec(train) 8.243sec(infer)\n",
      "Epoch 73 tst: l 0.660 a 0.787 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.727sec\n",
      "Epoch 74 tr: l 0.562 a 0.809 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.069009 27.543sec(train) 10.854sec(infer)\n",
      "Epoch 74 tst: l 0.652 a 0.790 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.924sec\n",
      "Epoch 75 tr: l 0.560 a 0.809 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.068664 24.031sec(train) 11.292sec(infer)\n",
      "Epoch 75 tst: l 0.655 a 0.790 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  2.219sec\n",
      "Epoch 76 tr: l 0.556 a 0.811 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.068321 25.845sec(train) 9.277sec(infer)\n",
      "Epoch 76 tst: l 0.648 a 0.792 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  2.026sec\n",
      "Epoch 77 tr: l 0.555 a 0.811 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.067979 28.902sec(train) 8.926sec(infer)\n",
      "Epoch 77 tst: l 0.651 a 0.791 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.669sec\n",
      "Epoch 78 tr: l 0.552 a 0.812 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.067639 26.261sec(train) 11.269sec(infer)\n",
      "Epoch 78 tst: l 0.645 a 0.793 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  2.030sec\n",
      "Epoch 79 tr: l 0.552 a 0.811 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.067301 24.120sec(train) 10.561sec(infer)\n",
      "Epoch 79 tst: l 0.649 a 0.791 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  2.271sec\n",
      "Epoch 80 tr: l 0.548 a 0.813 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.066965 27.232sec(train) 8.556sec(infer)\n",
      "Epoch 80 tst: l 0.642 a 0.793 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.928sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 81 tr: l 0.546 a 0.813 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.066630 28.231sec(train) 9.923sec(infer)\n",
      "Epoch 81 tst: l 0.644 a 0.793 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.831sec\n",
      "Epoch 82 tr: l 0.543 a 0.815 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.066297 24.823sec(train) 11.413sec(infer)\n",
      "Epoch 82 tst: l 0.638 a 0.794 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  2.272sec\n",
      "Epoch 83 tr: l 0.543 a 0.814 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.065965 24.967sec(train) 9.924sec(infer)\n",
      "Epoch 83 tst: l 0.641 a 0.793 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  2.063sec\n",
      "Epoch 84 tr: l 0.540 a 0.816 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.065635 28.014sec(train) 8.810sec(infer)\n",
      "Epoch 84 tst: l 0.636 a 0.795 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.766sec\n",
      "Epoch 85 tr: l 0.540 a 0.815 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.065307 27.300sec(train) 10.480sec(infer)\n",
      "Epoch 85 tst: l 0.640 a 0.794 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.947sec\n",
      "Epoch 86 tr: l 0.537 a 0.817 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.064981 24.690sec(train) 10.873sec(infer)\n",
      "Epoch 86 tst: l 0.634 a 0.795 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  2.250sec\n",
      "Epoch 87 tr: l 0.536 a 0.816 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.064656 26.563sec(train) 9.353sec(infer)\n",
      "Epoch 87 tst: l 0.636 a 0.795 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.999sec\n",
      "Epoch 88 tr: l 0.532 a 0.818 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.064333 28.000sec(train) 9.546sec(infer)\n",
      "Epoch 88 tst: l 0.631 a 0.797 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.661sec\n",
      "Epoch 89 tr: l 0.532 a 0.818 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.064011 26.061sec(train) 11.056sec(infer)\n",
      "Epoch 89 tst: l 0.633 a 0.796 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.970sec\n",
      "Epoch 90 tr: l 0.529 a 0.819 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.063691 24.801sec(train) 10.153sec(infer)\n",
      "Epoch 90 tst: l 0.628 a 0.797 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  2.228sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 91 tr: l 0.529 a 0.818 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.063372 27.164sec(train) 8.992sec(infer)\n",
      "Epoch 91 tst: l 0.631 a 0.797 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.965sec\n",
      "Epoch 92 tr: l 0.526 a 0.820 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.063056 27.592sec(train) 9.900sec(infer)\n",
      "Epoch 92 tst: l 0.626 a 0.798 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.902sec\n",
      "Epoch 93 tr: l 0.525 a 0.820 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.062740 25.262sec(train) 11.189sec(infer)\n",
      "Epoch 93 tst: l 0.628 a 0.799 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  2.212sec\n",
      "Epoch 94 tr: l 0.521 a 0.821 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.062427 25.541sec(train) 9.852sec(infer)\n",
      "Epoch 94 tst: l 0.623 a 0.799 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  2.011sec\n",
      "Epoch 95 tr: l 0.521 a 0.821 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.062114 27.413sec(train) 9.310sec(infer)\n",
      "Epoch 95 tst: l 0.625 a 0.799 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.794sec\n",
      "Epoch 96 tr: l 0.518 a 0.822 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.061804 26.746sec(train) 10.344sec(infer)\n",
      "Epoch 96 tst: l 0.621 a 0.799 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.953sec\n",
      "Epoch 97 tr: l 0.519 a 0.821 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.061495 25.207sec(train) 10.536sec(infer)\n",
      "Epoch 97 tst: l 0.624 a 0.800 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  2.272sec\n",
      "Epoch 98 tr: l 0.516 a 0.823 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.061187 26.567sec(train) 9.506sec(infer)\n",
      "Epoch 98 tst: l 0.619 a 0.800 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.939sec\n",
      "Epoch 99 tr: l 0.515 a 0.823 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.060881 27.850sec(train) 9.823sec(infer)\n",
      "Epoch 99 tst: l 0.621 a 0.801 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.921sec\n",
      "Epoch 100 tr: l 0.502 a 0.829 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.006058 25.931sec(train) 10.887sec(infer)\n",
      "Epoch 100 tst: l 0.608 a 0.806 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.968sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 101 tr: l 0.500 a 0.830 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.006027 25.318sec(train) 10.026sec(infer)\n",
      "Epoch 101 tst: l 0.605 a 0.808 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  2.101sec\n",
      "Epoch 102 tr: l 0.499 a 0.830 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.005997 27.117sec(train) 9.365sec(infer)\n",
      "Epoch 102 tst: l 0.604 a 0.808 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.943sec\n",
      "Epoch 103 tr: l 0.498 a 0.831 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.005967 27.148sec(train) 9.825sec(infer)\n",
      "Epoch 103 tst: l 0.603 a 0.808 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.944sec\n",
      "Epoch 104 tr: l 0.498 a 0.831 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.005937 25.893sec(train) 10.989sec(infer)\n",
      "Epoch 104 tst: l 0.603 a 0.808 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  2.119sec\n",
      "Epoch 105 tr: l 0.497 a 0.831 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.005908 25.668sec(train) 9.855sec(infer)\n",
      "Epoch 105 tst: l 0.603 a 0.808 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.964sec\n",
      "Epoch 106 tr: l 0.497 a 0.831 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.005878 27.156sec(train) 9.785sec(infer)\n",
      "Epoch 106 tst: l 0.603 a 0.808 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.826sec\n",
      "Epoch 107 tr: l 0.497 a 0.831 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.005849 26.492sec(train) 10.221sec(infer)\n",
      "Epoch 107 tst: l 0.603 a 0.808 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.914sec\n",
      "Epoch 108 tr: l 0.496 a 0.831 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.005820 25.859sec(train) 10.332sec(infer)\n",
      "Epoch 108 tst: l 0.603 a 0.808 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  2.250sec\n",
      "Epoch 109 tr: l 0.496 a 0.831 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.005790 26.607sec(train) 9.643sec(infer)\n",
      "Epoch 109 tst: l 0.602 a 0.808 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.950sec\n",
      "Epoch 110 tr: l 0.496 a 0.831 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.005762 27.119sec(train) 9.854sec(infer)\n",
      "Epoch 110 tst: l 0.602 a 0.808 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  2.059sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 111 tr: l 0.496 a 0.831 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.005733 25.982sec(train) 10.703sec(infer)\n",
      "Epoch 111 tst: l 0.602 a 0.809 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.967sec\n",
      "Epoch 112 tr: l 0.496 a 0.831 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.005704 25.957sec(train) 9.921sec(infer)\n",
      "Epoch 112 tst: l 0.602 a 0.808 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  2.059sec\n",
      "Epoch 113 tr: l 0.495 a 0.831 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.005676 26.928sec(train) 9.908sec(infer)\n",
      "Epoch 113 tst: l 0.602 a 0.808 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.954sec\n",
      "Epoch 114 tr: l 0.495 a 0.831 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.005647 26.794sec(train) 9.735sec(infer)\n",
      "Epoch 114 tst: l 0.602 a 0.809 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.982sec\n",
      "Epoch 115 tr: l 0.495 a 0.831 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.005619 26.027sec(train) 10.765sec(infer)\n",
      "Epoch 115 tst: l 0.602 a 0.809 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  2.101sec\n",
      "Epoch 116 tr: l 0.495 a 0.831 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.005591 26.255sec(train) 9.770sec(infer)\n",
      "Epoch 116 tst: l 0.601 a 0.809 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.972sec\n",
      "Epoch 117 tr: l 0.494 a 0.832 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.005563 26.710sec(train) 10.044sec(infer)\n",
      "Epoch 117 tst: l 0.601 a 0.809 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.973sec\n",
      "Epoch 118 tr: l 0.494 a 0.832 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.005535 26.648sec(train) 10.000sec(infer)\n",
      "Epoch 118 tst: l 0.601 a 0.809 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.972sec\n",
      "Epoch 119 tr: l 0.494 a 0.832 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.005507 25.876sec(train) 10.156sec(infer)\n",
      "Epoch 119 tst: l 0.601 a 0.809 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  2.263sec\n",
      "Epoch 120 tr: l 0.494 a 0.832 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.005480 26.417sec(train) 9.783sec(infer)\n",
      "Epoch 120 tst: l 0.601 a 0.809 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.962sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 121 tr: l 0.494 a 0.832 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.005452 26.674sec(train) 9.915sec(infer)\n",
      "Epoch 121 tst: l 0.601 a 0.809 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  2.055sec\n",
      "Epoch 122 tr: l 0.494 a 0.832 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.005425 26.189sec(train) 10.574sec(infer)\n",
      "Epoch 122 tst: l 0.601 a 0.809 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.926sec\n",
      "Epoch 123 tr: l 0.493 a 0.832 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.005398 26.153sec(train) 9.918sec(infer)\n",
      "Epoch 123 tst: l 0.601 a 0.809 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.986sec\n",
      "Epoch 124 tr: l 0.493 a 0.832 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.005371 26.511sec(train) 10.125sec(infer)\n",
      "Epoch 124 tst: l 0.600 a 0.809 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.964sec\n",
      "Epoch 125 tr: l 0.493 a 0.832 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.005344 26.625sec(train) 9.767sec(infer)\n",
      "Epoch 125 tst: l 0.600 a 0.809 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.983sec\n",
      "Epoch 126 tr: l 0.493 a 0.832 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.005318 26.155sec(train) 10.621sec(infer)\n",
      "Epoch 126 tst: l 0.600 a 0.809 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  2.023sec\n",
      "Epoch 127 tr: l 0.493 a 0.832 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.005291 26.236sec(train) 9.784sec(infer)\n",
      "Epoch 127 tst: l 0.600 a 0.809 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.978sec\n",
      "Epoch 128 tr: l 0.493 a 0.832 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.005264 26.642sec(train) 10.124sec(infer)\n",
      "Epoch 128 tst: l 0.600 a 0.809 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.988sec\n",
      "Epoch 129 tr: l 0.493 a 0.832 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.005238 26.483sec(train) 9.977sec(infer)\n",
      "Epoch 129 tst: l 0.600 a 0.809 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.948sec\n",
      "Epoch 130 tr: l 0.492 a 0.832 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.005212 26.070sec(train) 10.189sec(infer)\n",
      "Epoch 130 tst: l 0.600 a 0.809 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  2.246sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 131 tr: l 0.492 a 0.832 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.005186 26.377sec(train) 9.825sec(infer)\n",
      "Epoch 131 tst: l 0.600 a 0.809 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.945sec\n",
      "Epoch 132 tr: l 0.492 a 0.832 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.005160 26.789sec(train) 9.925sec(infer)\n",
      "Epoch 132 tst: l 0.600 a 0.809 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  2.040sec\n",
      "Epoch 133 tr: l 0.492 a 0.832 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.005134 26.167sec(train) 10.445sec(infer)\n",
      "Epoch 133 tst: l 0.600 a 0.809 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.960sec\n",
      "Epoch 134 tr: l 0.492 a 0.832 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.005108 26.209sec(train) 9.900sec(infer)\n",
      "Epoch 134 tst: l 0.599 a 0.809 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  2.040sec\n",
      "Epoch 135 tr: l 0.492 a 0.832 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.005083 26.518sec(train) 10.160sec(infer)\n",
      "Epoch 135 tst: l 0.599 a 0.809 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.963sec\n",
      "Epoch 136 tr: l 0.492 a 0.832 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.005058 26.592sec(train) 9.789sec(infer)\n",
      "Epoch 136 tst: l 0.599 a 0.809 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.995sec\n",
      "Epoch 137 tr: l 0.491 a 0.832 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.005032 26.499sec(train) 10.659sec(infer)\n",
      "Epoch 137 tst: l 0.599 a 0.809 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.943sec\n",
      "Epoch 138 tr: l 0.491 a 0.832 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.005007 26.242sec(train) 9.799sec(infer)\n",
      "Epoch 138 tst: l 0.599 a 0.809 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.927sec\n",
      "Epoch 139 tr: l 0.491 a 0.832 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.004982 26.596sec(train) 10.232sec(infer)\n",
      "Epoch 139 tst: l 0.599 a 0.809 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.955sec\n",
      "Epoch 140 tr: l 0.491 a 0.832 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.004957 26.531sec(train) 9.888sec(infer)\n",
      "Epoch 140 tst: l 0.599 a 0.809 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.922sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 141 tr: l 0.491 a 0.833 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.004932 26.145sec(train) 10.293sec(infer)\n",
      "Epoch 141 tst: l 0.599 a 0.809 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  2.222sec\n",
      "Epoch 142 tr: l 0.491 a 0.833 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.004908 26.468sec(train) 9.878sec(infer)\n",
      "Epoch 142 tst: l 0.599 a 0.809 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.925sec\n",
      "Epoch 143 tr: l 0.491 a 0.833 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.004883 26.582sec(train) 10.057sec(infer)\n",
      "Epoch 143 tst: l 0.599 a 0.809 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  2.082sec\n",
      "Epoch 144 tr: l 0.491 a 0.833 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.004859 26.231sec(train) 10.315sec(infer)\n",
      "Epoch 144 tst: l 0.599 a 0.809 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.982sec\n",
      "Epoch 145 tr: l 0.490 a 0.833 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.004834 26.245sec(train) 9.908sec(infer)\n",
      "Epoch 145 tst: l 0.598 a 0.809 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  2.086sec\n",
      "Epoch 146 tr: l 0.490 a 0.833 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.004810 26.369sec(train) 10.184sec(infer)\n",
      "Epoch 146 tst: l 0.598 a 0.809 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.962sec\n",
      "Epoch 147 tr: l 0.490 a 0.833 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.004786 26.519sec(train) 9.734sec(infer)\n",
      "Epoch 147 tst: l 0.598 a 0.809 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  2.075sec\n",
      "Epoch 148 tr: l 0.490 a 0.833 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.004762 26.191sec(train) 10.417sec(infer)\n",
      "Epoch 148 tst: l 0.598 a 0.809 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.963sec\n",
      "Epoch 149 tr: l 0.490 a 0.833 clct[np.int64(99), np.int64(1), np.int64(50), np.int64(50)] cl_acc 0.755  lr 0.004738 26.146sec(train) 9.759sec(infer)\n",
      "Epoch 149 tst: l 0.598 a 0.809 clct[np.int64(20), np.int64(0), np.int64(10), np.int64(10)] cl_acc 0.750  1.983sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "---train cluster Ended in 1.60 hour (5752.996 sec) \n",
      "---------------------------------IFCA, lr: 0.1, seed: 4506---------------------------------\n",
      "config: {'m': 200, 'm_test': 40, 'p': 4, 'n': 1500, 'uneven': True, 'local_model_init': False, 'Gp': 0.15, 'graph': 'er', 'agg': 'seq', '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:2\n",
      "Epoch -1 tr: l 3.862 a 0.028 clct[np.int64(100), np.int64(84), np.int64(4), np.int64(12)] cl_acc 0.490  10.527sec\n",
      "Epoch -1 tst: l 3.858 a 0.028 clct[np.int64(16), np.int64(21), np.int64(1), np.int64(2)] cl_acc 0.425  2.048sec\n",
      "Epoch 0 tr: l 3.448 a 0.172 clct[np.int64(87), np.int64(61), np.int64(48), np.int64(4)] cl_acc 0.725  lr 0.100000 26.134sec(train) 9.821sec(infer)\n",
      "Epoch 0 tst: l 3.465 a 0.169 clct[np.int64(15), np.int64(15), np.int64(9), np.int64(1)] cl_acc 0.725  2.065sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 1 tr: l 2.771 a 0.385 clct[np.int64(99), np.int64(50), np.int64(48), np.int64(3)] cl_acc 0.745  lr 0.099500 26.525sec(train) 10.266sec(infer)\n",
      "Epoch 1 tst: l 2.796 a 0.379 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.059sec\n",
      "Epoch 2 tr: l 2.219 a 0.498 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.099003 26.676sec(train) 9.845sec(infer)\n",
      "Epoch 2 tst: l 2.246 a 0.491 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.014sec\n",
      "Epoch 3 tr: l 1.864 a 0.557 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.098507 26.145sec(train) 10.442sec(infer)\n",
      "Epoch 3 tst: l 1.894 a 0.550 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.180sec\n",
      "Epoch 4 tr: l 1.646 a 0.585 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.098015 26.058sec(train) 9.861sec(infer)\n",
      "Epoch 4 tst: l 1.681 a 0.578 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.006sec\n",
      "Epoch 5 tr: l 1.525 a 0.591 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.097525 26.524sec(train) 10.105sec(infer)\n",
      "Epoch 5 tst: l 1.556 a 0.583 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.214sec\n",
      "Epoch 6 tr: l 1.395 a 0.618 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.097037 26.378sec(train) 10.123sec(infer)\n",
      "Epoch 6 tst: l 1.438 a 0.611 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  1.999sec\n",
      "Epoch 7 tr: l 1.282 a 0.648 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.096552 26.100sec(train) 10.014sec(infer)\n",
      "Epoch 7 tst: l 1.320 a 0.640 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.226sec\n",
      "Epoch 8 tr: l 1.198 a 0.667 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.096069 26.427sec(train) 10.074sec(infer)\n",
      "Epoch 8 tst: l 1.241 a 0.659 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.018sec\n",
      "Epoch 9 tr: l 1.135 a 0.680 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.095589 26.502sec(train) 9.896sec(infer)\n",
      "Epoch 9 tst: l 1.181 a 0.672 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.087sec\n",
      "Epoch 10 tr: l 1.071 a 0.695 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.095111 26.357sec(train) 10.486sec(infer)\n",
      "Epoch 10 tst: l 1.119 a 0.687 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.031sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 11 tr: l 1.027 a 0.705 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.094635 25.961sec(train) 9.855sec(infer)\n",
      "Epoch 11 tst: l 1.077 a 0.696 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.076sec\n",
      "Epoch 12 tr: l 0.981 a 0.715 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.094162 26.376sec(train) 10.161sec(infer)\n",
      "Epoch 12 tst: l 1.033 a 0.706 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  1.993sec\n",
      "Epoch 13 tr: l 0.950 a 0.722 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.093691 26.474sec(train) 9.831sec(infer)\n",
      "Epoch 13 tst: l 1.004 a 0.713 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  1.979sec\n",
      "Epoch 14 tr: l 0.916 a 0.730 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.093223 26.336sec(train) 10.617sec(infer)\n",
      "Epoch 14 tst: l 0.973 a 0.721 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.013sec\n",
      "Epoch 15 tr: l 0.893 a 0.735 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.092757 26.056sec(train) 9.832sec(infer)\n",
      "Epoch 15 tst: l 0.951 a 0.726 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.018sec\n",
      "Epoch 16 tr: l 0.863 a 0.743 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.092293 26.643sec(train) 10.261sec(infer)\n",
      "Epoch 16 tst: l 0.923 a 0.734 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.013sec\n",
      "Epoch 17 tr: l 0.843 a 0.747 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.091832 26.257sec(train) 9.926sec(infer)\n",
      "Epoch 17 tst: l 0.904 a 0.737 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  1.960sec\n",
      "Epoch 18 tr: l 0.819 a 0.755 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.091372 26.077sec(train) 10.219sec(infer)\n",
      "Epoch 18 tst: l 0.882 a 0.743 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.327sec\n",
      "Epoch 19 tr: l 0.805 a 0.756 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.090916 25.960sec(train) 9.905sec(infer)\n",
      "Epoch 19 tst: l 0.868 a 0.746 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  1.998sec\n",
      "Epoch 20 tr: l 0.785 a 0.763 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.090461 26.334sec(train) 9.924sec(infer)\n",
      "Epoch 20 tst: l 0.852 a 0.751 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.196sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 21 tr: l 0.772 a 0.764 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.090009 26.182sec(train) 10.367sec(infer)\n",
      "Epoch 21 tst: l 0.839 a 0.752 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.011sec\n",
      "Epoch 22 tr: l 0.753 a 0.772 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.089559 26.230sec(train) 9.891sec(infer)\n",
      "Epoch 22 tst: l 0.820 a 0.760 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.131sec\n",
      "Epoch 23 tr: l 0.742 a 0.771 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.089111 26.414sec(train) 10.349sec(infer)\n",
      "Epoch 23 tst: l 0.813 a 0.759 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.028sec\n",
      "Epoch 24 tr: l 0.727 a 0.778 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.088665 26.246sec(train) 9.814sec(infer)\n",
      "Epoch 24 tst: l 0.795 a 0.765 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.117sec\n",
      "Epoch 25 tr: l 0.716 a 0.778 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.088222 26.046sec(train) 10.479sec(infer)\n",
      "Epoch 25 tst: l 0.790 a 0.765 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.032sec\n",
      "Epoch 26 tr: l 0.703 a 0.784 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.087781 26.236sec(train) 9.844sec(infer)\n",
      "Epoch 26 tst: l 0.773 a 0.771 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.056sec\n",
      "Epoch 27 tr: l 0.694 a 0.783 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.087342 26.723sec(train) 10.339sec(infer)\n",
      "Epoch 27 tst: l 0.770 a 0.770 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.051sec\n",
      "Epoch 28 tr: l 0.683 a 0.788 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.086905 26.364sec(train) 9.810sec(infer)\n",
      "Epoch 28 tst: l 0.754 a 0.775 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.020sec\n",
      "Epoch 29 tr: l 0.677 a 0.787 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.086471 26.210sec(train) 10.485sec(infer)\n",
      "Epoch 29 tst: l 0.754 a 0.773 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.187sec\n",
      "Epoch 30 tr: l 0.668 a 0.792 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.086038 26.243sec(train) 9.900sec(infer)\n",
      "Epoch 30 tst: l 0.741 a 0.779 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  1.986sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 31 tr: l 0.658 a 0.793 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.085608 26.471sec(train) 10.184sec(infer)\n",
      "Epoch 31 tst: l 0.734 a 0.779 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.247sec\n",
      "Epoch 32 tr: l 0.650 a 0.796 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.085180 26.388sec(train) 10.135sec(infer)\n",
      "Epoch 32 tst: l 0.726 a 0.783 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.024sec\n",
      "Epoch 33 tr: l 0.643 a 0.797 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.084754 26.153sec(train) 9.992sec(infer)\n",
      "Epoch 33 tst: l 0.719 a 0.783 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.212sec\n",
      "Epoch 34 tr: l 0.635 a 0.800 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.084331 26.305sec(train) 10.073sec(infer)\n",
      "Epoch 34 tst: l 0.713 a 0.787 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.024sec\n",
      "Epoch 35 tr: l 0.627 a 0.802 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.083909 26.312sec(train) 9.937sec(infer)\n",
      "Epoch 35 tst: l 0.705 a 0.787 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.126sec\n",
      "Epoch 36 tr: l 0.620 a 0.804 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.083489 26.283sec(train) 10.514sec(infer)\n",
      "Epoch 36 tst: l 0.700 a 0.791 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.006sec\n",
      "Epoch 37 tr: l 0.614 a 0.805 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.083072 26.600sec(train) 9.915sec(infer)\n",
      "Epoch 37 tst: l 0.693 a 0.791 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.124sec\n",
      "Epoch 38 tr: l 0.608 a 0.807 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.082657 26.300sec(train) 10.384sec(infer)\n",
      "Epoch 38 tst: l 0.688 a 0.794 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.030sec\n",
      "Epoch 39 tr: l 0.603 a 0.809 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.082243 26.387sec(train) 9.817sec(infer)\n",
      "Epoch 39 tst: l 0.684 a 0.794 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.088sec\n",
      "Epoch 40 tr: l 0.599 a 0.810 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.081832 26.339sec(train) 10.495sec(infer)\n",
      "Epoch 40 tst: l 0.678 a 0.795 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.072sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 41 tr: l 0.596 a 0.810 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.081423 26.392sec(train) 9.821sec(infer)\n",
      "Epoch 41 tst: l 0.679 a 0.795 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.056sec\n",
      "Epoch 42 tr: l 0.591 a 0.810 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.081016 26.720sec(train) 10.413sec(infer)\n",
      "Epoch 42 tst: l 0.671 a 0.795 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.098sec\n",
      "Epoch 43 tr: l 0.586 a 0.812 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.080611 26.332sec(train) 9.878sec(infer)\n",
      "Epoch 43 tst: l 0.670 a 0.798 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.022sec\n",
      "Epoch 44 tr: l 0.581 a 0.813 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.080208 26.322sec(train) 10.232sec(infer)\n",
      "Epoch 44 tst: l 0.662 a 0.797 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.274sec\n",
      "Epoch 45 tr: l 0.574 a 0.816 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.079807 26.237sec(train) 9.996sec(infer)\n",
      "Epoch 45 tst: l 0.659 a 0.801 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.028sec\n",
      "Epoch 46 tr: l 0.568 a 0.817 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.079408 26.512sec(train) 10.004sec(infer)\n",
      "Epoch 46 tst: l 0.651 a 0.800 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.228sec\n",
      "Epoch 47 tr: l 0.563 a 0.819 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.079010 26.216sec(train) 10.183sec(infer)\n",
      "Epoch 47 tst: l 0.650 a 0.804 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.028sec\n",
      "Epoch 48 tr: l 0.559 a 0.820 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.078615 26.191sec(train) 9.914sec(infer)\n",
      "Epoch 48 tst: l 0.642 a 0.803 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.149sec\n",
      "Epoch 49 tr: l 0.554 a 0.822 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.078222 26.286sec(train) 10.291sec(infer)\n",
      "Epoch 49 tst: l 0.642 a 0.805 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.041sec\n",
      "Epoch 50 tr: l 0.550 a 0.823 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.077831 26.577sec(train) 9.833sec(infer)\n",
      "Epoch 50 tst: l 0.635 a 0.806 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.134sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 51 tr: l 0.546 a 0.823 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.077442 26.292sec(train) 10.419sec(infer)\n",
      "Epoch 51 tst: l 0.635 a 0.806 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.034sec\n",
      "Epoch 52 tr: l 0.543 a 0.824 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.077055 26.543sec(train) 9.732sec(infer)\n",
      "Epoch 52 tst: l 0.628 a 0.807 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.095sec\n",
      "Epoch 53 tr: l 0.539 a 0.825 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.076670 26.281sec(train) 10.478sec(infer)\n",
      "Epoch 53 tst: l 0.629 a 0.807 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.034sec\n",
      "Epoch 54 tr: l 0.536 a 0.826 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.076286 26.277sec(train) 9.764sec(infer)\n",
      "Epoch 54 tst: l 0.622 a 0.809 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.060sec\n",
      "Epoch 55 tr: l 0.532 a 0.827 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.075905 26.413sec(train) 10.309sec(infer)\n",
      "Epoch 55 tst: l 0.623 a 0.809 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.098sec\n",
      "Epoch 56 tr: l 0.528 a 0.828 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.075525 26.160sec(train) 9.820sec(infer)\n",
      "Epoch 56 tst: l 0.615 a 0.811 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.023sec\n",
      "Epoch 57 tr: l 0.524 a 0.830 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.075148 26.308sec(train) 10.220sec(infer)\n",
      "Epoch 57 tst: l 0.616 a 0.811 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.294sec\n",
      "Epoch 58 tr: l 0.521 a 0.830 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.074772 26.202sec(train) 10.005sec(infer)\n",
      "Epoch 58 tst: l 0.609 a 0.812 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.019sec\n",
      "Epoch 59 tr: l 0.516 a 0.832 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.074398 26.459sec(train) 9.988sec(infer)\n",
      "Epoch 59 tst: l 0.610 a 0.813 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.185sec\n",
      "Epoch 60 tr: l 0.514 a 0.832 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.074026 26.499sec(train) 10.232sec(infer)\n",
      "Epoch 60 tst: l 0.602 a 0.814 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.010sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 61 tr: l 0.510 a 0.833 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.073656 26.085sec(train) 9.949sec(infer)\n",
      "Epoch 61 tst: l 0.605 a 0.814 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.141sec\n",
      "Epoch 62 tr: l 0.507 a 0.834 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.073288 26.273sec(train) 10.287sec(infer)\n",
      "Epoch 62 tst: l 0.597 a 0.815 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.034sec\n",
      "Epoch 63 tr: l 0.505 a 0.834 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.072921 26.428sec(train) 9.850sec(infer)\n",
      "Epoch 63 tst: l 0.602 a 0.815 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.144sec\n",
      "Epoch 64 tr: l 0.501 a 0.835 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.072557 26.443sec(train) 10.425sec(infer)\n",
      "Epoch 64 tst: l 0.592 a 0.816 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.019sec\n",
      "Epoch 65 tr: l 0.500 a 0.835 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.072194 26.065sec(train) 9.795sec(infer)\n",
      "Epoch 65 tst: l 0.598 a 0.816 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.067sec\n",
      "Epoch 66 tr: l 0.495 a 0.837 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.071833 26.247sec(train) 10.371sec(infer)\n",
      "Epoch 66 tst: l 0.587 a 0.817 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  1.991sec\n",
      "Epoch 67 tr: l 0.492 a 0.838 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.071474 26.365sec(train) 9.843sec(infer)\n",
      "Epoch 67 tst: l 0.590 a 0.818 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.012sec\n",
      "Epoch 68 tr: l 0.487 a 0.840 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.071116 26.542sec(train) 10.540sec(infer)\n",
      "Epoch 68 tst: l 0.581 a 0.820 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.029sec\n",
      "Epoch 69 tr: l 0.484 a 0.840 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.070761 26.152sec(train) 9.879sec(infer)\n",
      "Epoch 69 tst: l 0.582 a 0.820 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  1.979sec\n",
      "Epoch 70 tr: l 0.480 a 0.841 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.070407 26.436sec(train) 10.279sec(infer)\n",
      "Epoch 70 tst: l 0.576 a 0.821 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.131sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 71 tr: l 0.478 a 0.841 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.070055 26.330sec(train) 9.935sec(infer)\n",
      "Epoch 71 tst: l 0.576 a 0.821 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.028sec\n",
      "Epoch 72 tr: l 0.475 a 0.843 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.069705 26.108sec(train) 10.084sec(infer)\n",
      "Epoch 72 tst: l 0.573 a 0.822 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.306sec\n",
      "Epoch 73 tr: l 0.473 a 0.843 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.069356 26.507sec(train) 10.001sec(infer)\n",
      "Epoch 73 tst: l 0.571 a 0.822 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.024sec\n",
      "Epoch 74 tr: l 0.469 a 0.844 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.069009 26.579sec(train) 9.899sec(infer)\n",
      "Epoch 74 tst: l 0.569 a 0.823 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.129sec\n",
      "Epoch 75 tr: l 0.468 a 0.844 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.068664 25.991sec(train) 10.399sec(infer)\n",
      "Epoch 75 tst: l 0.566 a 0.823 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.042sec\n",
      "Epoch 76 tr: l 0.466 a 0.845 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.068321 25.975sec(train) 9.858sec(infer)\n",
      "Epoch 76 tst: l 0.566 a 0.824 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.082sec\n",
      "Epoch 77 tr: l 0.464 a 0.845 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.067979 26.626sec(train) 10.259sec(infer)\n",
      "Epoch 77 tst: l 0.563 a 0.824 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  1.994sec\n",
      "Epoch 78 tr: l 0.462 a 0.846 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.067639 26.532sec(train) 9.816sec(infer)\n",
      "Epoch 78 tst: l 0.564 a 0.825 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.028sec\n",
      "Epoch 79 tr: l 0.458 a 0.847 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.067301 26.262sec(train) 10.709sec(infer)\n",
      "Epoch 79 tst: l 0.560 a 0.825 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.059sec\n",
      "Epoch 80 tr: l 0.457 a 0.847 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.066965 26.002sec(train) 9.796sec(infer)\n",
      "Epoch 80 tst: l 0.560 a 0.826 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.048sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 81 tr: l 0.454 a 0.848 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.066630 26.642sec(train) 10.144sec(infer)\n",
      "Epoch 81 tst: l 0.556 a 0.826 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.085sec\n",
      "Epoch 82 tr: l 0.452 a 0.848 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.066297 26.743sec(train) 9.953sec(infer)\n",
      "Epoch 82 tst: l 0.556 a 0.827 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.009sec\n",
      "Epoch 83 tr: l 0.449 a 0.849 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.065965 26.132sec(train) 10.357sec(infer)\n",
      "Epoch 83 tst: l 0.553 a 0.827 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.352sec\n",
      "Epoch 84 tr: l 0.448 a 0.850 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.065635 25.939sec(train) 9.941sec(infer)\n",
      "Epoch 84 tst: l 0.552 a 0.828 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  1.985sec\n",
      "Epoch 85 tr: l 0.445 a 0.850 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.065307 26.405sec(train) 9.970sec(infer)\n",
      "Epoch 85 tst: l 0.550 a 0.828 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.183sec\n",
      "Epoch 86 tr: l 0.444 a 0.851 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.064981 26.511sec(train) 10.370sec(infer)\n",
      "Epoch 86 tst: l 0.549 a 0.829 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  1.988sec\n",
      "Epoch 87 tr: l 0.442 a 0.851 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.064656 26.116sec(train) 9.958sec(infer)\n",
      "Epoch 87 tst: l 0.547 a 0.828 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.187sec\n",
      "Epoch 88 tr: l 0.440 a 0.852 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.064333 26.412sec(train) 10.057sec(infer)\n",
      "Epoch 88 tst: l 0.546 a 0.829 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.001sec\n",
      "Epoch 89 tr: l 0.438 a 0.852 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.064011 26.313sec(train) 9.811sec(infer)\n",
      "Epoch 89 tst: l 0.545 a 0.829 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.109sec\n",
      "Epoch 90 tr: l 0.437 a 0.853 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.063691 26.407sec(train) 10.470sec(infer)\n",
      "Epoch 90 tst: l 0.543 a 0.830 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  1.983sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 91 tr: l 0.435 a 0.852 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.063372 26.053sec(train) 9.857sec(infer)\n",
      "Epoch 91 tst: l 0.544 a 0.830 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.059sec\n",
      "Epoch 92 tr: l 0.434 a 0.853 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.063056 26.280sec(train) 10.279sec(infer)\n",
      "Epoch 92 tst: l 0.541 a 0.830 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  1.991sec\n",
      "Epoch 93 tr: l 0.433 a 0.853 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.062740 26.251sec(train) 9.855sec(infer)\n",
      "Epoch 93 tst: l 0.544 a 0.830 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  1.988sec\n",
      "Epoch 94 tr: l 0.433 a 0.853 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.062427 26.352sec(train) 10.363sec(infer)\n",
      "Epoch 94 tst: l 0.539 a 0.831 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.040sec\n",
      "Epoch 95 tr: l 0.433 a 0.853 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.062114 26.425sec(train) 9.940sec(infer)\n",
      "Epoch 95 tst: l 0.545 a 0.830 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  1.967sec\n",
      "Epoch 96 tr: l 0.432 a 0.854 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.061804 26.370sec(train) 10.232sec(infer)\n",
      "Epoch 96 tst: l 0.538 a 0.831 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.222sec\n",
      "Epoch 97 tr: l 0.431 a 0.853 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.061495 26.121sec(train) 10.025sec(infer)\n",
      "Epoch 97 tst: l 0.545 a 0.830 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  1.950sec\n",
      "Epoch 98 tr: l 0.429 a 0.854 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.061187 26.288sec(train) 10.072sec(infer)\n",
      "Epoch 98 tst: l 0.536 a 0.831 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.180sec\n",
      "Epoch 99 tr: l 0.428 a 0.854 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.060881 26.367sec(train) 10.156sec(infer)\n",
      "Epoch 99 tst: l 0.543 a 0.831 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  1.996sec\n",
      "Epoch 100 tr: l 0.418 a 0.857 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.006058 26.730sec(train) 9.974sec(infer)\n",
      "Epoch 100 tst: l 0.531 a 0.834 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.119sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 101 tr: l 0.416 a 0.858 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.006027 26.272sec(train) 10.454sec(infer)\n",
      "Epoch 101 tst: l 0.528 a 0.835 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.034sec\n",
      "Epoch 102 tr: l 0.415 a 0.858 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.005997 26.180sec(train) 9.842sec(infer)\n",
      "Epoch 102 tst: l 0.527 a 0.835 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.119sec\n",
      "Epoch 103 tr: l 0.414 a 0.859 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.005967 26.350sec(train) 10.367sec(infer)\n",
      "Epoch 103 tst: l 0.526 a 0.835 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.034sec\n",
      "Epoch 104 tr: l 0.414 a 0.859 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.005937 26.427sec(train) 9.821sec(infer)\n",
      "Epoch 104 tst: l 0.525 a 0.836 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.066sec\n",
      "Epoch 105 tr: l 0.413 a 0.859 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.005908 26.393sec(train) 10.541sec(infer)\n",
      "Epoch 105 tst: l 0.525 a 0.836 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.051sec\n",
      "Epoch 106 tr: l 0.413 a 0.859 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.005878 26.091sec(train) 9.746sec(infer)\n",
      "Epoch 106 tst: l 0.524 a 0.836 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.047sec\n",
      "Epoch 107 tr: l 0.412 a 0.859 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.005849 26.477sec(train) 10.350sec(infer)\n",
      "Epoch 107 tst: l 0.524 a 0.836 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.129sec\n",
      "Epoch 108 tr: l 0.412 a 0.859 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.005820 26.176sec(train) 9.920sec(infer)\n",
      "Epoch 108 tst: l 0.523 a 0.836 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.000sec\n",
      "Epoch 109 tr: l 0.411 a 0.860 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.005790 26.479sec(train) 10.254sec(infer)\n",
      "Epoch 109 tst: l 0.523 a 0.836 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.353sec\n",
      "Epoch 110 tr: l 0.411 a 0.860 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.005762 26.598sec(train) 10.098sec(infer)\n",
      "Epoch 110 tst: l 0.523 a 0.837 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.012sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 111 tr: l 0.410 a 0.860 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.005733 26.410sec(train) 10.020sec(infer)\n",
      "Epoch 111 tst: l 0.522 a 0.837 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.188sec\n",
      "Epoch 112 tr: l 0.410 a 0.860 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.005704 22.281sec(train) 11.242sec(infer)\n",
      "Epoch 112 tst: l 0.522 a 0.837 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.354sec\n",
      "Epoch 113 tr: l 0.409 a 0.860 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.005676 26.616sec(train) 8.449sec(infer)\n",
      "Epoch 113 tst: l 0.522 a 0.837 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  1.869sec\n",
      "Epoch 114 tr: l 0.409 a 0.860 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.005647 28.716sec(train) 9.485sec(infer)\n",
      "Epoch 114 tst: l 0.521 a 0.837 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  1.695sec\n",
      "Epoch 115 tr: l 0.409 a 0.860 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.005619 22.449sec(train) 7.589sec(infer)\n",
      "Epoch 115 tst: l 0.521 a 0.837 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  1.547sec\n",
      "Epoch 116 tr: l 0.408 a 0.861 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.005591 17.862sec(train) 6.567sec(infer)\n",
      "Epoch 116 tst: l 0.521 a 0.837 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  1.571sec\n",
      "Epoch 117 tr: l 0.408 a 0.861 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.005563 20.402sec(train) 8.070sec(infer)\n",
      "Epoch 117 tst: l 0.520 a 0.837 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  1.652sec\n",
      "Epoch 118 tr: l 0.408 a 0.861 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.005535 26.775sec(train) 11.441sec(infer)\n",
      "Epoch 118 tst: l 0.520 a 0.838 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.183sec\n",
      "Epoch 119 tr: l 0.407 a 0.861 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.005507 22.910sec(train) 11.273sec(infer)\n",
      "Epoch 119 tst: l 0.520 a 0.838 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.360sec\n",
      "Epoch 120 tr: l 0.407 a 0.861 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.005480 26.385sec(train) 8.456sec(infer)\n",
      "Epoch 120 tst: l 0.519 a 0.838 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  1.891sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 121 tr: l 0.406 a 0.861 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.005452 29.100sec(train) 9.372sec(infer)\n",
      "Epoch 121 tst: l 0.519 a 0.838 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  1.700sec\n",
      "Epoch 122 tr: l 0.406 a 0.861 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.005425 24.865sec(train) 11.422sec(infer)\n",
      "Epoch 122 tst: l 0.519 a 0.838 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.362sec\n",
      "Epoch 123 tr: l 0.406 a 0.861 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.005398 24.180sec(train) 9.907sec(infer)\n",
      "Epoch 123 tst: l 0.518 a 0.838 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.349sec\n",
      "Epoch 124 tr: l 0.405 a 0.861 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.005371 28.281sec(train) 8.073sec(infer)\n",
      "Epoch 124 tst: l 0.518 a 0.838 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  1.787sec\n",
      "Epoch 125 tr: l 0.405 a 0.861 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.005344 27.259sec(train) 11.034sec(infer)\n",
      "Epoch 125 tst: l 0.518 a 0.838 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.015sec\n",
      "Epoch 126 tr: l 0.405 a 0.861 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.005318 23.323sec(train) 11.311sec(infer)\n",
      "Epoch 126 tst: l 0.518 a 0.838 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.370sec\n",
      "Epoch 127 tr: l 0.405 a 0.862 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.005291 25.935sec(train) 8.709sec(infer)\n",
      "Epoch 127 tst: l 0.517 a 0.838 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.106sec\n",
      "Epoch 128 tr: l 0.404 a 0.862 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.005264 28.611sec(train) 8.960sec(infer)\n",
      "Epoch 128 tst: l 0.517 a 0.839 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  1.684sec\n",
      "Epoch 129 tr: l 0.404 a 0.862 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.005238 25.479sec(train) 11.437sec(infer)\n",
      "Epoch 129 tst: l 0.517 a 0.839 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.362sec\n",
      "Epoch 130 tr: l 0.404 a 0.862 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.005212 23.732sec(train) 10.239sec(infer)\n",
      "Epoch 130 tst: l 0.517 a 0.839 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.357sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 131 tr: l 0.403 a 0.862 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.005186 27.741sec(train) 8.220sec(infer)\n",
      "Epoch 131 tst: l 0.516 a 0.839 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  1.785sec\n",
      "Epoch 132 tr: l 0.403 a 0.862 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.005160 27.503sec(train) 10.672sec(infer)\n",
      "Epoch 132 tst: l 0.516 a 0.839 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.026sec\n",
      "Epoch 133 tr: l 0.403 a 0.862 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.005134 23.911sec(train) 11.234sec(infer)\n",
      "Epoch 133 tst: l 0.516 a 0.839 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.351sec\n",
      "Epoch 134 tr: l 0.402 a 0.862 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.005108 25.866sec(train) 9.213sec(infer)\n",
      "Epoch 134 tst: l 0.516 a 0.839 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.107sec\n",
      "Epoch 135 tr: l 0.402 a 0.862 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.005083 28.396sec(train) 8.885sec(infer)\n",
      "Epoch 135 tst: l 0.515 a 0.839 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  1.732sec\n",
      "Epoch 136 tr: l 0.402 a 0.862 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.005058 25.698sec(train) 11.258sec(infer)\n",
      "Epoch 136 tst: l 0.515 a 0.839 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.125sec\n",
      "Epoch 137 tr: l 0.402 a 0.862 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.005032 23.859sec(train) 10.285sec(infer)\n",
      "Epoch 137 tst: l 0.515 a 0.839 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.359sec\n",
      "Epoch 138 tr: l 0.401 a 0.863 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.005007 27.531sec(train) 8.343sec(infer)\n",
      "Epoch 138 tst: l 0.515 a 0.839 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  1.912sec\n",
      "Epoch 139 tr: l 0.401 a 0.863 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.004982 27.767sec(train) 10.116sec(infer)\n",
      "Epoch 139 tst: l 0.515 a 0.839 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  1.998sec\n",
      "Epoch 140 tr: l 0.401 a 0.863 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.004957 24.775sec(train) 11.129sec(infer)\n",
      "Epoch 140 tst: l 0.514 a 0.839 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.378sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 141 tr: l 0.401 a 0.863 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.004932 25.197sec(train) 9.604sec(infer)\n",
      "Epoch 141 tst: l 0.514 a 0.839 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.098sec\n",
      "Epoch 142 tr: l 0.400 a 0.863 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.004908 27.741sec(train) 9.135sec(infer)\n",
      "Epoch 142 tst: l 0.514 a 0.839 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  1.813sec\n",
      "Epoch 143 tr: l 0.400 a 0.863 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.004883 25.743sec(train) 10.801sec(infer)\n",
      "Epoch 143 tst: l 0.514 a 0.840 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.042sec\n",
      "Epoch 144 tr: l 0.400 a 0.863 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.004859 24.918sec(train) 10.227sec(infer)\n",
      "Epoch 144 tst: l 0.514 a 0.840 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.322sec\n",
      "Epoch 145 tr: l 0.400 a 0.863 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.004834 26.731sec(train) 8.844sec(infer)\n",
      "Epoch 145 tst: l 0.513 a 0.840 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.001sec\n",
      "Epoch 146 tr: l 0.399 a 0.863 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.004810 27.575sec(train) 9.803sec(infer)\n",
      "Epoch 146 tst: l 0.513 a 0.840 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.035sec\n",
      "Epoch 147 tr: l 0.399 a 0.863 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.004786 25.017sec(train) 11.106sec(infer)\n",
      "Epoch 147 tst: l 0.513 a 0.840 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.278sec\n",
      "Epoch 148 tr: l 0.399 a 0.863 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.004762 25.121sec(train) 9.871sec(infer)\n",
      "Epoch 148 tst: l 0.513 a 0.840 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  2.121sec\n",
      "Epoch 149 tr: l 0.399 a 0.863 clct[np.int64(99), np.int64(50), np.int64(49), np.int64(2)] cl_acc 0.750  lr 0.004738 27.419sec(train) 9.414sec(infer)\n",
      "Epoch 149 tst: l 0.513 a 0.840 clct[np.int64(20), np.int64(10), np.int64(10), np.int64(0)] cl_acc 0.750  1.760sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "---train cluster Ended in 1.60 hour (5749.315 sec) \n",
      "---------------------------------IFCA, lr: 0.1, seed: 4012---------------------------------\n",
      "config: {'m': 200, 'm_test': 40, 'p': 4, 'n': 1500, 'uneven': True, 'local_model_init': False, 'Gp': 0.15, 'graph': 'er', 'agg': 'seq', '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:2\n",
      "Epoch -1 tr: l 3.868 a 0.022 clct[np.int64(65), np.int64(60), np.int64(51), np.int64(24)] cl_acc 0.555  9.901sec\n",
      "Epoch -1 tst: l 3.873 a 0.021 clct[np.int64(12), np.int64(15), np.int64(10), np.int64(3)] cl_acc 0.525  2.048sec\n",
      "Epoch 0 tr: l 3.397 a 0.206 clct[np.int64(48), np.int64(52), np.int64(50), np.int64(50)] cl_acc 0.990  lr 0.100000 27.239sec(train) 9.621sec(infer)\n",
      "Epoch 0 tst: l 3.402 a 0.203 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.712sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 1 tr: l 2.498 a 0.509 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.099500 26.444sec(train) 10.440sec(infer)\n",
      "Epoch 1 tst: l 2.511 a 0.503 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.963sec\n",
      "Epoch 2 tr: l 1.820 a 0.617 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.099003 25.250sec(train) 10.264sec(infer)\n",
      "Epoch 2 tst: l 1.841 a 0.611 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.267sec\n",
      "Epoch 3 tr: l 1.430 a 0.667 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.098507 26.719sec(train) 9.469sec(infer)\n",
      "Epoch 3 tst: l 1.455 a 0.663 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.929sec\n",
      "Epoch 4 tr: l 1.215 a 0.691 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.098015 27.190sec(train) 9.894sec(infer)\n",
      "Epoch 4 tst: l 1.244 a 0.686 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.054sec\n",
      "Epoch 5 tr: l 1.105 a 0.698 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.097525 25.578sec(train) 10.923sec(infer)\n",
      "Epoch 5 tst: l 1.137 a 0.692 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.931sec\n",
      "Epoch 6 tr: l 0.998 a 0.721 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.097037 25.559sec(train) 9.976sec(infer)\n",
      "Epoch 6 tst: l 1.032 a 0.714 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.037sec\n",
      "Epoch 7 tr: l 0.905 a 0.744 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.096552 26.659sec(train) 9.834sec(infer)\n",
      "Epoch 7 tst: l 0.943 a 0.736 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.953sec\n",
      "Epoch 8 tr: l 0.848 a 0.755 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.096069 26.733sec(train) 10.016sec(infer)\n",
      "Epoch 8 tst: l 0.886 a 0.746 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.981sec\n",
      "Epoch 9 tr: l 0.800 a 0.766 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.095589 25.551sec(train) 10.485sec(infer)\n",
      "Epoch 9 tst: l 0.841 a 0.759 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.282sec\n",
      "Epoch 10 tr: l 0.758 a 0.774 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.095111 26.145sec(train) 9.781sec(infer)\n",
      "Epoch 10 tst: l 0.799 a 0.766 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.960sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 11 tr: l 0.728 a 0.782 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.094635 26.680sec(train) 10.026sec(infer)\n",
      "Epoch 11 tst: l 0.772 a 0.774 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.030sec\n",
      "Epoch 12 tr: l 0.696 a 0.789 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.094162 25.916sec(train) 10.627sec(infer)\n",
      "Epoch 12 tst: l 0.741 a 0.779 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.954sec\n",
      "Epoch 13 tr: l 0.671 a 0.796 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.093691 26.047sec(train) 10.034sec(infer)\n",
      "Epoch 13 tst: l 0.718 a 0.785 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.016sec\n",
      "Epoch 14 tr: l 0.649 a 0.800 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.093223 26.551sec(train) 9.952sec(infer)\n",
      "Epoch 14 tst: l 0.697 a 0.790 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.905sec\n",
      "Epoch 15 tr: l 0.631 a 0.804 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.092757 26.609sec(train) 9.979sec(infer)\n",
      "Epoch 15 tst: l 0.680 a 0.793 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.980sec\n",
      "Epoch 16 tr: l 0.616 a 0.808 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.092293 25.994sec(train) 10.522sec(infer)\n",
      "Epoch 16 tst: l 0.666 a 0.798 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.982sec\n",
      "Epoch 17 tr: l 0.600 a 0.812 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.091832 26.764sec(train) 9.973sec(infer)\n",
      "Epoch 17 tst: l 0.652 a 0.800 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.941sec\n",
      "Epoch 18 tr: l 0.586 a 0.815 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.091372 26.511sec(train) 10.221sec(infer)\n",
      "Epoch 18 tst: l 0.639 a 0.805 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.782sec\n",
      "Epoch 19 tr: l 0.575 a 0.818 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.090916 25.866sec(train) 9.958sec(infer)\n",
      "Epoch 19 tst: l 0.629 a 0.807 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.955sec\n",
      "Epoch 20 tr: l 0.562 a 0.821 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.090461 26.275sec(train) 10.028sec(infer)\n",
      "Epoch 20 tst: l 0.617 a 0.809 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.071sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 21 tr: l 0.553 a 0.823 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.090009 26.840sec(train) 10.045sec(infer)\n",
      "Epoch 21 tst: l 0.609 a 0.811 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.919sec\n",
      "Epoch 22 tr: l 0.542 a 0.826 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.089559 26.314sec(train) 10.001sec(infer)\n",
      "Epoch 22 tst: l 0.599 a 0.813 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.035sec\n",
      "Epoch 23 tr: l 0.533 a 0.827 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.089111 26.374sec(train) 10.193sec(infer)\n",
      "Epoch 23 tst: l 0.591 a 0.815 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.955sec\n",
      "Epoch 24 tr: l 0.524 a 0.830 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.088665 26.340sec(train) 9.975sec(infer)\n",
      "Epoch 24 tst: l 0.584 a 0.817 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.932sec\n",
      "Epoch 25 tr: l 0.516 a 0.832 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.088222 26.353sec(train) 10.424sec(infer)\n",
      "Epoch 25 tst: l 0.576 a 0.818 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.929sec\n",
      "Epoch 26 tr: l 0.509 a 0.834 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.087781 26.439sec(train) 9.955sec(infer)\n",
      "Epoch 26 tst: l 0.570 a 0.820 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.999sec\n",
      "Epoch 27 tr: l 0.501 a 0.836 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.087342 26.296sec(train) 10.163sec(infer)\n",
      "Epoch 27 tst: l 0.563 a 0.820 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.058sec\n",
      "Epoch 28 tr: l 0.495 a 0.838 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.086905 26.203sec(train) 10.243sec(infer)\n",
      "Epoch 28 tst: l 0.558 a 0.822 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.922sec\n",
      "Epoch 29 tr: l 0.489 a 0.838 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.086471 26.248sec(train) 10.145sec(infer)\n",
      "Epoch 29 tst: l 0.553 a 0.823 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.070sec\n",
      "Epoch 30 tr: l 0.487 a 0.838 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.086038 26.419sec(train) 10.269sec(infer)\n",
      "Epoch 30 tst: l 0.553 a 0.824 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.955sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 31 tr: l 0.480 a 0.840 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.085608 26.734sec(train) 10.028sec(infer)\n",
      "Epoch 31 tst: l 0.545 a 0.825 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.984sec\n",
      "Epoch 32 tr: l 0.475 a 0.842 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.085180 26.173sec(train) 10.558sec(infer)\n",
      "Epoch 32 tst: l 0.542 a 0.826 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.979sec\n",
      "Epoch 33 tr: l 0.468 a 0.843 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.084754 26.021sec(train) 9.926sec(infer)\n",
      "Epoch 33 tst: l 0.536 a 0.827 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.951sec\n",
      "Epoch 34 tr: l 0.464 a 0.845 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.084331 26.521sec(train) 10.242sec(infer)\n",
      "Epoch 34 tst: l 0.533 a 0.829 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.934sec\n",
      "Epoch 35 tr: l 0.458 a 0.846 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.083909 26.417sec(train) 10.292sec(infer)\n",
      "Epoch 35 tst: l 0.528 a 0.830 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.900sec\n",
      "Epoch 36 tr: l 0.454 a 0.848 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.083489 26.575sec(train) 10.277sec(infer)\n",
      "Epoch 36 tst: l 0.525 a 0.831 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.064sec\n",
      "Epoch 37 tr: l 0.448 a 0.849 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.083072 26.060sec(train) 9.885sec(infer)\n",
      "Epoch 37 tst: l 0.520 a 0.832 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.959sec\n",
      "Epoch 38 tr: l 0.444 a 0.851 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.082657 25.732sec(train) 9.923sec(infer)\n",
      "Epoch 38 tst: l 0.517 a 0.833 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.027sec\n",
      "Epoch 39 tr: l 0.440 a 0.851 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.082243 25.719sec(train) 10.224sec(infer)\n",
      "Epoch 39 tst: l 0.513 a 0.834 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.937sec\n",
      "Epoch 40 tr: l 0.436 a 0.853 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.081832 25.813sec(train) 9.840sec(infer)\n",
      "Epoch 40 tst: l 0.511 a 0.835 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.000sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 41 tr: l 0.432 a 0.853 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.081423 26.504sec(train) 10.136sec(infer)\n",
      "Epoch 41 tst: l 0.507 a 0.835 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.873sec\n",
      "Epoch 42 tr: l 0.429 a 0.855 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.081016 26.418sec(train) 9.954sec(infer)\n",
      "Epoch 42 tst: l 0.505 a 0.836 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.960sec\n",
      "Epoch 43 tr: l 0.425 a 0.855 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.080611 26.356sec(train) 10.242sec(infer)\n",
      "Epoch 43 tst: l 0.501 a 0.836 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.089sec\n",
      "Epoch 44 tr: l 0.421 a 0.857 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.080208 26.364sec(train) 10.168sec(infer)\n",
      "Epoch 44 tst: l 0.499 a 0.838 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.981sec\n",
      "Epoch 45 tr: l 0.418 a 0.857 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.079807 26.729sec(train) 10.082sec(infer)\n",
      "Epoch 45 tst: l 0.496 a 0.838 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.069sec\n",
      "Epoch 46 tr: l 0.415 a 0.858 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.079408 26.367sec(train) 10.292sec(infer)\n",
      "Epoch 46 tst: l 0.494 a 0.839 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.961sec\n",
      "Epoch 47 tr: l 0.412 a 0.859 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.079010 26.556sec(train) 9.974sec(infer)\n",
      "Epoch 47 tst: l 0.491 a 0.839 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.059sec\n",
      "Epoch 48 tr: l 0.409 a 0.860 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.078615 26.499sec(train) 10.085sec(infer)\n",
      "Epoch 48 tst: l 0.490 a 0.841 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.003sec\n",
      "Epoch 49 tr: l 0.406 a 0.861 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.078222 26.289sec(train) 10.040sec(infer)\n",
      "Epoch 49 tst: l 0.487 a 0.840 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.032sec\n",
      "Epoch 50 tr: l 0.403 a 0.862 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.077831 26.309sec(train) 10.339sec(infer)\n",
      "Epoch 50 tst: l 0.485 a 0.842 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.270sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 51 tr: l 0.400 a 0.862 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.077442 26.209sec(train) 9.962sec(infer)\n",
      "Epoch 51 tst: l 0.483 a 0.841 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.954sec\n",
      "Epoch 52 tr: l 0.397 a 0.863 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.077055 26.632sec(train) 10.137sec(infer)\n",
      "Epoch 52 tst: l 0.481 a 0.843 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.070sec\n",
      "Epoch 53 tr: l 0.395 a 0.863 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.076670 26.314sec(train) 10.391sec(infer)\n",
      "Epoch 53 tst: l 0.479 a 0.843 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.945sec\n",
      "Epoch 54 tr: l 0.393 a 0.864 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.076286 26.251sec(train) 10.083sec(infer)\n",
      "Epoch 54 tst: l 0.478 a 0.843 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.045sec\n",
      "Epoch 55 tr: l 0.392 a 0.864 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.075905 26.884sec(train) 10.174sec(infer)\n",
      "Epoch 55 tst: l 0.478 a 0.843 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.987sec\n",
      "Epoch 56 tr: l 0.389 a 0.865 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.075525 26.513sec(train) 9.990sec(infer)\n",
      "Epoch 56 tst: l 0.475 a 0.844 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.964sec\n",
      "Epoch 57 tr: l 0.386 a 0.866 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.075148 26.339sec(train) 10.527sec(infer)\n",
      "Epoch 57 tst: l 0.473 a 0.844 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.988sec\n",
      "Epoch 58 tr: l 0.383 a 0.867 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.074772 26.312sec(train) 10.003sec(infer)\n",
      "Epoch 58 tst: l 0.471 a 0.845 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.998sec\n",
      "Epoch 59 tr: l 0.381 a 0.867 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.074398 26.399sec(train) 10.170sec(infer)\n",
      "Epoch 59 tst: l 0.470 a 0.845 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.996sec\n",
      "Epoch 60 tr: l 0.379 a 0.868 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.074026 26.198sec(train) 10.421sec(infer)\n",
      "Epoch 60 tst: l 0.468 a 0.846 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.964sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 61 tr: l 0.377 a 0.868 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.073656 26.317sec(train) 10.111sec(infer)\n",
      "Epoch 61 tst: l 0.467 a 0.846 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.086sec\n",
      "Epoch 62 tr: l 0.374 a 0.869 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.073288 26.296sec(train) 10.187sec(infer)\n",
      "Epoch 62 tst: l 0.465 a 0.846 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.972sec\n",
      "Epoch 63 tr: l 0.372 a 0.869 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.072921 26.476sec(train) 9.940sec(infer)\n",
      "Epoch 63 tst: l 0.464 a 0.847 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.969sec\n",
      "Epoch 64 tr: l 0.370 a 0.870 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.072557 25.760sec(train) 10.608sec(infer)\n",
      "Epoch 64 tst: l 0.462 a 0.847 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.977sec\n",
      "Epoch 65 tr: l 0.368 a 0.871 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.072194 26.162sec(train) 9.608sec(infer)\n",
      "Epoch 65 tst: l 0.461 a 0.848 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.981sec\n",
      "Epoch 66 tr: l 0.367 a 0.871 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.071833 26.502sec(train) 10.294sec(infer)\n",
      "Epoch 66 tst: l 0.460 a 0.847 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.026sec\n",
      "Epoch 67 tr: l 0.365 a 0.871 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.071474 26.282sec(train) 10.156sec(infer)\n",
      "Epoch 67 tst: l 0.459 a 0.848 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.914sec\n",
      "Epoch 68 tr: l 0.363 a 0.872 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.071116 25.983sec(train) 10.154sec(infer)\n",
      "Epoch 68 tst: l 0.458 a 0.848 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.032sec\n",
      "Epoch 69 tr: l 0.361 a 0.873 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.070761 26.199sec(train) 10.137sec(infer)\n",
      "Epoch 69 tst: l 0.456 a 0.849 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.875sec\n",
      "Epoch 70 tr: l 0.359 a 0.873 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.070407 26.464sec(train) 10.003sec(infer)\n",
      "Epoch 70 tst: l 0.455 a 0.848 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.044sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 71 tr: l 0.358 a 0.874 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.070055 26.531sec(train) 10.172sec(infer)\n",
      "Epoch 71 tst: l 0.454 a 0.849 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.003sec\n",
      "Epoch 72 tr: l 0.357 a 0.873 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.069705 26.184sec(train) 9.910sec(infer)\n",
      "Epoch 72 tst: l 0.455 a 0.848 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.976sec\n",
      "Epoch 73 tr: l 0.355 a 0.874 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.069356 26.080sec(train) 10.308sec(infer)\n",
      "Epoch 73 tst: l 0.453 a 0.849 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.059sec\n",
      "Epoch 74 tr: l 0.354 a 0.874 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.069009 26.723sec(train) 9.850sec(infer)\n",
      "Epoch 74 tst: l 0.452 a 0.849 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.992sec\n",
      "Epoch 75 tr: l 0.351 a 0.876 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.068664 26.223sec(train) 10.132sec(infer)\n",
      "Epoch 75 tst: l 0.450 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.030sec\n",
      "Epoch 76 tr: l 0.350 a 0.875 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.068321 26.345sec(train) 10.374sec(infer)\n",
      "Epoch 76 tst: l 0.449 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.993sec\n",
      "Epoch 77 tr: l 0.348 a 0.877 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.067979 25.966sec(train) 10.166sec(infer)\n",
      "Epoch 77 tst: l 0.448 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.043sec\n",
      "Epoch 78 tr: l 0.346 a 0.877 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.067639 27.088sec(train) 10.237sec(infer)\n",
      "Epoch 78 tst: l 0.447 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.916sec\n",
      "Epoch 79 tr: l 0.344 a 0.877 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.067301 26.204sec(train) 10.000sec(infer)\n",
      "Epoch 79 tst: l 0.446 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.027sec\n",
      "Epoch 80 tr: l 0.343 a 0.878 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.066965 25.876sec(train) 10.615sec(infer)\n",
      "Epoch 80 tst: l 0.445 a 0.852 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.185sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 81 tr: l 0.341 a 0.878 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.066630 26.164sec(train) 9.745sec(infer)\n",
      "Epoch 81 tst: l 0.444 a 0.852 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.919sec\n",
      "Epoch 82 tr: l 0.340 a 0.879 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.066297 26.279sec(train) 10.306sec(infer)\n",
      "Epoch 82 tst: l 0.443 a 0.852 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.096sec\n",
      "Epoch 83 tr: l 0.338 a 0.879 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.065965 26.182sec(train) 10.494sec(infer)\n",
      "Epoch 83 tst: l 0.442 a 0.852 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.025sec\n",
      "Epoch 84 tr: l 0.337 a 0.880 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.065635 26.041sec(train) 10.074sec(infer)\n",
      "Epoch 84 tst: l 0.441 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.166sec\n",
      "Epoch 85 tr: l 0.336 a 0.880 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.065307 26.506sec(train) 10.263sec(infer)\n",
      "Epoch 85 tst: l 0.441 a 0.852 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.151sec\n",
      "Epoch 86 tr: l 0.334 a 0.880 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064981 26.310sec(train) 9.960sec(infer)\n",
      "Epoch 86 tst: l 0.440 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.992sec\n",
      "Epoch 87 tr: l 0.333 a 0.881 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064656 26.358sec(train) 10.355sec(infer)\n",
      "Epoch 87 tst: l 0.439 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.986sec\n",
      "Epoch 88 tr: l 0.332 a 0.881 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064333 26.776sec(train) 9.941sec(infer)\n",
      "Epoch 88 tst: l 0.439 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.988sec\n",
      "Epoch 89 tr: l 0.331 a 0.881 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064011 26.392sec(train) 10.191sec(infer)\n",
      "Epoch 89 tst: l 0.438 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.091sec\n",
      "Epoch 90 tr: l 0.329 a 0.882 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.063691 26.215sec(train) 9.985sec(infer)\n",
      "Epoch 90 tst: l 0.437 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.950sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 91 tr: l 0.328 a 0.882 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.063372 25.890sec(train) 10.071sec(infer)\n",
      "Epoch 91 tst: l 0.437 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.047sec\n",
      "Epoch 92 tr: l 0.327 a 0.882 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.063056 26.305sec(train) 10.280sec(infer)\n",
      "Epoch 92 tst: l 0.436 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.994sec\n",
      "Epoch 93 tr: l 0.326 a 0.882 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.062740 26.882sec(train) 10.068sec(infer)\n",
      "Epoch 93 tst: l 0.436 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.962sec\n",
      "Epoch 94 tr: l 0.325 a 0.883 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.062427 26.249sec(train) 10.369sec(infer)\n",
      "Epoch 94 tst: l 0.435 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.011sec\n",
      "Epoch 95 tr: l 0.323 a 0.883 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.062114 26.338sec(train) 9.793sec(infer)\n",
      "Epoch 95 tst: l 0.434 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.938sec\n",
      "Epoch 96 tr: l 0.322 a 0.884 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.061804 26.247sec(train) 10.189sec(infer)\n",
      "Epoch 96 tst: l 0.433 a 0.855 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.983sec\n",
      "Epoch 97 tr: l 0.321 a 0.884 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.061495 26.570sec(train) 10.025sec(infer)\n",
      "Epoch 97 tst: l 0.433 a 0.855 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.017sec\n",
      "Epoch 98 tr: l 0.320 a 0.884 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.061187 25.602sec(train) 10.610sec(infer)\n",
      "Epoch 98 tst: l 0.432 a 0.855 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.065sec\n",
      "Epoch 99 tr: l 0.318 a 0.885 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.060881 25.470sec(train) 10.689sec(infer)\n",
      "Epoch 99 tst: l 0.432 a 0.855 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.038sec\n",
      "Epoch 100 tr: l 0.318 a 0.885 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.006058 25.580sec(train) 10.403sec(infer)\n",
      "Epoch 100 tst: l 0.431 a 0.855 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.260sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 101 tr: l 0.317 a 0.885 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.006027 25.488sec(train) 10.986sec(infer)\n",
      "Epoch 101 tst: l 0.430 a 0.855 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.740sec\n",
      "Epoch 102 tr: l 0.317 a 0.885 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005997 26.197sec(train) 10.676sec(infer)\n",
      "Epoch 102 tst: l 0.430 a 0.855 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.187sec\n",
      "Epoch 103 tr: l 0.317 a 0.886 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005967 25.029sec(train) 10.743sec(infer)\n",
      "Epoch 103 tst: l 0.430 a 0.855 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.975sec\n",
      "Epoch 104 tr: l 0.317 a 0.886 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005937 26.121sec(train) 9.566sec(infer)\n",
      "Epoch 104 tst: l 0.430 a 0.855 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.200sec\n",
      "Epoch 105 tr: l 0.317 a 0.886 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005908 26.139sec(train) 10.962sec(infer)\n",
      "Epoch 105 tst: l 0.430 a 0.855 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.077sec\n",
      "Epoch 106 tr: l 0.316 a 0.886 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005878 25.064sec(train) 10.993sec(infer)\n",
      "Epoch 106 tst: l 0.430 a 0.855 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.029sec\n",
      "Epoch 107 tr: l 0.316 a 0.886 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005849 25.779sec(train) 9.561sec(infer)\n",
      "Epoch 107 tst: l 0.430 a 0.855 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.149sec\n",
      "Epoch 108 tr: l 0.316 a 0.886 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005820 26.047sec(train) 10.522sec(infer)\n",
      "Epoch 108 tst: l 0.430 a 0.855 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.176sec\n",
      "Epoch 109 tr: l 0.316 a 0.886 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005790 24.714sec(train) 10.585sec(infer)\n",
      "Epoch 109 tst: l 0.430 a 0.855 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.023sec\n",
      "Epoch 110 tr: l 0.316 a 0.886 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005762 25.059sec(train) 10.020sec(infer)\n",
      "Epoch 110 tst: l 0.430 a 0.855 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.240sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 111 tr: l 0.316 a 0.886 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005733 25.979sec(train) 10.421sec(infer)\n",
      "Epoch 111 tst: l 0.430 a 0.855 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.484sec\n",
      "Epoch 112 tr: l 0.316 a 0.886 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005704 26.339sec(train) 10.597sec(infer)\n",
      "Epoch 112 tst: l 0.430 a 0.855 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.331sec\n",
      "Epoch 113 tr: l 0.315 a 0.886 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005676 24.758sec(train) 10.657sec(infer)\n",
      "Epoch 113 tst: l 0.430 a 0.855 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.200sec\n",
      "Epoch 114 tr: l 0.315 a 0.886 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005647 26.142sec(train) 9.960sec(infer)\n",
      "Epoch 114 tst: l 0.429 a 0.855 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.982sec\n",
      "Epoch 115 tr: l 0.315 a 0.886 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005619 25.916sec(train) 10.103sec(infer)\n",
      "Epoch 115 tst: l 0.429 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.016sec\n",
      "Epoch 116 tr: l 0.315 a 0.886 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005591 24.825sec(train) 11.235sec(infer)\n",
      "Epoch 116 tst: l 0.429 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.974sec\n",
      "Epoch 117 tr: l 0.315 a 0.886 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005563 25.940sec(train) 9.470sec(infer)\n",
      "Epoch 117 tst: l 0.429 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.123sec\n",
      "Epoch 118 tr: l 0.315 a 0.886 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005535 25.437sec(train) 10.803sec(infer)\n",
      "Epoch 118 tst: l 0.429 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.278sec\n",
      "Epoch 119 tr: l 0.315 a 0.886 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005507 25.752sec(train) 10.536sec(infer)\n",
      "Epoch 119 tst: l 0.429 a 0.855 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.019sec\n",
      "Epoch 120 tr: l 0.314 a 0.886 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005480 25.516sec(train) 10.511sec(infer)\n",
      "Epoch 120 tst: l 0.429 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.902sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 121 tr: l 0.314 a 0.886 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005452 25.438sec(train) 10.439sec(infer)\n",
      "Epoch 121 tst: l 0.429 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.161sec\n",
      "Epoch 122 tr: l 0.314 a 0.886 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005425 26.810sec(train) 9.484sec(infer)\n",
      "Epoch 122 tst: l 0.429 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.119sec\n",
      "Epoch 123 tr: l 0.314 a 0.886 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005398 25.275sec(train) 10.776sec(infer)\n",
      "Epoch 123 tst: l 0.429 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.229sec\n",
      "Epoch 124 tr: l 0.314 a 0.886 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005371 25.782sec(train) 10.125sec(infer)\n",
      "Epoch 124 tst: l 0.429 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.095sec\n",
      "Epoch 125 tr: l 0.314 a 0.886 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005344 25.012sec(train) 10.611sec(infer)\n",
      "Epoch 125 tst: l 0.429 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.042sec\n",
      "Epoch 126 tr: l 0.314 a 0.886 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005318 26.410sec(train) 10.389sec(infer)\n",
      "Epoch 126 tst: l 0.429 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.616sec\n",
      "Epoch 127 tr: l 0.314 a 0.886 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005291 25.854sec(train) 10.482sec(infer)\n",
      "Epoch 127 tst: l 0.429 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.059sec\n",
      "Epoch 128 tr: l 0.314 a 0.887 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005264 25.000sec(train) 10.851sec(infer)\n",
      "Epoch 128 tst: l 0.429 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.214sec\n",
      "Epoch 129 tr: l 0.313 a 0.887 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005238 26.029sec(train) 10.015sec(infer)\n",
      "Epoch 129 tst: l 0.429 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.016sec\n",
      "Epoch 130 tr: l 0.313 a 0.887 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005212 25.744sec(train) 10.706sec(infer)\n",
      "Epoch 130 tst: l 0.429 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.183sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 131 tr: l 0.313 a 0.887 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005186 26.066sec(train) 10.850sec(infer)\n",
      "Epoch 131 tst: l 0.429 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.984sec\n",
      "Epoch 132 tr: l 0.313 a 0.887 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005160 25.690sec(train) 11.029sec(infer)\n",
      "Epoch 132 tst: l 0.428 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.030sec\n",
      "Epoch 133 tr: l 0.313 a 0.887 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005134 25.662sec(train) 10.964sec(infer)\n",
      "Epoch 133 tst: l 0.428 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.165sec\n",
      "Epoch 134 tr: l 0.313 a 0.887 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005108 25.610sec(train) 10.016sec(infer)\n",
      "Epoch 134 tst: l 0.428 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.054sec\n",
      "Epoch 135 tr: l 0.313 a 0.887 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005083 25.186sec(train) 10.366sec(infer)\n",
      "Epoch 135 tst: l 0.428 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.274sec\n",
      "Epoch 136 tr: l 0.313 a 0.887 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005058 26.551sec(train) 10.217sec(infer)\n",
      "Epoch 136 tst: l 0.428 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.095sec\n",
      "Epoch 137 tr: l 0.312 a 0.887 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005032 25.488sec(train) 10.675sec(infer)\n",
      "Epoch 137 tst: l 0.428 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.070sec\n",
      "Epoch 138 tr: l 0.312 a 0.887 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005007 26.161sec(train) 10.814sec(infer)\n",
      "Epoch 138 tst: l 0.428 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.626sec\n",
      "Epoch 139 tr: l 0.312 a 0.887 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004982 25.946sec(train) 9.733sec(infer)\n",
      "Epoch 139 tst: l 0.428 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.158sec\n",
      "Epoch 140 tr: l 0.312 a 0.887 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004957 25.527sec(train) 10.890sec(infer)\n",
      "Epoch 140 tst: l 0.428 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.189sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 141 tr: l 0.312 a 0.887 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004932 26.107sec(train) 10.493sec(infer)\n",
      "Epoch 141 tst: l 0.428 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.995sec\n",
      "Epoch 142 tr: l 0.312 a 0.887 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004908 25.733sec(train) 10.605sec(infer)\n",
      "Epoch 142 tst: l 0.428 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.111sec\n",
      "Epoch 143 tr: l 0.312 a 0.887 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004883 25.700sec(train) 10.624sec(infer)\n",
      "Epoch 143 tst: l 0.428 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.017sec\n",
      "Epoch 144 tr: l 0.312 a 0.887 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004859 25.311sec(train) 10.424sec(infer)\n",
      "Epoch 144 tst: l 0.428 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.009sec\n",
      "Epoch 145 tr: l 0.312 a 0.887 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004834 25.649sec(train) 10.967sec(infer)\n",
      "Epoch 145 tst: l 0.428 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.168sec\n",
      "Epoch 146 tr: l 0.312 a 0.887 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004810 25.693sec(train) 10.188sec(infer)\n",
      "Epoch 146 tst: l 0.428 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.012sec\n",
      "Epoch 147 tr: l 0.311 a 0.887 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004786 25.043sec(train) 10.655sec(infer)\n",
      "Epoch 147 tst: l 0.428 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.960sec\n",
      "Epoch 148 tr: l 0.311 a 0.887 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004762 26.032sec(train) 10.922sec(infer)\n",
      "Epoch 148 tst: l 0.428 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.985sec\n",
      "Epoch 149 tr: l 0.311 a 0.887 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004738 25.621sec(train) 10.725sec(infer)\n",
      "Epoch 149 tst: l 0.428 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.065sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "---train cluster Ended in 1.60 hour (5771.610 sec) \n",
      "---------------------------------IFCA, lr: 0.1, seed: 3657---------------------------------\n",
      "config: {'m': 200, 'm_test': 40, 'p': 4, 'n': 1500, 'uneven': True, 'local_model_init': False, 'Gp': 0.15, 'graph': 'er', 'agg': 'seq', '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:2\n",
      "Epoch -1 tr: l 3.856 a 0.022 clct[np.int64(63), np.int64(6), np.int64(130), np.int64(1)] cl_acc 0.480  10.629sec\n",
      "Epoch -1 tst: l 3.858 a 0.023 clct[np.int64(11), np.int64(0), np.int64(29), np.int64(0)] cl_acc 0.475  2.283sec\n",
      "Epoch 0 tr: l 3.419 a 0.183 clct[np.int64(49), np.int64(53), np.int64(50), np.int64(48)] cl_acc 0.985  lr 0.100000 25.265sec(train) 10.153sec(infer)\n",
      "Epoch 0 tst: l 3.444 a 0.183 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.124sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 1 tr: l 2.478 a 0.482 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.099500 26.530sec(train) 10.775sec(infer)\n",
      "Epoch 1 tst: l 2.502 a 0.476 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.684sec\n",
      "Epoch 2 tr: l 1.822 a 0.605 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.099003 26.125sec(train) 10.332sec(infer)\n",
      "Epoch 2 tst: l 1.852 a 0.602 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.368sec\n",
      "Epoch 3 tr: l 1.444 a 0.659 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.098507 25.175sec(train) 10.534sec(infer)\n",
      "Epoch 3 tst: l 1.477 a 0.654 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.139sec\n",
      "Epoch 4 tr: l 1.254 a 0.677 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.098015 25.431sec(train) 10.201sec(infer)\n",
      "Epoch 4 tst: l 1.292 a 0.672 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.949sec\n",
      "Epoch 5 tr: l 1.132 a 0.689 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.097525 25.760sec(train) 10.681sec(infer)\n",
      "Epoch 5 tst: l 1.171 a 0.682 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.037sec\n",
      "Epoch 6 tr: l 1.017 a 0.718 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.097037 25.141sec(train) 10.780sec(infer)\n",
      "Epoch 6 tst: l 1.058 a 0.711 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.051sec\n",
      "Epoch 7 tr: l 0.927 a 0.736 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.096552 25.717sec(train) 10.051sec(infer)\n",
      "Epoch 7 tst: l 0.968 a 0.729 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.125sec\n",
      "Epoch 8 tr: l 0.868 a 0.751 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.096069 25.436sec(train) 10.856sec(infer)\n",
      "Epoch 8 tst: l 0.912 a 0.744 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.229sec\n",
      "Epoch 9 tr: l 0.812 a 0.763 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.095589 26.116sec(train) 9.609sec(infer)\n",
      "Epoch 9 tst: l 0.856 a 0.756 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.072sec\n",
      "Epoch 10 tr: l 0.773 a 0.773 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.095111 26.008sec(train) 10.461sec(infer)\n",
      "Epoch 10 tst: l 0.819 a 0.765 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.318sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 11 tr: l 0.734 a 0.781 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.094635 24.814sec(train) 10.718sec(infer)\n",
      "Epoch 11 tst: l 0.781 a 0.773 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.084sec\n",
      "Epoch 12 tr: l 0.709 a 0.787 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.094162 25.994sec(train) 10.173sec(infer)\n",
      "Epoch 12 tst: l 0.757 a 0.779 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.227sec\n",
      "Epoch 13 tr: l 0.680 a 0.794 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.093691 26.149sec(train) 11.332sec(infer)\n",
      "Epoch 13 tst: l 0.729 a 0.785 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.226sec\n",
      "Epoch 14 tr: l 0.663 a 0.798 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.093223 25.414sec(train) 10.104sec(infer)\n",
      "Epoch 14 tst: l 0.714 a 0.787 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.102sec\n",
      "Epoch 15 tr: l 0.641 a 0.802 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.092757 25.727sec(train) 11.062sec(infer)\n",
      "Epoch 15 tst: l 0.692 a 0.793 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.220sec\n",
      "Epoch 16 tr: l 0.625 a 0.806 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.092293 25.638sec(train) 10.469sec(infer)\n",
      "Epoch 16 tst: l 0.679 a 0.796 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.105sec\n",
      "Epoch 17 tr: l 0.608 a 0.810 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.091832 26.119sec(train) 10.316sec(infer)\n",
      "Epoch 17 tst: l 0.661 a 0.800 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.096sec\n",
      "Epoch 18 tr: l 0.595 a 0.813 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.091372 25.616sec(train) 10.492sec(infer)\n",
      "Epoch 18 tst: l 0.651 a 0.803 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.067sec\n",
      "Epoch 19 tr: l 0.581 a 0.816 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.090916 25.485sec(train) 10.095sec(infer)\n",
      "Epoch 19 tst: l 0.636 a 0.806 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.038sec\n",
      "Epoch 20 tr: l 0.571 a 0.819 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.090461 25.385sec(train) 10.704sec(infer)\n",
      "Epoch 20 tst: l 0.628 a 0.808 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.135sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 21 tr: l 0.559 a 0.821 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.090009 26.444sec(train) 9.853sec(infer)\n",
      "Epoch 21 tst: l 0.617 a 0.810 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.147sec\n",
      "Epoch 22 tr: l 0.550 a 0.824 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.089559 24.632sec(train) 7.200sec(infer)\n",
      "Epoch 22 tst: l 0.609 a 0.811 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.909sec\n",
      "Epoch 23 tr: l 0.539 a 0.827 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.089111 25.249sec(train) 12.541sec(infer)\n",
      "Epoch 23 tst: l 0.599 a 0.815 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.502sec\n",
      "Epoch 24 tr: l 0.531 a 0.829 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.088665 21.967sec(train) 10.501sec(infer)\n",
      "Epoch 24 tst: l 0.592 a 0.816 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.378sec\n",
      "Epoch 25 tr: l 0.522 a 0.831 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.088222 27.815sec(train) 7.757sec(infer)\n",
      "Epoch 25 tst: l 0.583 a 0.819 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.895sec\n",
      "Epoch 26 tr: l 0.515 a 0.832 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.087781 27.090sec(train) 11.707sec(infer)\n",
      "Epoch 26 tst: l 0.578 a 0.820 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.917sec\n",
      "Epoch 27 tr: l 0.507 a 0.834 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.087342 22.409sec(train) 10.101sec(infer)\n",
      "Epoch 27 tst: l 0.571 a 0.822 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.634sec\n",
      "Epoch 28 tr: l 0.503 a 0.835 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.086905 18.253sec(train) 7.289sec(infer)\n",
      "Epoch 28 tst: l 0.569 a 0.822 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.481sec\n",
      "Epoch 29 tr: l 0.495 a 0.837 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.086471 20.992sec(train) 5.785sec(infer)\n",
      "Epoch 29 tst: l 0.560 a 0.825 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.640sec\n",
      "Epoch 30 tr: l 0.489 a 0.838 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.086038 23.947sec(train) 12.309sec(infer)\n",
      "Epoch 30 tst: l 0.556 a 0.825 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.524sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 31 tr: l 0.482 a 0.841 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.085608 23.528sec(train) 9.132sec(infer)\n",
      "Epoch 31 tst: l 0.549 a 0.827 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.035sec\n",
      "Epoch 32 tr: l 0.477 a 0.842 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.085180 29.575sec(train) 7.619sec(infer)\n",
      "Epoch 32 tst: l 0.545 a 0.828 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.801sec\n",
      "Epoch 33 tr: l 0.471 a 0.844 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.084754 24.178sec(train) 12.206sec(infer)\n",
      "Epoch 33 tst: l 0.540 a 0.829 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.507sec\n",
      "Epoch 34 tr: l 0.467 a 0.844 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.084331 23.055sec(train) 9.110sec(infer)\n",
      "Epoch 34 tst: l 0.536 a 0.830 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.139sec\n",
      "Epoch 35 tr: l 0.461 a 0.846 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.083909 29.646sec(train) 7.085sec(infer)\n",
      "Epoch 35 tst: l 0.532 a 0.831 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.895sec\n",
      "Epoch 36 tr: l 0.457 a 0.847 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.083489 24.713sec(train) 12.238sec(infer)\n",
      "Epoch 36 tst: l 0.529 a 0.831 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.542sec\n",
      "Epoch 37 tr: l 0.453 a 0.848 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.083072 23.015sec(train) 9.144sec(infer)\n",
      "Epoch 37 tst: l 0.526 a 0.833 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.453sec\n",
      "Epoch 38 tr: l 0.450 a 0.848 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.082657 29.697sec(train) 6.813sec(infer)\n",
      "Epoch 38 tst: l 0.523 a 0.833 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.793sec\n",
      "Epoch 39 tr: l 0.445 a 0.850 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.082243 24.333sec(train) 12.570sec(infer)\n",
      "Epoch 39 tst: l 0.519 a 0.834 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.437sec\n",
      "Epoch 40 tr: l 0.440 a 0.851 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.081832 22.672sec(train) 9.476sec(infer)\n",
      "Epoch 40 tst: l 0.515 a 0.834 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.509sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 41 tr: l 0.438 a 0.852 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.081423 29.557sec(train) 7.175sec(infer)\n",
      "Epoch 41 tst: l 0.513 a 0.835 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.821sec\n",
      "Epoch 42 tr: l 0.434 a 0.853 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.081016 25.343sec(train) 12.437sec(infer)\n",
      "Epoch 42 tst: l 0.511 a 0.835 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.489sec\n",
      "Epoch 43 tr: l 0.431 a 0.854 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.080611 22.251sec(train) 10.346sec(infer)\n",
      "Epoch 43 tst: l 0.507 a 0.836 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.475sec\n",
      "Epoch 44 tr: l 0.427 a 0.854 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.080208 28.268sec(train) 7.885sec(infer)\n",
      "Epoch 44 tst: l 0.506 a 0.837 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.819sec\n",
      "Epoch 45 tr: l 0.424 a 0.855 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.079807 26.512sec(train) 12.746sec(infer)\n",
      "Epoch 45 tst: l 0.502 a 0.838 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.407sec\n",
      "Epoch 46 tr: l 0.420 a 0.856 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.079408 21.685sec(train) 11.775sec(infer)\n",
      "Epoch 46 tst: l 0.500 a 0.838 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.394sec\n",
      "Epoch 47 tr: l 0.417 a 0.857 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.079010 26.227sec(train) 8.450sec(infer)\n",
      "Epoch 47 tst: l 0.497 a 0.840 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.660sec\n",
      "Epoch 48 tr: l 0.413 a 0.858 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.078615 27.402sec(train) 11.805sec(infer)\n",
      "Epoch 48 tst: l 0.494 a 0.840 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.248sec\n",
      "Epoch 49 tr: l 0.410 a 0.859 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.078222 21.507sec(train) 11.703sec(infer)\n",
      "Epoch 49 tst: l 0.491 a 0.841 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.434sec\n",
      "Epoch 50 tr: l 0.407 a 0.860 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.077831 26.091sec(train) 8.693sec(infer)\n",
      "Epoch 50 tst: l 0.490 a 0.841 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.053sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 51 tr: l 0.405 a 0.861 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.077442 28.797sec(train) 9.964sec(infer)\n",
      "Epoch 51 tst: l 0.487 a 0.842 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  0.877sec\n",
      "Epoch 52 tr: l 0.402 a 0.861 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.077055 21.850sec(train) 12.196sec(infer)\n",
      "Epoch 52 tst: l 0.486 a 0.841 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.452sec\n",
      "Epoch 53 tr: l 0.399 a 0.863 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.076670 25.113sec(train) 9.109sec(infer)\n",
      "Epoch 53 tst: l 0.484 a 0.842 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.782sec\n",
      "Epoch 54 tr: l 0.396 a 0.862 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.076286 28.923sec(train) 9.172sec(infer)\n",
      "Epoch 54 tst: l 0.482 a 0.842 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.310sec\n",
      "Epoch 55 tr: l 0.394 a 0.864 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.075905 22.793sec(train) 12.027sec(infer)\n",
      "Epoch 55 tst: l 0.480 a 0.843 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.345sec\n",
      "Epoch 56 tr: l 0.391 a 0.864 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.075525 24.475sec(train) 9.013sec(infer)\n",
      "Epoch 56 tst: l 0.478 a 0.844 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.956sec\n",
      "Epoch 57 tr: l 0.389 a 0.866 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.075148 28.972sec(train) 8.992sec(infer)\n",
      "Epoch 57 tst: l 0.476 a 0.844 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.502sec\n",
      "Epoch 58 tr: l 0.387 a 0.865 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.074772 23.140sec(train) 12.667sec(infer)\n",
      "Epoch 58 tst: l 0.475 a 0.844 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.672sec\n",
      "Epoch 59 tr: l 0.385 a 0.866 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.074398 23.664sec(train) 8.880sec(infer)\n",
      "Epoch 59 tst: l 0.473 a 0.845 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.028sec\n",
      "Epoch 60 tr: l 0.383 a 0.866 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.074026 29.020sec(train) 8.847sec(infer)\n",
      "Epoch 60 tst: l 0.472 a 0.845 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.710sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 61 tr: l 0.381 a 0.867 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.073656 24.561sec(train) 12.543sec(infer)\n",
      "Epoch 61 tst: l 0.471 a 0.846 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.447sec\n",
      "Epoch 62 tr: l 0.379 a 0.867 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.073288 23.441sec(train) 9.750sec(infer)\n",
      "Epoch 62 tst: l 0.469 a 0.845 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.279sec\n",
      "Epoch 63 tr: l 0.376 a 0.869 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.072921 28.963sec(train) 8.513sec(infer)\n",
      "Epoch 63 tst: l 0.468 a 0.847 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.531sec\n",
      "Epoch 64 tr: l 0.374 a 0.869 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.072557 25.878sec(train) 12.101sec(infer)\n",
      "Epoch 64 tst: l 0.466 a 0.847 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.045sec\n",
      "Epoch 65 tr: l 0.372 a 0.870 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.072194 23.447sec(train) 11.075sec(infer)\n",
      "Epoch 65 tst: l 0.465 a 0.847 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.435sec\n",
      "Epoch 66 tr: l 0.370 a 0.870 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.071833 26.810sec(train) 8.571sec(infer)\n",
      "Epoch 66 tst: l 0.463 a 0.847 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.894sec\n",
      "Epoch 67 tr: l 0.368 a 0.871 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.071474 28.316sec(train) 10.639sec(infer)\n",
      "Epoch 67 tst: l 0.463 a 0.848 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.255sec\n",
      "Epoch 68 tr: l 0.366 a 0.871 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.071116 22.866sec(train) 11.643sec(infer)\n",
      "Epoch 68 tst: l 0.460 a 0.848 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.519sec\n",
      "Epoch 69 tr: l 0.364 a 0.872 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.070761 24.784sec(train) 9.850sec(infer)\n",
      "Epoch 69 tst: l 0.460 a 0.848 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.084sec\n",
      "Epoch 70 tr: l 0.362 a 0.872 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.070407 28.243sec(train) 9.913sec(infer)\n",
      "Epoch 70 tst: l 0.458 a 0.849 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.367sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 71 tr: l 0.360 a 0.873 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.070055 25.097sec(train) 12.518sec(infer)\n",
      "Epoch 71 tst: l 0.458 a 0.849 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.902sec\n",
      "Epoch 72 tr: l 0.359 a 0.873 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.069705 23.879sec(train) 10.753sec(infer)\n",
      "Epoch 72 tst: l 0.456 a 0.849 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.309sec\n",
      "Epoch 73 tr: l 0.357 a 0.874 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.069356 27.368sec(train) 8.951sec(infer)\n",
      "Epoch 73 tst: l 0.455 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.957sec\n",
      "Epoch 74 tr: l 0.355 a 0.874 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.069009 27.459sec(train) 10.823sec(infer)\n",
      "Epoch 74 tst: l 0.454 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.012sec\n",
      "Epoch 75 tr: l 0.354 a 0.875 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.068664 24.289sec(train) 11.558sec(infer)\n",
      "Epoch 75 tst: l 0.453 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.484sec\n",
      "Epoch 76 tr: l 0.352 a 0.875 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.068321 25.501sec(train) 9.626sec(infer)\n",
      "Epoch 76 tst: l 0.452 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.172sec\n",
      "Epoch 77 tr: l 0.350 a 0.876 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.067979 27.696sec(train) 10.249sec(infer)\n",
      "Epoch 77 tst: l 0.451 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.742sec\n",
      "Epoch 78 tr: l 0.349 a 0.876 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.067639 24.997sec(train) 11.958sec(infer)\n",
      "Epoch 78 tst: l 0.450 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.092sec\n",
      "Epoch 79 tr: l 0.347 a 0.877 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.067301 24.207sec(train) 10.689sec(infer)\n",
      "Epoch 79 tst: l 0.449 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.244sec\n",
      "Epoch 80 tr: l 0.346 a 0.877 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.066965 26.943sec(train) 9.806sec(infer)\n",
      "Epoch 80 tst: l 0.448 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.801sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 81 tr: l 0.344 a 0.878 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.066630 27.083sec(train) 10.870sec(infer)\n",
      "Epoch 81 tst: l 0.448 a 0.852 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.032sec\n",
      "Epoch 82 tr: l 0.343 a 0.878 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.066297 24.840sec(train) 11.050sec(infer)\n",
      "Epoch 82 tst: l 0.447 a 0.852 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.456sec\n",
      "Epoch 83 tr: l 0.342 a 0.878 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.065965 26.440sec(train) 10.088sec(infer)\n",
      "Epoch 83 tst: l 0.446 a 0.852 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.242sec\n",
      "Epoch 84 tr: l 0.340 a 0.878 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.065635 26.683sec(train) 10.638sec(infer)\n",
      "Epoch 84 tst: l 0.445 a 0.852 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.929sec\n",
      "Epoch 85 tr: l 0.339 a 0.879 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.065307 25.482sec(train) 11.314sec(infer)\n",
      "Epoch 85 tst: l 0.445 a 0.852 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.092sec\n",
      "Epoch 86 tr: l 0.338 a 0.879 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064981 24.785sec(train) 10.670sec(infer)\n",
      "Epoch 86 tst: l 0.444 a 0.852 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.286sec\n",
      "Epoch 87 tr: l 0.336 a 0.880 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064656 26.330sec(train) 9.493sec(infer)\n",
      "Epoch 87 tst: l 0.443 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.113sec\n",
      "Epoch 88 tr: l 0.335 a 0.880 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064333 27.433sec(train) 10.564sec(infer)\n",
      "Epoch 88 tst: l 0.442 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.191sec\n",
      "Epoch 89 tr: l 0.334 a 0.880 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064011 25.735sec(train) 11.465sec(infer)\n",
      "Epoch 89 tst: l 0.442 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.077sec\n",
      "Epoch 90 tr: l 0.332 a 0.880 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.063691 25.493sec(train) 9.847sec(infer)\n",
      "Epoch 90 tst: l 0.441 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.074sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 91 tr: l 0.331 a 0.881 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.063372 26.503sec(train) 10.723sec(infer)\n",
      "Epoch 91 tst: l 0.440 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.915sec\n",
      "Epoch 92 tr: l 0.330 a 0.881 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.063056 25.522sec(train) 10.568sec(infer)\n",
      "Epoch 92 tst: l 0.439 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.118sec\n",
      "Epoch 93 tr: l 0.328 a 0.882 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.062740 25.696sec(train) 10.852sec(infer)\n",
      "Epoch 93 tst: l 0.439 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.170sec\n",
      "Epoch 94 tr: l 0.327 a 0.882 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.062427 26.309sec(train) 10.232sec(infer)\n",
      "Epoch 94 tst: l 0.438 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.090sec\n",
      "Epoch 95 tr: l 0.326 a 0.883 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.062114 26.045sec(train) 10.272sec(infer)\n",
      "Epoch 95 tst: l 0.437 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.071sec\n",
      "Epoch 96 tr: l 0.325 a 0.883 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.061804 26.032sec(train) 10.502sec(infer)\n",
      "Epoch 96 tst: l 0.437 a 0.855 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.087sec\n",
      "Epoch 97 tr: l 0.324 a 0.883 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.061495 26.402sec(train) 10.133sec(infer)\n",
      "Epoch 97 tst: l 0.436 a 0.855 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.171sec\n",
      "Epoch 98 tr: l 0.322 a 0.883 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.061187 25.883sec(train) 10.551sec(infer)\n",
      "Epoch 98 tst: l 0.435 a 0.855 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.373sec\n",
      "Epoch 99 tr: l 0.321 a 0.884 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.060881 26.163sec(train) 10.575sec(infer)\n",
      "Epoch 99 tst: l 0.435 a 0.855 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.068sec\n",
      "Epoch 100 tr: l 0.321 a 0.884 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.006058 25.749sec(train) 10.448sec(infer)\n",
      "Epoch 100 tst: l 0.434 a 0.855 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.144sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 101 tr: l 0.320 a 0.884 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.006027 26.187sec(train) 10.251sec(infer)\n",
      "Epoch 101 tst: l 0.434 a 0.855 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.034sec\n",
      "Epoch 102 tr: l 0.320 a 0.885 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005997 26.847sec(train) 10.408sec(infer)\n",
      "Epoch 102 tst: l 0.434 a 0.855 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.237sec\n",
      "Epoch 103 tr: l 0.320 a 0.885 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005967 25.891sec(train) 10.699sec(infer)\n",
      "Epoch 103 tst: l 0.434 a 0.855 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.014sec\n",
      "Epoch 104 tr: l 0.320 a 0.885 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005937 25.773sec(train) 10.323sec(infer)\n",
      "Epoch 104 tst: l 0.434 a 0.855 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.020sec\n",
      "Epoch 105 tr: l 0.320 a 0.885 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005908 26.287sec(train) 10.791sec(infer)\n",
      "Epoch 105 tst: l 0.433 a 0.855 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.682sec\n",
      "Epoch 106 tr: l 0.320 a 0.885 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005878 26.436sec(train) 10.819sec(infer)\n",
      "Epoch 106 tst: l 0.433 a 0.855 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.235sec\n",
      "Epoch 107 tr: l 0.319 a 0.885 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005849 25.342sec(train) 10.554sec(infer)\n",
      "Epoch 107 tst: l 0.433 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.027sec\n",
      "Epoch 108 tr: l 0.319 a 0.885 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005820 26.151sec(train) 10.293sec(infer)\n",
      "Epoch 108 tst: l 0.433 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.169sec\n",
      "Epoch 109 tr: l 0.319 a 0.885 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005790 26.160sec(train) 10.817sec(infer)\n",
      "Epoch 109 tst: l 0.433 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.231sec\n",
      "Epoch 110 tr: l 0.319 a 0.885 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005762 25.339sec(train) 10.404sec(infer)\n",
      "Epoch 110 tst: l 0.433 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.060sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 111 tr: l 0.319 a 0.885 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005733 25.503sec(train) 10.466sec(infer)\n",
      "Epoch 111 tst: l 0.433 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.150sec\n",
      "Epoch 112 tr: l 0.319 a 0.885 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005704 26.128sec(train) 11.052sec(infer)\n",
      "Epoch 112 tst: l 0.433 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.063sec\n",
      "Epoch 113 tr: l 0.319 a 0.885 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005676 25.873sec(train) 10.166sec(infer)\n",
      "Epoch 113 tst: l 0.433 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.212sec\n",
      "Epoch 114 tr: l 0.318 a 0.885 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005647 26.140sec(train) 10.854sec(infer)\n",
      "Epoch 114 tst: l 0.433 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.119sec\n",
      "Epoch 115 tr: l 0.318 a 0.885 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005619 25.684sec(train) 10.311sec(infer)\n",
      "Epoch 115 tst: l 0.433 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.074sec\n",
      "Epoch 116 tr: l 0.318 a 0.885 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005591 25.947sec(train) 10.630sec(infer)\n",
      "Epoch 116 tst: l 0.433 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.337sec\n",
      "Epoch 117 tr: l 0.318 a 0.885 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005563 26.622sec(train) 10.222sec(infer)\n",
      "Epoch 117 tst: l 0.433 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.086sec\n",
      "Epoch 118 tr: l 0.318 a 0.885 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005535 26.038sec(train) 10.386sec(infer)\n",
      "Epoch 118 tst: l 0.433 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.023sec\n",
      "Epoch 119 tr: l 0.318 a 0.885 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005507 25.816sec(train) 11.013sec(infer)\n",
      "Epoch 119 tst: l 0.433 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.901sec\n",
      "Epoch 120 tr: l 0.318 a 0.885 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005480 25.836sec(train) 10.257sec(infer)\n",
      "Epoch 120 tst: l 0.432 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.961sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 121 tr: l 0.317 a 0.885 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005452 25.921sec(train) 10.492sec(infer)\n",
      "Epoch 121 tst: l 0.432 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.200sec\n",
      "Epoch 122 tr: l 0.317 a 0.885 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005425 26.091sec(train) 10.558sec(infer)\n",
      "Epoch 122 tst: l 0.432 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.180sec\n",
      "Epoch 123 tr: l 0.317 a 0.885 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005398 25.115sec(train) 10.499sec(infer)\n",
      "Epoch 123 tst: l 0.432 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.244sec\n",
      "Epoch 124 tr: l 0.317 a 0.885 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005371 26.046sec(train) 9.910sec(infer)\n",
      "Epoch 124 tst: l 0.432 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.032sec\n",
      "Epoch 125 tr: l 0.317 a 0.885 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005344 26.609sec(train) 10.799sec(infer)\n",
      "Epoch 125 tst: l 0.432 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.067sec\n",
      "Epoch 126 tr: l 0.317 a 0.885 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005318 25.914sec(train) 11.058sec(infer)\n",
      "Epoch 126 tst: l 0.432 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.218sec\n",
      "Epoch 127 tr: l 0.317 a 0.885 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005291 25.595sec(train) 10.298sec(infer)\n",
      "Epoch 127 tst: l 0.432 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.067sec\n",
      "Epoch 128 tr: l 0.317 a 0.885 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005264 26.023sec(train) 10.769sec(infer)\n",
      "Epoch 128 tst: l 0.432 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.774sec\n",
      "Epoch 129 tr: l 0.317 a 0.885 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005238 26.047sec(train) 10.508sec(infer)\n",
      "Epoch 129 tst: l 0.432 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.176sec\n",
      "Epoch 130 tr: l 0.316 a 0.885 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005212 26.118sec(train) 10.456sec(infer)\n",
      "Epoch 130 tst: l 0.432 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.191sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 131 tr: l 0.316 a 0.886 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005186 26.261sec(train) 10.340sec(infer)\n",
      "Epoch 131 tst: l 0.432 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.087sec\n",
      "Epoch 132 tr: l 0.316 a 0.886 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005160 25.911sec(train) 10.480sec(infer)\n",
      "Epoch 132 tst: l 0.432 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.237sec\n",
      "Epoch 133 tr: l 0.316 a 0.886 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005134 26.055sec(train) 10.377sec(infer)\n",
      "Epoch 133 tst: l 0.432 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.917sec\n",
      "Epoch 134 tr: l 0.316 a 0.886 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005108 25.910sec(train) 9.969sec(infer)\n",
      "Epoch 134 tst: l 0.432 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.141sec\n",
      "Epoch 135 tr: l 0.316 a 0.886 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005083 26.377sec(train) 11.115sec(infer)\n",
      "Epoch 135 tst: l 0.432 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.677sec\n",
      "Epoch 136 tr: l 0.316 a 0.886 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005058 26.364sec(train) 10.274sec(infer)\n",
      "Epoch 136 tst: l 0.432 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.071sec\n",
      "Epoch 137 tr: l 0.316 a 0.886 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005032 25.695sec(train) 10.621sec(infer)\n",
      "Epoch 137 tst: l 0.432 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.245sec\n",
      "Epoch 138 tr: l 0.316 a 0.886 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005007 25.803sec(train) 9.507sec(infer)\n",
      "Epoch 138 tst: l 0.432 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.121sec\n",
      "Epoch 139 tr: l 0.315 a 0.886 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004982 26.044sec(train) 10.406sec(infer)\n",
      "Epoch 139 tst: l 0.432 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.084sec\n",
      "Epoch 140 tr: l 0.315 a 0.886 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004957 26.080sec(train) 11.072sec(infer)\n",
      "Epoch 140 tst: l 0.431 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.017sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 141 tr: l 0.315 a 0.886 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004932 25.878sec(train) 10.087sec(infer)\n",
      "Epoch 141 tst: l 0.431 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.206sec\n",
      "Epoch 142 tr: l 0.315 a 0.886 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004908 25.974sec(train) 10.679sec(infer)\n",
      "Epoch 142 tst: l 0.431 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.963sec\n",
      "Epoch 143 tr: l 0.315 a 0.886 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004883 26.254sec(train) 10.707sec(infer)\n",
      "Epoch 143 tst: l 0.431 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.240sec\n",
      "Epoch 144 tr: l 0.315 a 0.886 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004859 25.513sec(train) 10.658sec(infer)\n",
      "Epoch 144 tst: l 0.431 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.282sec\n",
      "Epoch 145 tr: l 0.315 a 0.886 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004834 25.891sec(train) 10.343sec(infer)\n",
      "Epoch 145 tst: l 0.431 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.036sec\n",
      "Epoch 146 tr: l 0.315 a 0.886 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004810 26.664sec(train) 10.329sec(infer)\n",
      "Epoch 146 tst: l 0.431 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.235sec\n",
      "Epoch 147 tr: l 0.315 a 0.886 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004786 26.142sec(train) 10.669sec(infer)\n",
      "Epoch 147 tst: l 0.431 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  1.838sec\n",
      "Epoch 148 tr: l 0.314 a 0.886 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004762 25.644sec(train) 10.493sec(infer)\n",
      "Epoch 148 tst: l 0.431 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.122sec\n",
      "Epoch 149 tr: l 0.314 a 0.886 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004738 26.097sec(train) 10.663sec(infer)\n",
      "Epoch 149 tst: l 0.431 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  2.007sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "---train cluster Ended in 1.59 hour (5734.048 sec) \n"
     ]
    }
   ],
   "source": [
    "rc.wait_interactive()\n",
    "_.display_outputs()\n",
    "\n",
    "dfca_gi = rc[0].pull('dfca_gi', block=True)\n",
    "dfca_li = rc[1].pull('dfca_li', block=True)\n",
    "ifca = rc[2].pull('ifca', block=True)\n",
    "\n",
    "dfca_gi_last_acc = rc[0].pull('last_accs', block=True)\n",
    "dfca_li_last_acc = rc[1].pull('last_accs', block=True)\n",
    "ifca_last_acc = rc[2].pull('last_accs', block=True)\n",
    "\n",
    "\n",
    "dfca_gi_std = rc[0].pull('res_std', block=True)\n",
    "dfca_li_std = rc[1].pull('res_std', block=True)\n",
    "ifca_std = rc[2].pull('res_std', block=True)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-19T12:04:35.661691Z",
     "iopub.status.busy": "2025-09-19T12:04:35.661437Z",
     "iopub.status.idle": "2025-09-19T12:04:35.670327Z",
     "shell.execute_reply": "2025-09-19T12:04:35.669839Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "---------------------------------DFCA-LI, lr: 0.1, seed: 1824---------------------------------\n",
      "config: {'m': 200, 'm_test': 40, 'p': 4, 'n': 1500, 'uneven': True, 'local_model_init': True, 'Gp': 0.15, 'graph': 'er', 'agg': 'seq', '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:2\n",
      "Epoch -1 tr: l 3.862 a 0.023 clct[np.int64(50), np.int64(53), np.int64(45), np.int64(52)] cl_acc 0.295  10.926sec\n",
      "Epoch -1 tst: l 3.863 a 0.029 clct[np.int64(9), np.int64(5), np.int64(12), np.int64(14)] cl_acc 0.375  10.089sec\n",
      "Epoch 0 tr: l 3.565 a 0.318 clct[np.int64(50), np.int64(52), np.int64(45), np.int64(53)] cl_acc 0.295  lr 0.100000 31.187sec(train) 12.120sec(infer)\n",
      "Epoch 0 tst: l 3.793 a 0.090 clct[np.int64(6), np.int64(10), np.int64(12), np.int64(12)] cl_acc 0.375  10.596sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 1 tr: l 3.534 a 0.300 clct[np.int64(49), np.int64(52), np.int64(47), np.int64(52)] cl_acc 0.300  lr 0.099500 30.205sec(train) 12.024sec(infer)\n",
      "Epoch 1 tst: l 3.778 a 0.114 clct[np.int64(12), np.int64(7), np.int64(8), np.int64(13)] cl_acc 0.500  9.229sec\n",
      "Epoch 2 tr: l 3.530 a 0.253 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.300  lr 0.099003 31.928sec(train) 10.838sec(infer)\n",
      "Epoch 2 tst: l 3.754 a 0.125 clct[np.int64(13), np.int64(5), np.int64(12), np.int64(10)] cl_acc 0.475  10.777sec\n",
      "Epoch 3 tr: l 3.469 a 0.227 clct[np.int64(52), np.int64(51), np.int64(49), np.int64(48)] cl_acc 0.300  lr 0.098507 30.531sec(train) 12.340sec(infer)\n",
      "Epoch 3 tst: l 3.722 a 0.129 clct[np.int64(13), np.int64(7), np.int64(13), np.int64(7)] cl_acc 0.450  10.399sec\n",
      "Epoch 4 tr: l 3.373 a 0.240 clct[np.int64(54), np.int64(51), np.int64(49), np.int64(46)] cl_acc 0.305  lr 0.098015 30.246sec(train) 11.437sec(infer)\n",
      "Epoch 4 tst: l 3.660 a 0.141 clct[np.int64(17), np.int64(8), np.int64(6), np.int64(9)] cl_acc 0.375  9.570sec\n",
      "Epoch 5 tr: l 3.211 a 0.254 clct[np.int64(55), np.int64(48), np.int64(49), np.int64(48)] cl_acc 0.315  lr 0.097525 31.668sec(train) 11.415sec(infer)\n",
      "Epoch 5 tst: l 3.533 a 0.160 clct[np.int64(15), np.int64(9), np.int64(8), np.int64(8)] cl_acc 0.400  10.646sec\n",
      "Epoch 6 tr: l 3.024 a 0.288 clct[np.int64(56), np.int64(48), np.int64(48), np.int64(48)] cl_acc 0.335  lr 0.097037 30.270sec(train) 12.262sec(infer)\n",
      "Epoch 6 tst: l 3.373 a 0.186 clct[np.int64(12), np.int64(7), np.int64(10), np.int64(11)] cl_acc 0.475  9.741sec\n",
      "Epoch 7 tr: l 2.857 a 0.313 clct[np.int64(60), np.int64(43), np.int64(49), np.int64(48)] cl_acc 0.345  lr 0.096552 30.950sec(train) 10.667sec(infer)\n",
      "Epoch 7 tst: l 3.206 a 0.214 clct[np.int64(13), np.int64(8), np.int64(9), np.int64(10)] cl_acc 0.475  10.186sec\n",
      "Epoch 8 tr: l 2.673 a 0.319 clct[np.int64(66), np.int64(36), np.int64(48), np.int64(50)] cl_acc 0.395  lr 0.096069 30.915sec(train) 12.099sec(infer)\n",
      "Epoch 8 tst: l 3.030 a 0.232 clct[np.int64(14), np.int64(5), np.int64(10), np.int64(11)] cl_acc 0.450  10.629sec\n",
      "Epoch 9 tr: l 2.450 a 0.381 clct[np.int64(74), np.int64(36), np.int64(43), np.int64(47)] cl_acc 0.470  lr 0.095589 30.171sec(train) 12.116sec(infer)\n",
      "Epoch 9 tst: l 2.854 a 0.273 clct[np.int64(17), np.int64(5), np.int64(7), np.int64(11)] cl_acc 0.475  9.140sec\n",
      "Epoch 10 tr: l 2.249 a 0.418 clct[np.int64(75), np.int64(30), np.int64(37), np.int64(58)] cl_acc 0.555  lr 0.095111 31.963sec(train) 10.917sec(infer)\n",
      "Epoch 10 tst: l 2.662 a 0.307 clct[np.int64(14), np.int64(5), np.int64(8), np.int64(13)] cl_acc 0.625  10.609sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 11 tr: l 2.055 a 0.461 clct[np.int64(72), np.int64(33), np.int64(36), np.int64(59)] cl_acc 0.605  lr 0.094635 30.116sec(train) 12.150sec(infer)\n",
      "Epoch 11 tst: l 2.446 a 0.366 clct[np.int64(15), np.int64(5), np.int64(5), np.int64(15)] cl_acc 0.750  10.446sec\n",
      "Epoch 12 tr: l 1.865 a 0.506 clct[np.int64(70), np.int64(37), np.int64(34), np.int64(59)] cl_acc 0.645  lr 0.094162 30.456sec(train) 11.466sec(infer)\n",
      "Epoch 12 tst: l 2.230 a 0.427 clct[np.int64(14), np.int64(10), np.int64(4), np.int64(12)] cl_acc 0.800  9.572sec\n",
      "Epoch 13 tr: l 1.697 a 0.542 clct[np.int64(69), np.int64(39), np.int64(36), np.int64(56)] cl_acc 0.680  lr 0.093691 31.520sec(train) 11.544sec(infer)\n",
      "Epoch 13 tst: l 2.065 a 0.469 clct[np.int64(14), np.int64(8), np.int64(5), np.int64(13)] cl_acc 0.800  10.672sec\n",
      "Epoch 14 tr: l 1.573 a 0.570 clct[np.int64(67), np.int64(43), np.int64(35), np.int64(55)] cl_acc 0.735  lr 0.093223 30.366sec(train) 12.277sec(infer)\n",
      "Epoch 14 tst: l 1.916 a 0.505 clct[np.int64(13), np.int64(9), np.int64(6), np.int64(12)] cl_acc 0.850  9.675sec\n",
      "Epoch 15 tr: l 1.407 a 0.609 clct[np.int64(63), np.int64(46), np.int64(37), np.int64(54)] cl_acc 0.790  lr 0.092757 31.041sec(train) 10.871sec(infer)\n",
      "Epoch 15 tst: l 1.761 a 0.544 clct[np.int64(12), np.int64(10), np.int64(8), np.int64(10)] cl_acc 0.950  10.129sec\n",
      "Epoch 16 tr: l 1.265 a 0.649 clct[np.int64(60), np.int64(45), np.int64(42), np.int64(53)] cl_acc 0.845  lr 0.092293 31.031sec(train) 12.174sec(infer)\n",
      "Epoch 16 tst: l 1.605 a 0.585 clct[np.int64(12), np.int64(10), np.int64(8), np.int64(10)] cl_acc 0.950  10.706sec\n",
      "Epoch 17 tr: l 1.150 a 0.675 clct[np.int64(55), np.int64(47), np.int64(45), np.int64(53)] cl_acc 0.920  lr 0.091832 30.353sec(train) 12.256sec(infer)\n",
      "Epoch 17 tst: l 1.461 a 0.620 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.236sec\n",
      "Epoch 18 tr: l 1.037 a 0.707 clct[np.int64(50), np.int64(49), np.int64(49), np.int64(52)] cl_acc 0.970  lr 0.091372 31.717sec(train) 10.720sec(infer)\n",
      "Epoch 18 tst: l 1.282 a 0.668 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.683sec\n",
      "Epoch 19 tr: l 0.956 a 0.719 clct[np.int64(49), np.int64(51), np.int64(49), np.int64(51)] cl_acc 0.985  lr 0.090916 30.063sec(train) 12.288sec(infer)\n",
      "Epoch 19 tst: l 1.157 a 0.692 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.694sec\n",
      "Epoch 20 tr: l 0.891 a 0.734 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.090461 30.228sec(train) 11.690sec(infer)\n",
      "Epoch 20 tst: l 1.076 a 0.711 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.329sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 21 tr: l 0.831 a 0.742 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.090009 31.808sec(train) 11.316sec(infer)\n",
      "Epoch 21 tst: l 1.008 a 0.722 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.676sec\n",
      "Epoch 22 tr: l 0.789 a 0.752 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.089559 30.148sec(train) 12.272sec(infer)\n",
      "Epoch 22 tst: l 0.964 a 0.732 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.065sec\n",
      "Epoch 23 tr: l 0.748 a 0.761 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.089111 30.738sec(train) 11.094sec(infer)\n",
      "Epoch 23 tst: l 0.920 a 0.740 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.003sec\n",
      "Epoch 24 tr: l 0.722 a 0.768 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.088665 31.341sec(train) 11.856sec(infer)\n",
      "Epoch 24 tst: l 0.885 a 0.749 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.647sec\n",
      "Epoch 25 tr: l 0.694 a 0.775 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.088222 30.128sec(train) 12.170sec(infer)\n",
      "Epoch 25 tst: l 0.857 a 0.753 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.485sec\n",
      "Epoch 26 tr: l 0.674 a 0.781 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.087781 31.712sec(train) 10.570sec(infer)\n",
      "Epoch 26 tst: l 0.835 a 0.759 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.606sec\n",
      "Epoch 27 tr: l 0.649 a 0.787 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.087342 30.461sec(train) 12.269sec(infer)\n",
      "Epoch 27 tst: l 0.808 a 0.765 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.689sec\n",
      "Epoch 28 tr: l 0.637 a 0.790 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.086905 29.881sec(train) 11.922sec(infer)\n",
      "Epoch 28 tst: l 0.791 a 0.769 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.212sec\n",
      "Epoch 29 tr: l 0.619 a 0.793 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.086471 31.747sec(train) 10.997sec(infer)\n",
      "Epoch 29 tst: l 0.774 a 0.773 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.667sec\n",
      "Epoch 30 tr: l 0.599 a 0.801 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.086038 30.287sec(train) 12.285sec(infer)\n",
      "Epoch 30 tst: l 0.760 a 0.778 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.315sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 31 tr: l 0.581 a 0.803 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.085608 30.620sec(train) 11.308sec(infer)\n",
      "Epoch 31 tst: l 0.750 a 0.779 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.736sec\n",
      "Epoch 32 tr: l 0.569 a 0.807 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.085180 31.298sec(train) 11.597sec(infer)\n",
      "Epoch 32 tst: l 0.735 a 0.783 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.682sec\n",
      "Epoch 33 tr: l 0.558 a 0.810 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.084754 30.334sec(train) 12.303sec(infer)\n",
      "Epoch 33 tst: l 0.721 a 0.786 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.717sec\n",
      "Epoch 34 tr: l 0.555 a 0.812 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.084331 31.110sec(train) 10.671sec(infer)\n",
      "Epoch 34 tst: l 0.711 a 0.789 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.231sec\n",
      "Epoch 35 tr: l 0.539 a 0.814 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.083909 30.860sec(train) 12.185sec(infer)\n",
      "Epoch 35 tst: l 0.703 a 0.790 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.706sec\n",
      "Epoch 36 tr: l 0.532 a 0.818 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.083489 30.256sec(train) 12.179sec(infer)\n",
      "Epoch 36 tst: l 0.694 a 0.793 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.205sec\n",
      "Epoch 37 tr: l 0.524 a 0.819 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.083072 31.878sec(train) 10.832sec(infer)\n",
      "Epoch 37 tst: l 0.685 a 0.795 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.666sec\n",
      "Epoch 38 tr: l 0.515 a 0.823 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.082657 30.349sec(train) 12.184sec(infer)\n",
      "Epoch 38 tst: l 0.678 a 0.798 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.607sec\n",
      "Epoch 39 tr: l 0.504 a 0.826 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.082243 30.312sec(train) 11.619sec(infer)\n",
      "Epoch 39 tst: l 0.669 a 0.799 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.429sec\n",
      "Epoch 40 tr: l 0.497 a 0.828 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.081832 31.471sec(train) 11.453sec(infer)\n",
      "Epoch 40 tst: l 0.663 a 0.801 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.682sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 41 tr: l 0.492 a 0.829 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.081423 30.397sec(train) 12.321sec(infer)\n",
      "Epoch 41 tst: l 0.655 a 0.803 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.891sec\n",
      "Epoch 42 tr: l 0.488 a 0.831 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.081016 30.761sec(train) 10.975sec(infer)\n",
      "Epoch 42 tst: l 0.656 a 0.803 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.020sec\n",
      "Epoch 43 tr: l 0.477 a 0.833 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.080611 30.962sec(train) 11.981sec(infer)\n",
      "Epoch 43 tst: l 0.642 a 0.806 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.653sec\n",
      "Epoch 44 tr: l 0.470 a 0.836 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.080208 30.237sec(train) 12.293sec(infer)\n",
      "Epoch 44 tst: l 0.640 a 0.807 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.317sec\n",
      "Epoch 45 tr: l 0.467 a 0.836 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.079807 31.664sec(train) 10.461sec(infer)\n",
      "Epoch 45 tst: l 0.632 a 0.810 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.602sec\n",
      "Epoch 46 tr: l 0.460 a 0.838 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.079408 30.449sec(train) 12.277sec(infer)\n",
      "Epoch 46 tst: l 0.627 a 0.810 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.688sec\n",
      "Epoch 47 tr: l 0.453 a 0.840 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.079010 30.479sec(train) 11.853sec(infer)\n",
      "Epoch 47 tst: l 0.622 a 0.812 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.198sec\n",
      "Epoch 48 tr: l 0.452 a 0.841 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.078615 31.883sec(train) 11.144sec(infer)\n",
      "Epoch 48 tst: l 0.616 a 0.813 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.719sec\n",
      "Epoch 49 tr: l 0.443 a 0.842 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.078222 30.331sec(train) 12.337sec(infer)\n",
      "Epoch 49 tst: l 0.613 a 0.815 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.239sec\n",
      "Epoch 50 tr: l 0.441 a 0.844 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.077831 30.708sec(train) 11.234sec(infer)\n",
      "Epoch 50 tst: l 0.609 a 0.815 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.834sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 51 tr: l 0.437 a 0.846 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.077442 31.245sec(train) 11.679sec(infer)\n",
      "Epoch 51 tst: l 0.604 a 0.817 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.712sec\n",
      "Epoch 52 tr: l 0.430 a 0.847 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.077055 30.621sec(train) 12.306sec(infer)\n",
      "Epoch 52 tst: l 0.602 a 0.817 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.575sec\n",
      "Epoch 53 tr: l 0.426 a 0.848 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.076670 31.211sec(train) 10.584sec(infer)\n",
      "Epoch 53 tst: l 0.596 a 0.819 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.456sec\n",
      "Epoch 54 tr: l 0.420 a 0.849 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.076286 30.598sec(train) 12.310sec(infer)\n",
      "Epoch 54 tst: l 0.594 a 0.820 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.586sec\n",
      "Epoch 55 tr: l 0.418 a 0.850 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.075905 30.227sec(train) 12.033sec(infer)\n",
      "Epoch 55 tst: l 0.589 a 0.821 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.189sec\n",
      "Epoch 56 tr: l 0.418 a 0.851 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.075525 31.768sec(train) 10.971sec(infer)\n",
      "Epoch 56 tst: l 0.587 a 0.822 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.686sec\n",
      "Epoch 57 tr: l 0.411 a 0.853 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.075148 30.327sec(train) 12.280sec(infer)\n",
      "Epoch 57 tst: l 0.582 a 0.822 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.314sec\n",
      "Epoch 58 tr: l 0.409 a 0.853 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.074772 30.393sec(train) 11.331sec(infer)\n",
      "Epoch 58 tst: l 0.583 a 0.822 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.594sec\n",
      "Epoch 59 tr: l 0.405 a 0.854 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.074398 31.409sec(train) 11.580sec(infer)\n",
      "Epoch 59 tst: l 0.580 a 0.824 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.633sec\n",
      "Epoch 60 tr: l 0.401 a 0.855 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.074026 30.393sec(train) 12.239sec(infer)\n",
      "Epoch 60 tst: l 0.576 a 0.824 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.609sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 61 tr: l 0.396 a 0.857 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.073656 31.242sec(train) 10.733sec(infer)\n",
      "Epoch 61 tst: l 0.573 a 0.825 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.325sec\n",
      "Epoch 62 tr: l 0.393 a 0.858 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.073288 31.131sec(train) 12.329sec(infer)\n",
      "Epoch 62 tst: l 0.572 a 0.826 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.732sec\n",
      "Epoch 63 tr: l 0.392 a 0.859 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.072921 30.780sec(train) 12.011sec(infer)\n",
      "Epoch 63 tst: l 0.567 a 0.827 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.246sec\n",
      "Epoch 64 tr: l 0.386 a 0.860 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.072557 31.933sec(train) 10.942sec(infer)\n",
      "Epoch 64 tst: l 0.567 a 0.827 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.698sec\n",
      "Epoch 65 tr: l 0.384 a 0.861 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.072194 30.499sec(train) 12.320sec(infer)\n",
      "Epoch 65 tst: l 0.561 a 0.828 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.377sec\n",
      "Epoch 66 tr: l 0.382 a 0.862 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.071833 30.616sec(train) 11.437sec(infer)\n",
      "Epoch 66 tst: l 0.560 a 0.830 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.657sec\n",
      "Epoch 67 tr: l 0.381 a 0.863 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.071474 31.795sec(train) 11.646sec(infer)\n",
      "Epoch 67 tst: l 0.557 a 0.830 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.684sec\n",
      "Epoch 68 tr: l 0.376 a 0.863 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.071116 30.364sec(train) 12.352sec(infer)\n",
      "Epoch 68 tst: l 0.556 a 0.830 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.868sec\n",
      "Epoch 69 tr: l 0.375 a 0.864 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.070761 31.241sec(train) 10.803sec(infer)\n",
      "Epoch 69 tst: l 0.552 a 0.832 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.249sec\n",
      "Epoch 70 tr: l 0.372 a 0.865 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.070407 31.349sec(train) 12.275sec(infer)\n",
      "Epoch 70 tst: l 0.549 a 0.833 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.738sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 71 tr: l 0.370 a 0.865 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.070055 30.245sec(train) 12.093sec(infer)\n",
      "Epoch 71 tst: l 0.549 a 0.833 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.188sec\n",
      "Epoch 72 tr: l 0.366 a 0.866 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.069705 32.002sec(train) 10.807sec(infer)\n",
      "Epoch 72 tst: l 0.546 a 0.833 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.671sec\n",
      "Epoch 73 tr: l 0.362 a 0.867 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.069356 30.497sec(train) 12.406sec(infer)\n",
      "Epoch 73 tst: l 0.544 a 0.834 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.659sec\n",
      "Epoch 74 tr: l 0.362 a 0.868 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.069009 30.456sec(train) 11.636sec(infer)\n",
      "Epoch 74 tst: l 0.543 a 0.834 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.478sec\n",
      "Epoch 75 tr: l 0.356 a 0.870 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.068664 31.746sec(train) 11.442sec(infer)\n",
      "Epoch 75 tst: l 0.540 a 0.835 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.674sec\n",
      "Epoch 76 tr: l 0.356 a 0.869 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.068321 30.565sec(train) 12.340sec(infer)\n",
      "Epoch 76 tst: l 0.540 a 0.836 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.010sec\n",
      "Epoch 77 tr: l 0.356 a 0.870 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.067979 30.802sec(train) 11.078sec(infer)\n",
      "Epoch 77 tst: l 0.536 a 0.837 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.035sec\n",
      "Epoch 78 tr: l 0.355 a 0.870 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.067639 31.306sec(train) 11.966sec(infer)\n",
      "Epoch 78 tst: l 0.536 a 0.837 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.627sec\n",
      "Epoch 79 tr: l 0.350 a 0.872 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.067301 30.364sec(train) 12.329sec(infer)\n",
      "Epoch 79 tst: l 0.535 a 0.837 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.431sec\n",
      "Epoch 80 tr: l 0.350 a 0.872 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.066965 31.675sec(train) 10.558sec(infer)\n",
      "Epoch 80 tst: l 0.532 a 0.838 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.529sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 81 tr: l 0.351 a 0.871 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.066630 30.656sec(train) 12.252sec(infer)\n",
      "Epoch 81 tst: l 0.528 a 0.839 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.660sec\n",
      "Epoch 82 tr: l 0.349 a 0.872 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.066297 30.010sec(train) 12.023sec(infer)\n",
      "Epoch 82 tst: l 0.531 a 0.838 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.233sec\n",
      "Epoch 83 tr: l 0.341 a 0.874 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.065965 32.129sec(train) 11.094sec(infer)\n",
      "Epoch 83 tst: l 0.527 a 0.838 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.711sec\n",
      "Epoch 84 tr: l 0.342 a 0.874 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.065635 30.326sec(train) 12.254sec(infer)\n",
      "Epoch 84 tst: l 0.525 a 0.840 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.336sec\n",
      "Epoch 85 tr: l 0.342 a 0.874 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.065307 30.494sec(train) 11.340sec(infer)\n",
      "Epoch 85 tst: l 0.524 a 0.840 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.740sec\n",
      "Epoch 86 tr: l 0.337 a 0.876 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.064981 31.305sec(train) 11.549sec(infer)\n",
      "Epoch 86 tst: l 0.525 a 0.840 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.678sec\n",
      "Epoch 87 tr: l 0.336 a 0.876 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.064656 30.622sec(train) 12.334sec(infer)\n",
      "Epoch 87 tst: l 0.521 a 0.841 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.797sec\n",
      "Epoch 88 tr: l 0.329 a 0.878 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.064333 31.349sec(train) 10.829sec(infer)\n",
      "Epoch 88 tst: l 0.521 a 0.840 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.236sec\n",
      "Epoch 89 tr: l 0.331 a 0.878 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.064011 30.702sec(train) 12.194sec(infer)\n",
      "Epoch 89 tst: l 0.520 a 0.842 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.749sec\n",
      "Epoch 90 tr: l 0.336 a 0.878 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.063691 30.523sec(train) 12.363sec(infer)\n",
      "Epoch 90 tst: l 0.536 a 0.835 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.255sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 91 tr: l 0.328 a 0.879 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.063372 31.998sec(train) 10.757sec(infer)\n",
      "Epoch 91 tst: l 0.527 a 0.838 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.687sec\n",
      "Epoch 92 tr: l 0.327 a 0.878 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.063056 30.422sec(train) 12.208sec(infer)\n",
      "Epoch 92 tst: l 0.523 a 0.839 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.733sec\n",
      "Epoch 93 tr: l 0.325 a 0.879 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.062740 30.328sec(train) 11.672sec(infer)\n",
      "Epoch 93 tst: l 0.517 a 0.841 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.340sec\n",
      "Epoch 94 tr: l 0.323 a 0.880 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.062427 31.919sec(train) 11.369sec(infer)\n",
      "Epoch 94 tst: l 0.514 a 0.842 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.692sec\n",
      "Epoch 95 tr: l 0.321 a 0.880 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.062114 30.422sec(train) 12.372sec(infer)\n",
      "Epoch 95 tst: l 0.514 a 0.843 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.153sec\n",
      "Epoch 96 tr: l 0.318 a 0.881 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.061804 30.784sec(train) 11.225sec(infer)\n",
      "Epoch 96 tst: l 0.511 a 0.843 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.893sec\n",
      "Epoch 97 tr: l 0.316 a 0.882 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.061495 31.151sec(train) 11.814sec(infer)\n",
      "Epoch 97 tst: l 0.511 a 0.843 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.701sec\n",
      "Epoch 98 tr: l 0.314 a 0.884 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.061187 30.780sec(train) 12.299sec(infer)\n",
      "Epoch 98 tst: l 0.509 a 0.844 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.547sec\n",
      "Epoch 99 tr: l 0.314 a 0.883 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.060881 31.446sec(train) 10.600sec(infer)\n",
      "Epoch 99 tst: l 0.509 a 0.844 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.496sec\n",
      "Epoch 100 tr: l 0.329 a 0.880 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.006058 30.722sec(train) 12.366sec(infer)\n",
      "Epoch 100 tst: l 0.499 a 0.847 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.733sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 101 tr: l 0.341 a 0.878 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.006027 30.372sec(train) 12.079sec(infer)\n",
      "Epoch 101 tst: l 0.495 a 0.848 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.285sec\n",
      "Epoch 102 tr: l 0.347 a 0.876 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.005997 31.957sec(train) 11.007sec(infer)\n",
      "Epoch 102 tst: l 0.493 a 0.849 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.704sec\n",
      "Epoch 103 tr: l 0.349 a 0.876 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.005967 30.496sec(train) 12.196sec(infer)\n",
      "Epoch 103 tst: l 0.491 a 0.849 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.453sec\n",
      "Epoch 104 tr: l 0.348 a 0.876 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.005937 30.619sec(train) 11.446sec(infer)\n",
      "Epoch 104 tst: l 0.490 a 0.849 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.623sec\n",
      "Epoch 105 tr: l 0.348 a 0.876 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.005908 31.623sec(train) 11.573sec(infer)\n",
      "Epoch 105 tst: l 0.489 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.691sec\n",
      "Epoch 106 tr: l 0.348 a 0.876 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.005878 30.121sec(train) 12.332sec(infer)\n",
      "Epoch 106 tst: l 0.488 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.778sec\n",
      "Epoch 107 tr: l 0.347 a 0.876 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.005849 31.174sec(train) 10.836sec(infer)\n",
      "Epoch 107 tst: l 0.488 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  8.995sec\n",
      "Epoch 108 tr: l 0.348 a 0.876 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.005820 31.298sec(train) 10.892sec(infer)\n",
      "Epoch 108 tst: l 0.488 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.167sec\n",
      "Epoch 109 tr: l 0.348 a 0.876 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.005790 31.062sec(train) 12.247sec(infer)\n",
      "Epoch 109 tst: l 0.487 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.682sec\n",
      "Epoch 110 tr: l 0.348 a 0.876 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.005762 30.422sec(train) 12.113sec(infer)\n",
      "Epoch 110 tst: l 0.486 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.173sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 111 tr: l 0.348 a 0.876 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.005733 32.029sec(train) 10.898sec(infer)\n",
      "Epoch 111 tst: l 0.486 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.639sec\n",
      "Epoch 112 tr: l 0.348 a 0.876 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.005704 30.378sec(train) 12.349sec(infer)\n",
      "Epoch 112 tst: l 0.486 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.411sec\n",
      "Epoch 113 tr: l 0.346 a 0.877 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.005676 30.573sec(train) 11.347sec(infer)\n",
      "Epoch 113 tst: l 0.486 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.577sec\n",
      "Epoch 114 tr: l 0.348 a 0.876 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.005647 31.422sec(train) 11.616sec(infer)\n",
      "Epoch 114 tst: l 0.485 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.686sec\n",
      "Epoch 115 tr: l 0.346 a 0.877 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.005619 30.238sec(train) 12.347sec(infer)\n",
      "Epoch 115 tst: l 0.485 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.774sec\n",
      "Epoch 116 tr: l 0.346 a 0.877 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.005591 31.465sec(train) 10.853sec(infer)\n",
      "Epoch 116 tst: l 0.485 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.225sec\n",
      "Epoch 117 tr: l 0.345 a 0.877 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.005563 31.021sec(train) 12.298sec(infer)\n",
      "Epoch 117 tst: l 0.485 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.759sec\n",
      "Epoch 118 tr: l 0.345 a 0.877 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.005535 30.507sec(train) 12.224sec(infer)\n",
      "Epoch 118 tst: l 0.485 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.284sec\n",
      "Epoch 119 tr: l 0.345 a 0.877 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.005507 32.031sec(train) 10.973sec(infer)\n",
      "Epoch 119 tst: l 0.484 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.586sec\n",
      "Epoch 120 tr: l 0.345 a 0.877 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.005480 30.488sec(train) 12.269sec(infer)\n",
      "Epoch 120 tst: l 0.484 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.385sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 121 tr: l 0.344 a 0.877 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.005452 30.570sec(train) 11.346sec(infer)\n",
      "Epoch 121 tst: l 0.484 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.673sec\n",
      "Epoch 122 tr: l 0.345 a 0.877 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.005425 31.559sec(train) 11.741sec(infer)\n",
      "Epoch 122 tst: l 0.484 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.651sec\n",
      "Epoch 123 tr: l 0.345 a 0.878 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.005398 30.243sec(train) 12.264sec(infer)\n",
      "Epoch 123 tst: l 0.484 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.691sec\n",
      "Epoch 124 tr: l 0.344 a 0.877 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.005371 31.140sec(train) 10.651sec(infer)\n",
      "Epoch 124 tst: l 0.484 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.439sec\n",
      "Epoch 125 tr: l 0.343 a 0.878 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.005344 31.063sec(train) 12.350sec(infer)\n",
      "Epoch 125 tst: l 0.483 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.724sec\n",
      "Epoch 126 tr: l 0.341 a 0.878 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.005318 30.497sec(train) 12.005sec(infer)\n",
      "Epoch 126 tst: l 0.484 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.302sec\n",
      "Epoch 127 tr: l 0.343 a 0.878 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.005291 32.198sec(train) 11.094sec(infer)\n",
      "Epoch 127 tst: l 0.484 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.722sec\n",
      "Epoch 128 tr: l 0.343 a 0.878 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.005264 30.529sec(train) 12.347sec(infer)\n",
      "Epoch 128 tst: l 0.483 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.331sec\n",
      "Epoch 129 tr: l 0.345 a 0.878 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.005238 30.925sec(train) 11.339sec(infer)\n",
      "Epoch 129 tst: l 0.482 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.859sec\n",
      "Epoch 130 tr: l 0.344 a 0.878 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.005212 31.748sec(train) 11.802sec(infer)\n",
      "Epoch 130 tst: l 0.483 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.762sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 131 tr: l 0.343 a 0.878 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.005186 30.553sec(train) 12.325sec(infer)\n",
      "Epoch 131 tst: l 0.483 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.665sec\n",
      "Epoch 132 tr: l 0.342 a 0.878 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.005160 31.505sec(train) 10.660sec(infer)\n",
      "Epoch 132 tst: l 0.483 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.509sec\n",
      "Epoch 133 tr: l 0.342 a 0.878 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.005134 30.788sec(train) 12.217sec(infer)\n",
      "Epoch 133 tst: l 0.483 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.774sec\n",
      "Epoch 134 tr: l 0.342 a 0.878 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.005108 30.247sec(train) 12.053sec(infer)\n",
      "Epoch 134 tst: l 0.482 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.291sec\n",
      "Epoch 135 tr: l 0.342 a 0.878 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.005083 32.027sec(train) 11.093sec(infer)\n",
      "Epoch 135 tst: l 0.482 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.750sec\n",
      "Epoch 136 tr: l 0.341 a 0.878 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.005058 30.595sec(train) 12.354sec(infer)\n",
      "Epoch 136 tst: l 0.482 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.260sec\n",
      "Epoch 137 tr: l 0.341 a 0.878 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.005032 30.791sec(train) 11.352sec(infer)\n",
      "Epoch 137 tst: l 0.482 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.762sec\n",
      "Epoch 138 tr: l 0.340 a 0.878 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.005007 31.579sec(train) 11.815sec(infer)\n",
      "Epoch 138 tst: l 0.481 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.734sec\n",
      "Epoch 139 tr: l 0.339 a 0.878 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.004982 30.482sec(train) 12.311sec(infer)\n",
      "Epoch 139 tst: l 0.482 a 0.852 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.565sec\n",
      "Epoch 140 tr: l 0.340 a 0.878 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.004957 31.310sec(train) 10.687sec(infer)\n",
      "Epoch 140 tst: l 0.481 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.431sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 141 tr: l 0.342 a 0.878 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.004932 31.032sec(train) 12.355sec(infer)\n",
      "Epoch 141 tst: l 0.481 a 0.852 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.802sec\n",
      "Epoch 142 tr: l 0.339 a 0.879 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.004908 30.397sec(train) 11.947sec(infer)\n",
      "Epoch 142 tst: l 0.481 a 0.852 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.247sec\n",
      "Epoch 143 tr: l 0.341 a 0.878 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.004883 32.100sec(train) 11.154sec(infer)\n",
      "Epoch 143 tst: l 0.481 a 0.852 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.610sec\n",
      "Epoch 144 tr: l 0.341 a 0.878 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.004859 30.523sec(train) 12.351sec(infer)\n",
      "Epoch 144 tst: l 0.481 a 0.852 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.244sec\n",
      "Epoch 145 tr: l 0.341 a 0.878 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.004834 30.655sec(train) 11.287sec(infer)\n",
      "Epoch 145 tst: l 0.481 a 0.852 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.846sec\n",
      "Epoch 146 tr: l 0.340 a 0.878 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.004810 31.426sec(train) 11.928sec(infer)\n",
      "Epoch 146 tst: l 0.481 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.747sec\n",
      "Epoch 147 tr: l 0.340 a 0.879 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.004786 30.289sec(train) 12.300sec(infer)\n",
      "Epoch 147 tst: l 0.481 a 0.852 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.596sec\n",
      "Epoch 148 tr: l 0.340 a 0.879 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.004762 31.534sec(train) 8.840sec(infer)\n",
      "Epoch 148 tst: l 0.481 a 0.852 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.659sec\n",
      "Epoch 149 tr: l 0.339 a 0.879 clct[np.int64(50), np.int64(51), np.int64(49), np.int64(50)] cl_acc 0.995  lr 0.004738 33.291sec(train) 10.618sec(infer)\n",
      "Epoch 149 tst: l 0.481 a 0.852 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.693sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "---train cluster Ended in 2.22 hour (7989.949 sec) \n",
      "---------------------------------DFCA-LI, lr: 0.1, seed: 409---------------------------------\n",
      "config: {'m': 200, 'm_test': 40, 'p': 4, 'n': 1500, 'uneven': True, 'local_model_init': True, 'Gp': 0.15, 'graph': 'er', 'agg': 'seq', '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:2\n",
      "Epoch -1 tr: l 3.862 a 0.024 clct[np.int64(46), np.int64(50), np.int64(45), np.int64(59)] cl_acc 0.325  9.579sec\n",
      "Epoch -1 tst: l 3.864 a 0.027 clct[np.int64(17), np.int64(7), np.int64(9), np.int64(7)] cl_acc 0.400  9.504sec\n",
      "Epoch 0 tr: l 3.577 a 0.319 clct[np.int64(46), np.int64(50), np.int64(46), np.int64(58)] cl_acc 0.325  lr 0.100000 33.140sec(train) 10.589sec(infer)\n",
      "Epoch 0 tst: l 3.780 a 0.099 clct[np.int64(11), np.int64(8), np.int64(9), np.int64(12)] cl_acc 0.400  8.862sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 1 tr: l 3.542 a 0.305 clct[np.int64(45), np.int64(52), np.int64(48), np.int64(55)] cl_acc 0.330  lr 0.099500 33.668sec(train) 9.474sec(infer)\n",
      "Epoch 1 tst: l 3.765 a 0.125 clct[np.int64(10), np.int64(6), np.int64(12), np.int64(12)] cl_acc 0.425  8.726sec\n",
      "Epoch 2 tr: l 3.536 a 0.263 clct[np.int64(45), np.int64(52), np.int64(48), np.int64(55)] cl_acc 0.330  lr 0.099003 33.814sec(train) 10.234sec(infer)\n",
      "Epoch 2 tst: l 3.742 a 0.128 clct[np.int64(10), np.int64(11), np.int64(10), np.int64(9)] cl_acc 0.575  9.466sec\n",
      "Epoch 3 tr: l 3.471 a 0.246 clct[np.int64(45), np.int64(51), np.int64(51), np.int64(53)] cl_acc 0.330  lr 0.098507 33.163sec(train) 10.855sec(infer)\n",
      "Epoch 3 tst: l 3.707 a 0.128 clct[np.int64(8), np.int64(9), np.int64(8), np.int64(15)] cl_acc 0.475  8.155sec\n",
      "Epoch 4 tr: l 3.382 a 0.262 clct[np.int64(46), np.int64(51), np.int64(50), np.int64(53)] cl_acc 0.325  lr 0.098015 34.355sec(train) 8.950sec(infer)\n",
      "Epoch 4 tst: l 3.625 a 0.144 clct[np.int64(6), np.int64(10), np.int64(10), np.int64(14)] cl_acc 0.400  9.284sec\n",
      "Epoch 5 tr: l 3.215 a 0.282 clct[np.int64(44), np.int64(53), np.int64(51), np.int64(52)] cl_acc 0.335  lr 0.097525 33.024sec(train) 10.879sec(infer)\n",
      "Epoch 5 tst: l 3.502 a 0.169 clct[np.int64(3), np.int64(12), np.int64(12), np.int64(13)] cl_acc 0.475  9.345sec\n",
      "Epoch 6 tr: l 3.014 a 0.311 clct[np.int64(44), np.int64(53), np.int64(49), np.int64(54)] cl_acc 0.340  lr 0.097037 32.687sec(train) 10.752sec(infer)\n",
      "Epoch 6 tst: l 3.339 a 0.200 clct[np.int64(3), np.int64(11), np.int64(9), np.int64(17)] cl_acc 0.500  7.794sec\n",
      "Epoch 7 tr: l 2.820 a 0.325 clct[np.int64(43), np.int64(53), np.int64(50), np.int64(54)] cl_acc 0.355  lr 0.096552 34.178sec(train) 9.746sec(infer)\n",
      "Epoch 7 tst: l 3.180 a 0.216 clct[np.int64(3), np.int64(11), np.int64(13), np.int64(13)] cl_acc 0.475  9.354sec\n",
      "Epoch 8 tr: l 2.648 a 0.346 clct[np.int64(43), np.int64(51), np.int64(49), np.int64(57)] cl_acc 0.395  lr 0.096069 32.711sec(train) 11.341sec(infer)\n",
      "Epoch 8 tst: l 2.999 a 0.244 clct[np.int64(3), np.int64(10), np.int64(8), np.int64(19)] cl_acc 0.475  8.827sec\n",
      "Epoch 9 tr: l 2.494 a 0.367 clct[np.int64(41), np.int64(51), np.int64(52), np.int64(56)] cl_acc 0.445  lr 0.095589 33.189sec(train) 10.343sec(infer)\n",
      "Epoch 9 tst: l 2.847 a 0.269 clct[np.int64(2), np.int64(11), np.int64(12), np.int64(15)] cl_acc 0.525  8.311sec\n",
      "Epoch 10 tr: l 2.340 a 0.396 clct[np.int64(40), np.int64(48), np.int64(51), np.int64(61)] cl_acc 0.470  lr 0.095111 33.519sec(train) 10.931sec(infer)\n",
      "Epoch 10 tst: l 2.685 a 0.304 clct[np.int64(5), np.int64(8), np.int64(10), np.int64(17)] cl_acc 0.575  9.253sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 11 tr: l 2.161 a 0.437 clct[np.int64(38), np.int64(48), np.int64(49), np.int64(65)] cl_acc 0.505  lr 0.094635 32.589sec(train) 11.569sec(infer)\n",
      "Epoch 11 tst: l 2.486 a 0.355 clct[np.int64(4), np.int64(9), np.int64(10), np.int64(17)] cl_acc 0.625  8.278sec\n",
      "Epoch 12 tr: l 1.996 a 0.478 clct[np.int64(35), np.int64(46), np.int64(50), np.int64(69)] cl_acc 0.540  lr 0.094162 33.201sec(train) 10.085sec(infer)\n",
      "Epoch 12 tst: l 2.307 a 0.400 clct[np.int64(3), np.int64(8), np.int64(10), np.int64(19)] cl_acc 0.625  9.022sec\n",
      "Epoch 13 tr: l 1.842 a 0.504 clct[np.int64(28), np.int64(45), np.int64(52), np.int64(75)] cl_acc 0.605  lr 0.093691 32.506sec(train) 11.780sec(infer)\n",
      "Epoch 13 tst: l 2.151 a 0.434 clct[np.int64(6), np.int64(8), np.int64(6), np.int64(20)] cl_acc 0.600  9.310sec\n",
      "Epoch 14 tr: l 1.701 a 0.537 clct[np.int64(25), np.int64(49), np.int64(47), np.int64(79)] cl_acc 0.645  lr 0.093223 32.236sec(train) 11.737sec(infer)\n",
      "Epoch 14 tst: l 1.982 a 0.478 clct[np.int64(4), np.int64(9), np.int64(7), np.int64(20)] cl_acc 0.625  7.832sec\n",
      "Epoch 15 tr: l 1.574 a 0.563 clct[np.int64(24), np.int64(49), np.int64(44), np.int64(83)] cl_acc 0.665  lr 0.092757 33.262sec(train) 10.532sec(infer)\n",
      "Epoch 15 tst: l 1.824 a 0.514 clct[np.int64(2), np.int64(10), np.int64(8), np.int64(20)] cl_acc 0.700  9.374sec\n",
      "Epoch 16 tr: l 1.465 a 0.579 clct[np.int64(18), np.int64(50), np.int64(44), np.int64(88)] cl_acc 0.715  lr 0.092293 32.008sec(train) 12.134sec(infer)\n",
      "Epoch 16 tst: l 1.686 a 0.534 clct[np.int64(1), np.int64(10), np.int64(9), np.int64(20)] cl_acc 0.725  9.210sec\n",
      "Epoch 17 tr: l 1.371 a 0.607 clct[np.int64(16), np.int64(49), np.int64(46), np.int64(89)] cl_acc 0.730  lr 0.091832 31.938sec(train) 11.417sec(infer)\n",
      "Epoch 17 tst: l 1.573 a 0.565 clct[np.int64(1), np.int64(10), np.int64(9), np.int64(20)] cl_acc 0.725  8.051sec\n",
      "Epoch 18 tr: l 1.291 a 0.622 clct[np.int64(12), np.int64(49), np.int64(46), np.int64(93)] cl_acc 0.750  lr 0.091372 32.595sec(train) 11.475sec(infer)\n",
      "Epoch 18 tst: l 1.481 a 0.581 clct[np.int64(1), np.int64(10), np.int64(9), np.int64(20)] cl_acc 0.725  9.416sec\n",
      "Epoch 19 tr: l 1.249 a 0.624 clct[np.int64(13), np.int64(49), np.int64(46), np.int64(92)] cl_acc 0.755  lr 0.090916 31.704sec(train) 12.440sec(infer)\n",
      "Epoch 19 tst: l 1.432 a 0.589 clct[np.int64(0), np.int64(10), np.int64(10), np.int64(20)] cl_acc 0.750  8.732sec\n",
      "Epoch 20 tr: l 1.131 a 0.661 clct[np.int64(14), np.int64(49), np.int64(46), np.int64(91)] cl_acc 0.760  lr 0.090461 32.270sec(train) 10.919sec(infer)\n",
      "Epoch 20 tst: l 1.313 a 0.623 clct[np.int64(0), np.int64(10), np.int64(10), np.int64(20)] cl_acc 0.750  8.766sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 21 tr: l 1.101 a 0.665 clct[np.int64(15), np.int64(49), np.int64(47), np.int64(89)] cl_acc 0.775  lr 0.090009 31.987sec(train) 12.009sec(infer)\n",
      "Epoch 21 tst: l 1.273 a 0.629 clct[np.int64(0), np.int64(10), np.int64(10), np.int64(20)] cl_acc 0.750  9.569sec\n",
      "Epoch 22 tr: l 1.039 a 0.680 clct[np.int64(17), np.int64(49), np.int64(47), np.int64(87)] cl_acc 0.785  lr 0.089559 31.239sec(train) 12.293sec(infer)\n",
      "Epoch 22 tst: l 1.215 a 0.646 clct[np.int64(1), np.int64(10), np.int64(10), np.int64(19)] cl_acc 0.775  8.205sec\n",
      "Epoch 23 tr: l 1.005 a 0.692 clct[np.int64(19), np.int64(49), np.int64(48), np.int64(84)] cl_acc 0.805  lr 0.089111 32.986sec(train) 10.637sec(infer)\n",
      "Epoch 23 tst: l 1.176 a 0.657 clct[np.int64(1), np.int64(10), np.int64(10), np.int64(19)] cl_acc 0.775  9.892sec\n",
      "Epoch 24 tr: l 0.960 a 0.705 clct[np.int64(18), np.int64(50), np.int64(48), np.int64(84)] cl_acc 0.820  lr 0.088665 31.060sec(train) 12.117sec(infer)\n",
      "Epoch 24 tst: l 1.127 a 0.669 clct[np.int64(1), np.int64(10), np.int64(10), np.int64(19)] cl_acc 0.775  9.798sec\n",
      "Epoch 25 tr: l 0.922 a 0.714 clct[np.int64(23), np.int64(50), np.int64(48), np.int64(79)] cl_acc 0.845  lr 0.088222 31.345sec(train) 11.793sec(infer)\n",
      "Epoch 25 tst: l 1.107 a 0.676 clct[np.int64(4), np.int64(10), np.int64(10), np.int64(16)] cl_acc 0.850  8.320sec\n",
      "Epoch 26 tr: l 0.850 a 0.737 clct[np.int64(25), np.int64(50), np.int64(49), np.int64(76)] cl_acc 0.865  lr 0.087781 32.605sec(train) 11.277sec(infer)\n",
      "Epoch 26 tst: l 1.050 a 0.695 clct[np.int64(4), np.int64(10), np.int64(10), np.int64(16)] cl_acc 0.850  10.030sec\n",
      "Epoch 27 tr: l 0.807 a 0.746 clct[np.int64(34), np.int64(50), np.int64(49), np.int64(67)] cl_acc 0.910  lr 0.087342 30.900sec(train) 12.317sec(infer)\n",
      "Epoch 27 tst: l 0.991 a 0.711 clct[np.int64(7), np.int64(10), np.int64(10), np.int64(13)] cl_acc 0.925  9.473sec\n",
      "Epoch 28 tr: l 0.764 a 0.762 clct[np.int64(41), np.int64(50), np.int64(50), np.int64(59)] cl_acc 0.955  lr 0.086905 31.486sec(train) 11.251sec(infer)\n",
      "Epoch 28 tst: l 0.927 a 0.730 clct[np.int64(8), np.int64(10), np.int64(10), np.int64(12)] cl_acc 0.950  9.324sec\n",
      "Epoch 29 tr: l 0.710 a 0.778 clct[np.int64(46), np.int64(50), np.int64(50), np.int64(54)] cl_acc 0.980  lr 0.086471 31.948sec(train) 11.819sec(infer)\n",
      "Epoch 29 tst: l 0.869 a 0.746 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.089sec\n",
      "Epoch 30 tr: l 0.671 a 0.789 clct[np.int64(47), np.int64(50), np.int64(50), np.int64(53)] cl_acc 0.985  lr 0.086038 31.155sec(train) 12.326sec(infer)\n",
      "Epoch 30 tst: l 0.823 a 0.759 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  8.810sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 31 tr: l 0.674 a 0.793 clct[np.int64(49), np.int64(50), np.int64(50), np.int64(51)] cl_acc 0.995  lr 0.085608 32.019sec(train) 10.525sec(infer)\n",
      "Epoch 31 tst: l 0.807 a 0.767 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.053sec\n",
      "Epoch 32 tr: l 0.639 a 0.796 clct[np.int64(49), np.int64(50), np.int64(50), np.int64(51)] cl_acc 0.995  lr 0.085180 31.067sec(train) 12.326sec(infer)\n",
      "Epoch 32 tst: l 0.786 a 0.771 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.383sec\n",
      "Epoch 33 tr: l 0.611 a 0.803 clct[np.int64(49), np.int64(50), np.int64(50), np.int64(51)] cl_acc 0.995  lr 0.084754 30.556sec(train) 11.957sec(infer)\n",
      "Epoch 33 tst: l 0.748 a 0.778 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  8.866sec\n",
      "Epoch 34 tr: l 0.598 a 0.805 clct[np.int64(49), np.int64(50), np.int64(50), np.int64(51)] cl_acc 0.995  lr 0.084331 31.842sec(train) 11.009sec(infer)\n",
      "Epoch 34 tst: l 0.735 a 0.782 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.477sec\n",
      "Epoch 35 tr: l 0.578 a 0.810 clct[np.int64(49), np.int64(50), np.int64(50), np.int64(51)] cl_acc 0.995  lr 0.083909 30.771sec(train) 12.356sec(infer)\n",
      "Epoch 35 tst: l 0.711 a 0.785 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.125sec\n",
      "Epoch 36 tr: l 0.569 a 0.813 clct[np.int64(49), np.int64(50), np.int64(50), np.int64(51)] cl_acc 0.995  lr 0.083489 31.073sec(train) 11.360sec(infer)\n",
      "Epoch 36 tst: l 0.701 a 0.789 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.588sec\n",
      "Epoch 37 tr: l 0.558 a 0.815 clct[np.int64(49), np.int64(50), np.int64(50), np.int64(51)] cl_acc 0.995  lr 0.083072 31.440sec(train) 11.726sec(infer)\n",
      "Epoch 37 tst: l 0.688 a 0.792 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.610sec\n",
      "Epoch 38 tr: l 0.548 a 0.818 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.082657 30.650sec(train) 12.160sec(infer)\n",
      "Epoch 38 tst: l 0.675 a 0.794 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.484sec\n",
      "Epoch 39 tr: l 0.540 a 0.820 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.082243 31.337sec(train) 10.752sec(infer)\n",
      "Epoch 39 tst: l 0.662 a 0.797 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.300sec\n",
      "Epoch 40 tr: l 0.527 a 0.823 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.081832 30.939sec(train) 12.552sec(infer)\n",
      "Epoch 40 tst: l 0.653 a 0.799 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.687sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 41 tr: l 0.515 a 0.826 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.081423 30.500sec(train) 12.094sec(infer)\n",
      "Epoch 41 tst: l 0.646 a 0.801 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.166sec\n",
      "Epoch 42 tr: l 0.508 a 0.827 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.081016 31.930sec(train) 10.928sec(infer)\n",
      "Epoch 42 tst: l 0.640 a 0.802 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.637sec\n",
      "Epoch 43 tr: l 0.503 a 0.830 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.080611 30.481sec(train) 12.288sec(infer)\n",
      "Epoch 43 tst: l 0.631 a 0.805 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.308sec\n",
      "Epoch 44 tr: l 0.495 a 0.831 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.080208 30.534sec(train) 11.455sec(infer)\n",
      "Epoch 44 tst: l 0.621 a 0.806 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.721sec\n",
      "Epoch 45 tr: l 0.486 a 0.835 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.079807 31.674sec(train) 11.621sec(infer)\n",
      "Epoch 45 tst: l 0.614 a 0.808 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.500sec\n",
      "Epoch 46 tr: l 0.484 a 0.835 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.079408 30.425sec(train) 12.254sec(infer)\n",
      "Epoch 46 tst: l 0.610 a 0.809 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.772sec\n",
      "Epoch 47 tr: l 0.474 a 0.838 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.079010 31.172sec(train) 10.810sec(infer)\n",
      "Epoch 47 tst: l 0.603 a 0.812 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.306sec\n",
      "Epoch 48 tr: l 0.472 a 0.838 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.078615 30.872sec(train) 12.180sec(infer)\n",
      "Epoch 48 tst: l 0.599 a 0.812 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.543sec\n",
      "Epoch 49 tr: l 0.464 a 0.841 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.078222 30.493sec(train) 12.220sec(infer)\n",
      "Epoch 49 tst: l 0.593 a 0.814 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.200sec\n",
      "Epoch 50 tr: l 0.458 a 0.841 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.077831 31.960sec(train) 10.804sec(infer)\n",
      "Epoch 50 tst: l 0.588 a 0.815 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.719sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 51 tr: l 0.449 a 0.844 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.077442 30.529sec(train) 12.282sec(infer)\n",
      "Epoch 51 tst: l 0.584 a 0.816 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.541sec\n",
      "Epoch 52 tr: l 0.452 a 0.844 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.077055 30.076sec(train) 11.645sec(infer)\n",
      "Epoch 52 tst: l 0.578 a 0.817 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.456sec\n",
      "Epoch 53 tr: l 0.442 a 0.847 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.076670 31.669sec(train) 11.459sec(infer)\n",
      "Epoch 53 tst: l 0.576 a 0.819 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.775sec\n",
      "Epoch 54 tr: l 0.437 a 0.847 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.076286 30.251sec(train) 12.299sec(infer)\n",
      "Epoch 54 tst: l 0.571 a 0.819 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.012sec\n",
      "Epoch 55 tr: l 0.433 a 0.849 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.075905 31.029sec(train) 10.984sec(infer)\n",
      "Epoch 55 tst: l 0.569 a 0.820 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.197sec\n",
      "Epoch 56 tr: l 0.426 a 0.852 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.075525 30.946sec(train) 12.058sec(infer)\n",
      "Epoch 56 tst: l 0.562 a 0.822 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.755sec\n",
      "Epoch 57 tr: l 0.424 a 0.852 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.075148 30.281sec(train) 12.296sec(infer)\n",
      "Epoch 57 tst: l 0.561 a 0.823 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.459sec\n",
      "Epoch 58 tr: l 0.418 a 0.853 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.074772 31.712sec(train) 10.534sec(infer)\n",
      "Epoch 58 tst: l 0.557 a 0.824 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.761sec\n",
      "Epoch 59 tr: l 0.413 a 0.855 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.074398 30.307sec(train) 12.164sec(infer)\n",
      "Epoch 59 tst: l 0.553 a 0.825 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.719sec\n",
      "Epoch 60 tr: l 0.412 a 0.854 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.074026 30.380sec(train) 11.847sec(infer)\n",
      "Epoch 60 tst: l 0.549 a 0.825 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.340sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 61 tr: l 0.412 a 0.855 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.073656 31.787sec(train) 11.414sec(infer)\n",
      "Epoch 61 tst: l 0.549 a 0.826 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.827sec\n",
      "Epoch 62 tr: l 0.408 a 0.856 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.073288 30.095sec(train) 12.233sec(infer)\n",
      "Epoch 62 tst: l 0.544 a 0.827 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.190sec\n",
      "Epoch 63 tr: l 0.405 a 0.858 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.072921 30.591sec(train) 11.235sec(infer)\n",
      "Epoch 63 tst: l 0.543 a 0.828 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.899sec\n",
      "Epoch 64 tr: l 0.399 a 0.860 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.072557 31.041sec(train) 11.823sec(infer)\n",
      "Epoch 64 tst: l 0.539 a 0.828 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.729sec\n",
      "Epoch 65 tr: l 0.395 a 0.860 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.072194 28.934sec(train) 11.795sec(infer)\n",
      "Epoch 65 tst: l 0.538 a 0.830 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.735sec\n",
      "Epoch 66 tr: l 0.390 a 0.862 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.071833 30.402sec(train) 12.257sec(infer)\n",
      "Epoch 66 tst: l 0.534 a 0.830 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.593sec\n",
      "Epoch 67 tr: l 0.390 a 0.861 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.071474 31.269sec(train) 10.502sec(infer)\n",
      "Epoch 67 tst: l 0.534 a 0.830 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.548sec\n",
      "Epoch 68 tr: l 0.389 a 0.862 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.071116 30.651sec(train) 12.289sec(infer)\n",
      "Epoch 68 tst: l 0.529 a 0.832 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.732sec\n",
      "Epoch 69 tr: l 0.385 a 0.863 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.070761 30.082sec(train) 11.983sec(infer)\n",
      "Epoch 69 tst: l 0.527 a 0.832 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.210sec\n",
      "Epoch 70 tr: l 0.381 a 0.865 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.070407 31.798sec(train) 10.874sec(infer)\n",
      "Epoch 70 tst: l 0.525 a 0.832 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.744sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 71 tr: l 0.379 a 0.865 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.070055 30.288sec(train) 12.353sec(infer)\n",
      "Epoch 71 tst: l 0.522 a 0.834 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.477sec\n",
      "Epoch 72 tr: l 0.375 a 0.866 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.069705 30.531sec(train) 11.456sec(infer)\n",
      "Epoch 72 tst: l 0.519 a 0.834 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.503sec\n",
      "Epoch 73 tr: l 0.375 a 0.866 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.069356 31.614sec(train) 11.410sec(infer)\n",
      "Epoch 73 tst: l 0.518 a 0.835 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.693sec\n",
      "Epoch 74 tr: l 0.369 a 0.868 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.069009 30.211sec(train) 12.271sec(infer)\n",
      "Epoch 74 tst: l 0.516 a 0.835 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.849sec\n",
      "Epoch 75 tr: l 0.372 a 0.868 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.068664 31.005sec(train) 10.753sec(infer)\n",
      "Epoch 75 tst: l 0.514 a 0.837 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.082sec\n",
      "Epoch 76 tr: l 0.366 a 0.870 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.068321 30.978sec(train) 12.088sec(infer)\n",
      "Epoch 76 tst: l 0.513 a 0.836 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.735sec\n",
      "Epoch 77 tr: l 0.365 a 0.869 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.067979 30.561sec(train) 12.264sec(infer)\n",
      "Epoch 77 tst: l 0.511 a 0.837 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.285sec\n",
      "Epoch 78 tr: l 0.358 a 0.872 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.067639 31.400sec(train) 10.581sec(infer)\n",
      "Epoch 78 tst: l 0.508 a 0.838 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.752sec\n",
      "Epoch 79 tr: l 0.358 a 0.871 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.067301 30.001sec(train) 12.273sec(infer)\n",
      "Epoch 79 tst: l 0.508 a 0.838 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.683sec\n",
      "Epoch 80 tr: l 0.355 a 0.873 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.066965 30.037sec(train) 11.606sec(infer)\n",
      "Epoch 80 tst: l 0.507 a 0.838 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.350sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 81 tr: l 0.357 a 0.872 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.066630 31.877sec(train) 11.171sec(infer)\n",
      "Epoch 81 tst: l 0.504 a 0.839 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.768sec\n",
      "Epoch 82 tr: l 0.353 a 0.873 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.066297 30.087sec(train) 12.269sec(infer)\n",
      "Epoch 82 tst: l 0.504 a 0.840 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.267sec\n",
      "Epoch 83 tr: l 0.351 a 0.874 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.065965 30.575sec(train) 11.080sec(infer)\n",
      "Epoch 83 tst: l 0.501 a 0.840 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.865sec\n",
      "Epoch 84 tr: l 0.350 a 0.874 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.065635 30.994sec(train) 11.869sec(infer)\n",
      "Epoch 84 tst: l 0.502 a 0.840 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.808sec\n",
      "Epoch 85 tr: l 0.344 a 0.875 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.065307 30.478sec(train) 12.167sec(infer)\n",
      "Epoch 85 tst: l 0.498 a 0.841 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.564sec\n",
      "Epoch 86 tr: l 0.345 a 0.876 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064981 31.449sec(train) 10.483sec(infer)\n",
      "Epoch 86 tst: l 0.497 a 0.841 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.546sec\n",
      "Epoch 87 tr: l 0.344 a 0.876 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064656 30.662sec(train) 12.335sec(infer)\n",
      "Epoch 87 tst: l 0.496 a 0.841 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.766sec\n",
      "Epoch 88 tr: l 0.337 a 0.877 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064333 30.025sec(train) 12.042sec(infer)\n",
      "Epoch 88 tst: l 0.495 a 0.842 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.261sec\n",
      "Epoch 89 tr: l 0.337 a 0.878 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064011 31.791sec(train) 10.906sec(infer)\n",
      "Epoch 89 tst: l 0.493 a 0.843 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.748sec\n",
      "Epoch 90 tr: l 0.333 a 0.879 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.063691 30.305sec(train) 12.301sec(infer)\n",
      "Epoch 90 tst: l 0.491 a 0.843 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.399sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 91 tr: l 0.330 a 0.880 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.063372 30.089sec(train) 11.456sec(infer)\n",
      "Epoch 91 tst: l 0.490 a 0.843 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.537sec\n",
      "Epoch 92 tr: l 0.330 a 0.880 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.063056 31.732sec(train) 11.475sec(infer)\n",
      "Epoch 92 tst: l 0.490 a 0.843 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.858sec\n",
      "Epoch 93 tr: l 0.328 a 0.881 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.062740 29.949sec(train) 12.250sec(infer)\n",
      "Epoch 93 tst: l 0.488 a 0.844 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.000sec\n",
      "Epoch 94 tr: l 0.327 a 0.881 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.062427 31.004sec(train) 10.931sec(infer)\n",
      "Epoch 94 tst: l 0.488 a 0.844 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.101sec\n",
      "Epoch 95 tr: l 0.326 a 0.881 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.062114 31.157sec(train) 12.054sec(infer)\n",
      "Epoch 95 tst: l 0.485 a 0.845 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.835sec\n",
      "Epoch 96 tr: l 0.324 a 0.882 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.061804 30.482sec(train) 12.316sec(infer)\n",
      "Epoch 96 tst: l 0.485 a 0.845 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.441sec\n",
      "Epoch 97 tr: l 0.324 a 0.882 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.061495 31.665sec(train) 10.505sec(infer)\n",
      "Epoch 97 tst: l 0.484 a 0.845 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.780sec\n",
      "Epoch 98 tr: l 0.323 a 0.882 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.061187 30.514sec(train) 12.341sec(infer)\n",
      "Epoch 98 tst: l 0.483 a 0.846 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.771sec\n",
      "Epoch 99 tr: l 0.317 a 0.884 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.060881 29.854sec(train) 11.845sec(infer)\n",
      "Epoch 99 tst: l 0.482 a 0.846 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.215sec\n",
      "Epoch 100 tr: l 0.338 a 0.880 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.006058 31.953sec(train) 10.996sec(infer)\n",
      "Epoch 100 tst: l 0.474 a 0.849 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.748sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 101 tr: l 0.347 a 0.877 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.006027 30.332sec(train) 12.274sec(infer)\n",
      "Epoch 101 tst: l 0.470 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.278sec\n",
      "Epoch 102 tr: l 0.351 a 0.877 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005997 30.687sec(train) 11.274sec(infer)\n",
      "Epoch 102 tst: l 0.468 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.671sec\n",
      "Epoch 103 tr: l 0.351 a 0.876 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005967 31.315sec(train) 11.660sec(infer)\n",
      "Epoch 103 tst: l 0.467 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.863sec\n",
      "Epoch 104 tr: l 0.352 a 0.876 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005937 30.198sec(train) 12.242sec(infer)\n",
      "Epoch 104 tst: l 0.466 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.774sec\n",
      "Epoch 105 tr: l 0.352 a 0.876 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005908 31.115sec(train) 10.658sec(infer)\n",
      "Epoch 105 tst: l 0.465 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.335sec\n",
      "Epoch 106 tr: l 0.351 a 0.876 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005878 30.509sec(train) 12.141sec(infer)\n",
      "Epoch 106 tst: l 0.465 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.809sec\n",
      "Epoch 107 tr: l 0.352 a 0.876 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005849 30.220sec(train) 12.176sec(infer)\n",
      "Epoch 107 tst: l 0.464 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.271sec\n",
      "Epoch 108 tr: l 0.352 a 0.876 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005820 31.749sec(train) 10.807sec(infer)\n",
      "Epoch 108 tst: l 0.464 a 0.852 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.783sec\n",
      "Epoch 109 tr: l 0.352 a 0.876 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005790 30.384sec(train) 12.165sec(infer)\n",
      "Epoch 109 tst: l 0.463 a 0.852 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.653sec\n",
      "Epoch 110 tr: l 0.351 a 0.877 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005762 29.968sec(train) 11.594sec(infer)\n",
      "Epoch 110 tst: l 0.463 a 0.852 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.300sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 111 tr: l 0.350 a 0.877 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005733 31.750sec(train) 11.234sec(infer)\n",
      "Epoch 111 tst: l 0.463 a 0.852 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.800sec\n",
      "Epoch 112 tr: l 0.350 a 0.877 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005704 30.367sec(train) 12.123sec(infer)\n",
      "Epoch 112 tst: l 0.462 a 0.852 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.139sec\n",
      "Epoch 113 tr: l 0.350 a 0.877 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005676 30.644sec(train) 11.055sec(infer)\n",
      "Epoch 113 tst: l 0.462 a 0.852 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.824sec\n",
      "Epoch 114 tr: l 0.349 a 0.877 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005647 31.072sec(train) 11.799sec(infer)\n",
      "Epoch 114 tst: l 0.462 a 0.852 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.776sec\n",
      "Epoch 115 tr: l 0.350 a 0.877 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005619 30.478sec(train) 12.162sec(infer)\n",
      "Epoch 115 tst: l 0.462 a 0.852 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.534sec\n",
      "Epoch 116 tr: l 0.351 a 0.877 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005591 31.320sec(train) 10.505sec(infer)\n",
      "Epoch 116 tst: l 0.461 a 0.852 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.526sec\n",
      "Epoch 117 tr: l 0.350 a 0.877 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005563 30.431sec(train) 12.316sec(infer)\n",
      "Epoch 117 tst: l 0.462 a 0.852 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.764sec\n",
      "Epoch 118 tr: l 0.348 a 0.878 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005535 30.205sec(train) 12.005sec(infer)\n",
      "Epoch 118 tst: l 0.461 a 0.852 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.240sec\n",
      "Epoch 119 tr: l 0.349 a 0.878 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005507 31.802sec(train) 10.895sec(infer)\n",
      "Epoch 119 tst: l 0.461 a 0.852 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.823sec\n",
      "Epoch 120 tr: l 0.349 a 0.878 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005480 30.453sec(train) 12.249sec(infer)\n",
      "Epoch 120 tst: l 0.461 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.402sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 121 tr: l 0.349 a 0.878 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005452 30.566sec(train) 11.323sec(infer)\n",
      "Epoch 121 tst: l 0.461 a 0.852 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.666sec\n",
      "Epoch 122 tr: l 0.348 a 0.878 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005425 31.284sec(train) 11.578sec(infer)\n",
      "Epoch 122 tst: l 0.461 a 0.852 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.838sec\n",
      "Epoch 123 tr: l 0.347 a 0.878 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005398 30.105sec(train) 12.361sec(infer)\n",
      "Epoch 123 tst: l 0.461 a 0.852 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.891sec\n",
      "Epoch 124 tr: l 0.346 a 0.879 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005371 31.114sec(train) 10.761sec(infer)\n",
      "Epoch 124 tst: l 0.460 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.185sec\n",
      "Epoch 125 tr: l 0.348 a 0.878 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005344 31.021sec(train) 12.131sec(infer)\n",
      "Epoch 125 tst: l 0.460 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.799sec\n",
      "Epoch 126 tr: l 0.347 a 0.878 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005318 30.423sec(train) 12.230sec(infer)\n",
      "Epoch 126 tst: l 0.460 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.263sec\n",
      "Epoch 127 tr: l 0.346 a 0.879 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005291 31.602sec(train) 10.571sec(infer)\n",
      "Epoch 127 tst: l 0.460 a 0.852 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.702sec\n",
      "Epoch 128 tr: l 0.346 a 0.878 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005264 30.359sec(train) 12.205sec(infer)\n",
      "Epoch 128 tst: l 0.460 a 0.852 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.810sec\n",
      "Epoch 129 tr: l 0.346 a 0.879 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005238 30.177sec(train) 11.724sec(infer)\n",
      "Epoch 129 tst: l 0.460 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.348sec\n",
      "Epoch 130 tr: l 0.345 a 0.879 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005212 32.023sec(train) 11.266sec(infer)\n",
      "Epoch 130 tst: l 0.460 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.725sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 131 tr: l 0.346 a 0.879 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005186 30.281sec(train) 12.130sec(infer)\n",
      "Epoch 131 tst: l 0.459 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.080sec\n",
      "Epoch 132 tr: l 0.346 a 0.879 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005160 30.666sec(train) 11.059sec(infer)\n",
      "Epoch 132 tst: l 0.460 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.939sec\n",
      "Epoch 133 tr: l 0.345 a 0.879 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005134 31.535sec(train) 11.995sec(infer)\n",
      "Epoch 133 tst: l 0.459 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.718sec\n",
      "Epoch 134 tr: l 0.346 a 0.879 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005108 30.436sec(train) 12.292sec(infer)\n",
      "Epoch 134 tst: l 0.459 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.362sec\n",
      "Epoch 135 tr: l 0.346 a 0.879 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005083 31.214sec(train) 10.570sec(infer)\n",
      "Epoch 135 tst: l 0.459 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.824sec\n",
      "Epoch 136 tr: l 0.344 a 0.879 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005058 30.209sec(train) 12.294sec(infer)\n",
      "Epoch 136 tst: l 0.459 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.710sec\n",
      "Epoch 137 tr: l 0.346 a 0.879 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005032 30.192sec(train) 11.826sec(infer)\n",
      "Epoch 137 tst: l 0.459 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.260sec\n",
      "Epoch 138 tr: l 0.346 a 0.879 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005007 31.931sec(train) 11.104sec(infer)\n",
      "Epoch 138 tst: l 0.459 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.813sec\n",
      "Epoch 139 tr: l 0.345 a 0.879 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004982 30.294sec(train) 12.279sec(infer)\n",
      "Epoch 139 tst: l 0.459 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.391sec\n",
      "Epoch 140 tr: l 0.344 a 0.879 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004957 30.420sec(train) 11.360sec(infer)\n",
      "Epoch 140 tst: l 0.459 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.635sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 141 tr: l 0.345 a 0.879 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004932 31.499sec(train) 11.682sec(infer)\n",
      "Epoch 141 tst: l 0.459 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.759sec\n",
      "Epoch 142 tr: l 0.344 a 0.879 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004908 30.398sec(train) 12.130sec(infer)\n",
      "Epoch 142 tst: l 0.459 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.816sec\n",
      "Epoch 143 tr: l 0.343 a 0.879 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004883 31.080sec(train) 10.625sec(infer)\n",
      "Epoch 143 tst: l 0.459 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.408sec\n",
      "Epoch 144 tr: l 0.343 a 0.879 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004859 31.023sec(train) 12.316sec(infer)\n",
      "Epoch 144 tst: l 0.458 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.812sec\n",
      "Epoch 145 tr: l 0.343 a 0.880 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004834 30.212sec(train) 12.166sec(infer)\n",
      "Epoch 145 tst: l 0.458 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.291sec\n",
      "Epoch 146 tr: l 0.344 a 0.879 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004810 32.145sec(train) 10.713sec(infer)\n",
      "Epoch 146 tst: l 0.458 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.763sec\n",
      "Epoch 147 tr: l 0.344 a 0.879 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004786 29.841sec(train) 10.546sec(infer)\n",
      "Epoch 147 tst: l 0.458 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.479sec\n",
      "Epoch 148 tr: l 0.343 a 0.880 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004762 33.491sec(train) 9.636sec(infer)\n",
      "Epoch 148 tst: l 0.458 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  8.457sec\n",
      "Epoch 149 tr: l 0.343 a 0.880 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004738 34.521sec(train) 9.956sec(infer)\n",
      "Epoch 149 tst: l 0.458 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.678sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "---train cluster Ended in 2.22 hour (7982.572 sec) \n",
      "---------------------------------DFCA-LI, lr: 0.1, seed: 4506---------------------------------\n",
      "config: {'m': 200, 'm_test': 40, 'p': 4, 'n': 1500, 'uneven': True, 'local_model_init': True, 'Gp': 0.15, 'graph': 'er', 'agg': 'seq', '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:2\n",
      "Epoch -1 tr: l 3.864 a 0.024 clct[np.int64(57), np.int64(45), np.int64(47), np.int64(51)] cl_acc 0.295  8.930sec\n",
      "Epoch -1 tst: l 3.858 a 0.027 clct[np.int64(7), np.int64(11), np.int64(16), np.int64(6)] cl_acc 0.350  9.670sec\n",
      "Epoch 0 tr: l 3.597 a 0.312 clct[np.int64(57), np.int64(45), np.int64(47), np.int64(51)] cl_acc 0.295  lr 0.100000 33.308sec(train) 10.645sec(infer)\n",
      "Epoch 0 tst: l 3.791 a 0.088 clct[np.int64(12), np.int64(8), np.int64(12), np.int64(8)] cl_acc 0.325  9.906sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 1 tr: l 3.591 a 0.284 clct[np.int64(55), np.int64(47), np.int64(47), np.int64(51)] cl_acc 0.305  lr 0.099500 33.074sec(train) 10.271sec(infer)\n",
      "Epoch 1 tst: l 3.780 a 0.111 clct[np.int64(11), np.int64(9), np.int64(14), np.int64(6)] cl_acc 0.350  8.221sec\n",
      "Epoch 2 tr: l 3.570 a 0.233 clct[np.int64(54), np.int64(48), np.int64(47), np.int64(51)] cl_acc 0.310  lr 0.099003 34.518sec(train) 9.447sec(infer)\n",
      "Epoch 2 tst: l 3.758 a 0.114 clct[np.int64(17), np.int64(8), np.int64(8), np.int64(7)] cl_acc 0.400  9.794sec\n",
      "Epoch 3 tr: l 3.511 a 0.212 clct[np.int64(52), np.int64(48), np.int64(49), np.int64(51)] cl_acc 0.310  lr 0.098507 32.881sec(train) 10.961sec(infer)\n",
      "Epoch 3 tst: l 3.710 a 0.113 clct[np.int64(16), np.int64(9), np.int64(9), np.int64(6)] cl_acc 0.425  9.118sec\n",
      "Epoch 4 tr: l 3.384 a 0.230 clct[np.int64(51), np.int64(47), np.int64(49), np.int64(53)] cl_acc 0.320  lr 0.098015 33.161sec(train) 9.650sec(infer)\n",
      "Epoch 4 tst: l 3.628 a 0.128 clct[np.int64(17), np.int64(7), np.int64(9), np.int64(7)] cl_acc 0.425  8.943sec\n",
      "Epoch 5 tr: l 3.209 a 0.272 clct[np.int64(50), np.int64(50), np.int64(49), np.int64(51)] cl_acc 0.335  lr 0.097525 33.165sec(train) 10.811sec(infer)\n",
      "Epoch 5 tst: l 3.499 a 0.157 clct[np.int64(17), np.int64(8), np.int64(6), np.int64(9)] cl_acc 0.500  9.690sec\n",
      "Epoch 6 tr: l 3.000 a 0.304 clct[np.int64(52), np.int64(54), np.int64(47), np.int64(47)] cl_acc 0.355  lr 0.097037 32.770sec(train) 11.187sec(infer)\n",
      "Epoch 6 tst: l 3.335 a 0.183 clct[np.int64(16), np.int64(8), np.int64(9), np.int64(7)] cl_acc 0.475  8.169sec\n",
      "Epoch 7 tr: l 2.802 a 0.332 clct[np.int64(54), np.int64(53), np.int64(49), np.int64(44)] cl_acc 0.395  lr 0.096552 33.927sec(train) 9.379sec(infer)\n",
      "Epoch 7 tst: l 3.164 a 0.218 clct[np.int64(15), np.int64(11), np.int64(11), np.int64(3)] cl_acc 0.575  9.610sec\n",
      "Epoch 8 tr: l 2.635 a 0.357 clct[np.int64(52), np.int64(57), np.int64(47), np.int64(44)] cl_acc 0.450  lr 0.096069 32.218sec(train) 11.567sec(infer)\n",
      "Epoch 8 tst: l 2.972 a 0.250 clct[np.int64(10), np.int64(12), np.int64(10), np.int64(8)] cl_acc 0.650  9.486sec\n",
      "Epoch 9 tr: l 2.428 a 0.395 clct[np.int64(53), np.int64(61), np.int64(43), np.int64(43)] cl_acc 0.495  lr 0.095589 32.463sec(train) 10.787sec(infer)\n",
      "Epoch 9 tst: l 2.767 a 0.300 clct[np.int64(12), np.int64(13), np.int64(8), np.int64(7)] cl_acc 0.600  8.292sec\n",
      "Epoch 10 tr: l 2.206 a 0.440 clct[np.int64(57), np.int64(64), np.int64(41), np.int64(38)] cl_acc 0.555  lr 0.095111 33.488sec(train) 10.829sec(infer)\n",
      "Epoch 10 tst: l 2.567 a 0.344 clct[np.int64(12), np.int64(13), np.int64(8), np.int64(7)] cl_acc 0.650  9.659sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 11 tr: l 2.006 a 0.486 clct[np.int64(58), np.int64(63), np.int64(43), np.int64(36)] cl_acc 0.605  lr 0.094635 32.110sec(train) 11.810sec(infer)\n",
      "Epoch 11 tst: l 2.331 a 0.402 clct[np.int64(15), np.int64(12), np.int64(9), np.int64(4)] cl_acc 0.650  8.603sec\n",
      "Epoch 12 tr: l 1.809 a 0.522 clct[np.int64(59), np.int64(56), np.int64(48), np.int64(37)] cl_acc 0.645  lr 0.094162 32.958sec(train) 10.217sec(infer)\n",
      "Epoch 12 tst: l 2.120 a 0.445 clct[np.int64(15), np.int64(11), np.int64(9), np.int64(5)] cl_acc 0.725  9.070sec\n",
      "Epoch 13 tr: l 1.632 a 0.568 clct[np.int64(64), np.int64(54), np.int64(50), np.int64(32)] cl_acc 0.710  lr 0.093691 32.196sec(train) 12.008sec(infer)\n",
      "Epoch 13 tst: l 1.922 a 0.498 clct[np.int64(15), np.int64(11), np.int64(8), np.int64(6)] cl_acc 0.725  9.628sec\n",
      "Epoch 14 tr: l 1.488 a 0.593 clct[np.int64(66), np.int64(52), np.int64(49), np.int64(33)] cl_acc 0.780  lr 0.093223 31.691sec(train) 11.927sec(infer)\n",
      "Epoch 14 tst: l 1.751 a 0.528 clct[np.int64(16), np.int64(11), np.int64(8), np.int64(5)] cl_acc 0.800  8.011sec\n",
      "Epoch 15 tr: l 1.361 a 0.622 clct[np.int64(68), np.int64(51), np.int64(47), np.int64(34)] cl_acc 0.840  lr 0.092757 33.124sec(train) 10.940sec(infer)\n",
      "Epoch 15 tst: l 1.595 a 0.567 clct[np.int64(11), np.int64(11), np.int64(8), np.int64(10)] cl_acc 0.875  9.416sec\n",
      "Epoch 16 tr: l 1.217 a 0.659 clct[np.int64(60), np.int64(51), np.int64(50), np.int64(39)] cl_acc 0.925  lr 0.092293 31.373sec(train) 12.472sec(infer)\n",
      "Epoch 16 tst: l 1.435 a 0.606 clct[np.int64(12), np.int64(10), np.int64(10), np.int64(8)] cl_acc 0.950  9.413sec\n",
      "Epoch 17 tr: l 1.085 a 0.695 clct[np.int64(51), np.int64(50), np.int64(50), np.int64(49)] cl_acc 0.995  lr 0.091832 31.738sec(train) 11.470sec(infer)\n",
      "Epoch 17 tst: l 1.295 a 0.648 clct[np.int64(11), np.int64(10), np.int64(10), np.int64(9)] cl_acc 0.975  8.489sec\n",
      "Epoch 18 tr: l 0.971 a 0.716 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.091372 32.019sec(train) 11.845sec(infer)\n",
      "Epoch 18 tst: l 1.149 a 0.682 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.038sec\n",
      "Epoch 19 tr: l 0.891 a 0.731 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.090916 31.023sec(train) 12.404sec(infer)\n",
      "Epoch 19 tst: l 1.044 a 0.707 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  8.634sec\n",
      "Epoch 20 tr: l 0.838 a 0.744 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.090461 32.353sec(train) 10.654sec(infer)\n",
      "Epoch 20 tst: l 0.979 a 0.719 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.048sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 21 tr: l 0.798 a 0.753 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.090009 31.124sec(train) 12.464sec(infer)\n",
      "Epoch 21 tst: l 0.923 a 0.730 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.206sec\n",
      "Epoch 22 tr: l 0.760 a 0.761 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.089559 30.833sec(train) 11.962sec(infer)\n",
      "Epoch 22 tst: l 0.882 a 0.740 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  8.563sec\n",
      "Epoch 23 tr: l 0.733 a 0.769 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.089111 30.151sec(train) 11.884sec(infer)\n",
      "Epoch 23 tst: l 0.855 a 0.743 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  8.868sec\n",
      "Epoch 24 tr: l 0.701 a 0.776 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.088665 32.106sec(train) 11.267sec(infer)\n",
      "Epoch 24 tst: l 0.823 a 0.753 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.598sec\n",
      "Epoch 25 tr: l 0.681 a 0.782 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.088222 30.652sec(train) 12.450sec(infer)\n",
      "Epoch 25 tst: l 0.796 a 0.757 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.896sec\n",
      "Epoch 26 tr: l 0.652 a 0.788 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.087781 31.197sec(train) 11.177sec(infer)\n",
      "Epoch 26 tst: l 0.774 a 0.764 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.115sec\n",
      "Epoch 27 tr: l 0.630 a 0.794 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.087342 30.870sec(train) 12.142sec(infer)\n",
      "Epoch 27 tst: l 0.756 a 0.768 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.846sec\n",
      "Epoch 28 tr: l 0.614 a 0.799 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.086905 30.228sec(train) 12.407sec(infer)\n",
      "Epoch 28 tst: l 0.741 a 0.770 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.317sec\n",
      "Epoch 29 tr: l 0.603 a 0.800 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.086471 31.590sec(train) 10.753sec(infer)\n",
      "Epoch 29 tst: l 0.729 a 0.774 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.955sec\n",
      "Epoch 30 tr: l 0.589 a 0.803 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.086038 30.287sec(train) 12.436sec(infer)\n",
      "Epoch 30 tst: l 0.714 a 0.776 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.926sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 31 tr: l 0.577 a 0.807 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.085608 30.158sec(train) 11.689sec(infer)\n",
      "Epoch 31 tst: l 0.701 a 0.780 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.846sec\n",
      "Epoch 32 tr: l 0.568 a 0.810 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.085180 31.360sec(train) 11.502sec(infer)\n",
      "Epoch 32 tst: l 0.691 a 0.782 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.068sec\n",
      "Epoch 33 tr: l 0.554 a 0.813 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.084754 30.207sec(train) 12.413sec(infer)\n",
      "Epoch 33 tst: l 0.683 a 0.785 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.066sec\n",
      "Epoch 34 tr: l 0.551 a 0.813 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.084331 31.060sec(train) 10.942sec(infer)\n",
      "Epoch 34 tst: l 0.676 a 0.786 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.678sec\n",
      "Epoch 35 tr: l 0.536 a 0.818 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.083909 30.780sec(train) 12.334sec(infer)\n",
      "Epoch 35 tst: l 0.664 a 0.790 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.080sec\n",
      "Epoch 36 tr: l 0.523 a 0.822 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.083489 30.571sec(train) 12.265sec(infer)\n",
      "Epoch 36 tst: l 0.653 a 0.793 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.630sec\n",
      "Epoch 37 tr: l 0.516 a 0.824 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.083072 31.546sec(train) 11.223sec(infer)\n",
      "Epoch 37 tst: l 0.644 a 0.795 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.152sec\n",
      "Epoch 38 tr: l 0.506 a 0.825 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.082657 30.643sec(train) 12.470sec(infer)\n",
      "Epoch 38 tst: l 0.640 a 0.796 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.490sec\n",
      "Epoch 39 tr: l 0.502 a 0.828 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.082243 30.502sec(train) 11.332sec(infer)\n",
      "Epoch 39 tst: l 0.632 a 0.799 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.378sec\n",
      "Epoch 40 tr: l 0.491 a 0.831 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.081832 31.272sec(train) 12.097sec(infer)\n",
      "Epoch 40 tst: l 0.624 a 0.800 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.278sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 41 tr: l 0.485 a 0.832 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.081423 30.597sec(train) 12.501sec(infer)\n",
      "Epoch 41 tst: l 0.622 a 0.801 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.737sec\n",
      "Epoch 42 tr: l 0.481 a 0.834 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.081016 31.393sec(train) 10.756sec(infer)\n",
      "Epoch 42 tst: l 0.616 a 0.802 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.261sec\n",
      "Epoch 43 tr: l 0.471 a 0.836 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.080611 30.462sec(train) 12.451sec(infer)\n",
      "Epoch 43 tst: l 0.609 a 0.805 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.070sec\n",
      "Epoch 44 tr: l 0.465 a 0.838 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.080208 30.441sec(train) 11.631sec(infer)\n",
      "Epoch 44 tst: l 0.605 a 0.805 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.137sec\n",
      "Epoch 45 tr: l 0.458 a 0.839 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.079807 31.426sec(train) 11.790sec(infer)\n",
      "Epoch 45 tst: l 0.598 a 0.808 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.259sec\n",
      "Epoch 46 tr: l 0.455 a 0.841 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.079408 30.391sec(train) 12.415sec(infer)\n",
      "Epoch 46 tst: l 0.594 a 0.809 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.212sec\n",
      "Epoch 47 tr: l 0.451 a 0.842 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.079010 31.179sec(train) 10.742sec(infer)\n",
      "Epoch 47 tst: l 0.591 a 0.810 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.968sec\n",
      "Epoch 48 tr: l 0.445 a 0.844 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.078615 30.755sec(train) 12.588sec(infer)\n",
      "Epoch 48 tst: l 0.585 a 0.811 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.382sec\n",
      "Epoch 49 tr: l 0.441 a 0.844 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.078222 30.730sec(train) 12.035sec(infer)\n",
      "Epoch 49 tst: l 0.581 a 0.812 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.794sec\n",
      "Epoch 50 tr: l 0.434 a 0.846 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.077831 31.753sec(train) 11.483sec(infer)\n",
      "Epoch 50 tst: l 0.578 a 0.812 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.054sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 51 tr: l 0.431 a 0.848 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.077442 30.233sec(train) 12.329sec(infer)\n",
      "Epoch 51 tst: l 0.574 a 0.814 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.177sec\n",
      "Epoch 52 tr: l 0.426 a 0.849 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.077055 30.313sec(train) 10.728sec(infer)\n",
      "Epoch 52 tst: l 0.570 a 0.814 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.642sec\n",
      "Epoch 53 tr: l 0.427 a 0.849 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.076670 30.973sec(train) 12.500sec(infer)\n",
      "Epoch 53 tst: l 0.569 a 0.816 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.294sec\n",
      "Epoch 54 tr: l 0.422 a 0.850 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.076286 30.630sec(train) 12.217sec(infer)\n",
      "Epoch 54 tst: l 0.564 a 0.816 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.743sec\n",
      "Epoch 55 tr: l 0.418 a 0.852 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.075905 32.024sec(train) 11.431sec(infer)\n",
      "Epoch 55 tst: l 0.561 a 0.818 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.282sec\n",
      "Epoch 56 tr: l 0.414 a 0.853 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.075525 30.546sec(train) 12.512sec(infer)\n",
      "Epoch 56 tst: l 0.558 a 0.818 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.612sec\n",
      "Epoch 57 tr: l 0.409 a 0.854 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.075148 30.898sec(train) 11.226sec(infer)\n",
      "Epoch 57 tst: l 0.553 a 0.820 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.638sec\n",
      "Epoch 58 tr: l 0.402 a 0.856 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.074772 31.562sec(train) 12.387sec(infer)\n",
      "Epoch 58 tst: l 0.551 a 0.819 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.285sec\n",
      "Epoch 59 tr: l 0.402 a 0.856 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.074398 29.915sec(train) 12.329sec(infer)\n",
      "Epoch 59 tst: l 0.548 a 0.820 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.718sec\n",
      "Epoch 60 tr: l 0.398 a 0.857 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.074026 32.350sec(train) 11.144sec(infer)\n",
      "Epoch 60 tst: l 0.546 a 0.822 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.272sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 61 tr: l 0.393 a 0.860 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.073656 30.871sec(train) 12.504sec(infer)\n",
      "Epoch 61 tst: l 0.541 a 0.823 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.738sec\n",
      "Epoch 62 tr: l 0.389 a 0.860 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.073288 30.890sec(train) 11.367sec(infer)\n",
      "Epoch 62 tst: l 0.541 a 0.823 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.488sec\n",
      "Epoch 63 tr: l 0.386 a 0.861 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.072921 31.231sec(train) 12.143sec(infer)\n",
      "Epoch 63 tst: l 0.535 a 0.825 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.317sec\n",
      "Epoch 64 tr: l 0.385 a 0.861 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.072557 30.391sec(train) 12.544sec(infer)\n",
      "Epoch 64 tst: l 0.537 a 0.824 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.847sec\n",
      "Epoch 65 tr: l 0.382 a 0.862 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.072194 31.855sec(train) 10.807sec(infer)\n",
      "Epoch 65 tst: l 0.533 a 0.825 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.327sec\n",
      "Epoch 66 tr: l 0.378 a 0.864 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.071833 30.546sec(train) 12.492sec(infer)\n",
      "Epoch 66 tst: l 0.531 a 0.826 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.111sec\n",
      "Epoch 67 tr: l 0.378 a 0.864 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.071474 30.382sec(train) 11.736sec(infer)\n",
      "Epoch 67 tst: l 0.529 a 0.826 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.210sec\n",
      "Epoch 68 tr: l 0.373 a 0.865 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.071116 31.853sec(train) 12.026sec(infer)\n",
      "Epoch 68 tst: l 0.527 a 0.827 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.344sec\n",
      "Epoch 69 tr: l 0.370 a 0.866 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.070761 30.712sec(train) 12.648sec(infer)\n",
      "Epoch 69 tst: l 0.524 a 0.828 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.933sec\n",
      "Epoch 70 tr: l 0.371 a 0.866 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.070407 31.822sec(train) 10.813sec(infer)\n",
      "Epoch 70 tst: l 0.523 a 0.829 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.407sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 71 tr: l 0.370 a 0.868 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.070055 30.350sec(train) 12.665sec(infer)\n",
      "Epoch 71 tst: l 0.522 a 0.829 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.167sec\n",
      "Epoch 72 tr: l 0.362 a 0.868 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.069705 30.691sec(train) 11.494sec(infer)\n",
      "Epoch 72 tst: l 0.523 a 0.829 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.482sec\n",
      "Epoch 73 tr: l 0.360 a 0.869 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.069356 32.840sec(train) 12.376sec(infer)\n",
      "Epoch 73 tst: l 0.519 a 0.830 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.121sec\n",
      "Epoch 74 tr: l 0.360 a 0.869 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.069009 30.582sec(train) 12.591sec(infer)\n",
      "Epoch 74 tst: l 0.518 a 0.830 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.599sec\n",
      "Epoch 75 tr: l 0.358 a 0.870 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.068664 32.019sec(train) 11.353sec(infer)\n",
      "Epoch 75 tst: l 0.514 a 0.831 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.222sec\n",
      "Epoch 76 tr: l 0.357 a 0.870 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.068321 30.774sec(train) 12.483sec(infer)\n",
      "Epoch 76 tst: l 0.513 a 0.831 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.664sec\n",
      "Epoch 77 tr: l 0.353 a 0.871 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.067979 30.984sec(train) 11.425sec(infer)\n",
      "Epoch 77 tst: l 0.511 a 0.832 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.416sec\n",
      "Epoch 78 tr: l 0.350 a 0.873 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.067639 31.237sec(train) 12.155sec(infer)\n",
      "Epoch 78 tst: l 0.508 a 0.833 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.289sec\n",
      "Epoch 79 tr: l 0.351 a 0.872 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.067301 30.401sec(train) 12.516sec(infer)\n",
      "Epoch 79 tst: l 0.514 a 0.830 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.773sec\n",
      "Epoch 80 tr: l 0.349 a 0.873 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.066965 32.270sec(train) 11.113sec(infer)\n",
      "Epoch 80 tst: l 0.507 a 0.833 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.278sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 81 tr: l 0.344 a 0.874 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.066630 30.303sec(train) 12.821sec(infer)\n",
      "Epoch 81 tst: l 0.505 a 0.834 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.832sec\n",
      "Epoch 82 tr: l 0.342 a 0.875 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.066297 31.235sec(train) 11.509sec(infer)\n",
      "Epoch 82 tst: l 0.501 a 0.835 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.172sec\n",
      "Epoch 83 tr: l 0.341 a 0.876 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.065965 31.108sec(train) 12.105sec(infer)\n",
      "Epoch 83 tst: l 0.501 a 0.835 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.371sec\n",
      "Epoch 84 tr: l 0.337 a 0.876 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.065635 30.230sec(train) 12.523sec(infer)\n",
      "Epoch 84 tst: l 0.501 a 0.835 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.855sec\n",
      "Epoch 85 tr: l 0.336 a 0.876 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.065307 31.657sec(train) 10.746sec(infer)\n",
      "Epoch 85 tst: l 0.499 a 0.836 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.257sec\n",
      "Epoch 86 tr: l 0.330 a 0.879 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064981 30.694sec(train) 12.499sec(infer)\n",
      "Epoch 86 tst: l 0.498 a 0.836 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.204sec\n",
      "Epoch 87 tr: l 0.336 a 0.877 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064656 30.629sec(train) 11.725sec(infer)\n",
      "Epoch 87 tst: l 0.496 a 0.837 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.091sec\n",
      "Epoch 88 tr: l 0.330 a 0.879 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064333 31.968sec(train) 12.197sec(infer)\n",
      "Epoch 88 tst: l 0.494 a 0.837 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.291sec\n",
      "Epoch 89 tr: l 0.329 a 0.879 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064011 30.521sec(train) 12.496sec(infer)\n",
      "Epoch 89 tst: l 0.493 a 0.837 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.045sec\n",
      "Epoch 90 tr: l 0.324 a 0.881 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.063691 31.050sec(train) 10.832sec(infer)\n",
      "Epoch 90 tst: l 0.491 a 0.838 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.174sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 91 tr: l 0.327 a 0.880 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.063372 30.411sec(train) 12.615sec(infer)\n",
      "Epoch 91 tst: l 0.490 a 0.839 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.297sec\n",
      "Epoch 92 tr: l 0.321 a 0.882 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.063056 30.115sec(train) 12.013sec(infer)\n",
      "Epoch 92 tst: l 0.490 a 0.838 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.062sec\n",
      "Epoch 93 tr: l 0.321 a 0.882 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.062740 32.298sec(train) 12.072sec(infer)\n",
      "Epoch 93 tst: l 0.490 a 0.838 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.661sec\n",
      "Epoch 94 tr: l 0.321 a 0.882 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.062427 30.788sec(train) 13.083sec(infer)\n",
      "Epoch 94 tst: l 0.488 a 0.838 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.896sec\n",
      "Epoch 95 tr: l 0.317 a 0.883 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.062114 31.477sec(train) 11.040sec(infer)\n",
      "Epoch 95 tst: l 0.487 a 0.839 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.685sec\n",
      "Epoch 96 tr: l 0.313 a 0.884 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.061804 29.858sec(train) 12.720sec(infer)\n",
      "Epoch 96 tst: l 0.488 a 0.839 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.527sec\n",
      "Epoch 97 tr: l 0.315 a 0.883 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.061495 29.639sec(train) 12.446sec(infer)\n",
      "Epoch 97 tst: l 0.484 a 0.840 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.452sec\n",
      "Epoch 98 tr: l 0.315 a 0.882 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.061187 32.272sec(train) 12.447sec(infer)\n",
      "Epoch 98 tst: l 0.485 a 0.840 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.517sec\n",
      "Epoch 99 tr: l 0.311 a 0.885 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.060881 29.712sec(train) 13.184sec(infer)\n",
      "Epoch 99 tst: l 0.483 a 0.841 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.038sec\n",
      "Epoch 100 tr: l 0.328 a 0.882 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.006058 31.362sec(train) 11.680sec(infer)\n",
      "Epoch 100 tst: l 0.475 a 0.843 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.846sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 101 tr: l 0.338 a 0.879 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.006027 30.109sec(train) 13.319sec(infer)\n",
      "Epoch 101 tst: l 0.471 a 0.844 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.168sec\n",
      "Epoch 102 tr: l 0.344 a 0.878 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005997 31.215sec(train) 11.505sec(infer)\n",
      "Epoch 102 tst: l 0.469 a 0.844 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.456sec\n",
      "Epoch 103 tr: l 0.347 a 0.877 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005967 31.095sec(train) 13.158sec(infer)\n",
      "Epoch 103 tst: l 0.467 a 0.845 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.531sec\n",
      "Epoch 104 tr: l 0.348 a 0.877 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005937 29.552sec(train) 12.117sec(infer)\n",
      "Epoch 104 tst: l 0.467 a 0.845 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.650sec\n",
      "Epoch 105 tr: l 0.348 a 0.877 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005908 32.374sec(train) 12.746sec(infer)\n",
      "Epoch 105 tst: l 0.466 a 0.845 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.871sec\n",
      "Epoch 106 tr: l 0.347 a 0.877 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005878 30.913sec(train) 13.166sec(infer)\n",
      "Epoch 106 tst: l 0.466 a 0.845 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.763sec\n",
      "Epoch 107 tr: l 0.346 a 0.877 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005849 32.811sec(train) 12.112sec(infer)\n",
      "Epoch 107 tst: l 0.465 a 0.846 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.150sec\n",
      "Epoch 108 tr: l 0.346 a 0.878 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005820 30.487sec(train) 13.532sec(infer)\n",
      "Epoch 108 tst: l 0.465 a 0.846 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.523sec\n",
      "Epoch 109 tr: l 0.347 a 0.877 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005790 31.424sec(train) 11.518sec(infer)\n",
      "Epoch 109 tst: l 0.465 a 0.846 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.725sec\n",
      "Epoch 110 tr: l 0.345 a 0.878 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005762 30.395sec(train) 13.043sec(infer)\n",
      "Epoch 110 tst: l 0.465 a 0.846 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.919sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 111 tr: l 0.347 a 0.878 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005733 31.121sec(train) 12.128sec(infer)\n",
      "Epoch 111 tst: l 0.464 a 0.846 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.576sec\n",
      "Epoch 112 tr: l 0.347 a 0.878 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005704 31.857sec(train) 12.884sec(infer)\n",
      "Epoch 112 tst: l 0.464 a 0.846 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.284sec\n",
      "Epoch 113 tr: l 0.345 a 0.878 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005676 30.463sec(train) 12.869sec(infer)\n",
      "Epoch 113 tst: l 0.463 a 0.846 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.409sec\n",
      "Epoch 114 tr: l 0.345 a 0.878 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005647 32.894sec(train) 12.396sec(infer)\n",
      "Epoch 114 tst: l 0.463 a 0.846 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.905sec\n",
      "Epoch 115 tr: l 0.347 a 0.878 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005619 30.825sec(train) 13.332sec(infer)\n",
      "Epoch 115 tst: l 0.463 a 0.846 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.147sec\n",
      "Epoch 116 tr: l 0.345 a 0.878 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005591 31.723sec(train) 11.197sec(infer)\n",
      "Epoch 116 tst: l 0.463 a 0.846 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.588sec\n",
      "Epoch 117 tr: l 0.345 a 0.878 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005563 29.973sec(train) 13.179sec(infer)\n",
      "Epoch 117 tst: l 0.463 a 0.846 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.348sec\n",
      "Epoch 118 tr: l 0.345 a 0.878 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005535 29.643sec(train) 12.558sec(infer)\n",
      "Epoch 118 tst: l 0.462 a 0.846 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.116sec\n",
      "Epoch 119 tr: l 0.344 a 0.879 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005507 32.796sec(train) 12.504sec(infer)\n",
      "Epoch 119 tst: l 0.462 a 0.846 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.133sec\n",
      "Epoch 120 tr: l 0.343 a 0.879 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005480 30.100sec(train) 13.249sec(infer)\n",
      "Epoch 120 tst: l 0.462 a 0.846 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.974sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 121 tr: l 0.344 a 0.879 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005452 31.222sec(train) 11.217sec(infer)\n",
      "Epoch 121 tst: l 0.462 a 0.846 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.474sec\n",
      "Epoch 122 tr: l 0.344 a 0.879 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005425 31.118sec(train) 13.432sec(infer)\n",
      "Epoch 122 tst: l 0.462 a 0.847 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.747sec\n",
      "Epoch 123 tr: l 0.344 a 0.879 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005398 30.314sec(train) 11.580sec(infer)\n",
      "Epoch 123 tst: l 0.462 a 0.846 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.413sec\n",
      "Epoch 124 tr: l 0.345 a 0.879 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005371 31.431sec(train) 12.520sec(infer)\n",
      "Epoch 124 tst: l 0.462 a 0.847 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.439sec\n",
      "Epoch 125 tr: l 0.342 a 0.879 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005344 29.950sec(train) 13.281sec(infer)\n",
      "Epoch 125 tst: l 0.462 a 0.847 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.905sec\n",
      "Epoch 126 tr: l 0.343 a 0.879 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005318 31.807sec(train) 11.741sec(infer)\n",
      "Epoch 126 tst: l 0.462 a 0.846 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.639sec\n",
      "Epoch 127 tr: l 0.343 a 0.879 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005291 30.433sec(train) 13.205sec(infer)\n",
      "Epoch 127 tst: l 0.462 a 0.847 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.659sec\n",
      "Epoch 128 tr: l 0.343 a 0.879 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005264 31.083sec(train) 11.757sec(infer)\n",
      "Epoch 128 tst: l 0.461 a 0.847 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.324sec\n",
      "Epoch 129 tr: l 0.343 a 0.879 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005238 31.058sec(train) 13.272sec(infer)\n",
      "Epoch 129 tst: l 0.461 a 0.847 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.040sec\n",
      "Epoch 130 tr: l 0.344 a 0.879 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005212 28.238sec(train) 12.952sec(infer)\n",
      "Epoch 130 tst: l 0.461 a 0.847 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.181sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 131 tr: l 0.341 a 0.879 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005186 30.349sec(train) 12.360sec(infer)\n",
      "Epoch 131 tst: l 0.461 a 0.847 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.346sec\n",
      "Epoch 132 tr: l 0.342 a 0.879 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005160 32.064sec(train) 11.874sec(infer)\n",
      "Epoch 132 tst: l 0.461 a 0.847 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.181sec\n",
      "Epoch 133 tr: l 0.342 a 0.879 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005134 31.110sec(train) 13.130sec(infer)\n",
      "Epoch 133 tst: l 0.461 a 0.847 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.790sec\n",
      "Epoch 134 tr: l 0.342 a 0.879 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005108 31.906sec(train) 11.302sec(infer)\n",
      "Epoch 134 tst: l 0.461 a 0.847 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.432sec\n",
      "Epoch 135 tr: l 0.342 a 0.879 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005083 30.438sec(train) 13.044sec(infer)\n",
      "Epoch 135 tst: l 0.461 a 0.847 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.993sec\n",
      "Epoch 136 tr: l 0.343 a 0.879 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005058 29.393sec(train) 12.176sec(infer)\n",
      "Epoch 136 tst: l 0.460 a 0.847 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.441sec\n",
      "Epoch 137 tr: l 0.340 a 0.880 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005032 31.348sec(train) 12.772sec(infer)\n",
      "Epoch 137 tst: l 0.461 a 0.847 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.794sec\n",
      "Epoch 138 tr: l 0.339 a 0.880 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005007 30.409sec(train) 13.038sec(infer)\n",
      "Epoch 138 tst: l 0.460 a 0.847 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.400sec\n",
      "Epoch 139 tr: l 0.338 a 0.880 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004982 32.796sec(train) 11.774sec(infer)\n",
      "Epoch 139 tst: l 0.460 a 0.847 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.327sec\n",
      "Epoch 140 tr: l 0.340 a 0.880 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004957 29.642sec(train) 13.358sec(infer)\n",
      "Epoch 140 tst: l 0.460 a 0.847 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.891sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 141 tr: l 0.340 a 0.880 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004932 31.884sec(train) 10.923sec(infer)\n",
      "Epoch 141 tst: l 0.460 a 0.847 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.781sec\n",
      "Epoch 142 tr: l 0.340 a 0.880 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004908 30.812sec(train) 12.893sec(infer)\n",
      "Epoch 142 tst: l 0.460 a 0.847 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.208sec\n",
      "Epoch 143 tr: l 0.339 a 0.880 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004883 30.067sec(train) 12.491sec(infer)\n",
      "Epoch 143 tst: l 0.460 a 0.847 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.868sec\n",
      "Epoch 144 tr: l 0.338 a 0.880 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004859 32.806sec(train) 12.749sec(infer)\n",
      "Epoch 144 tst: l 0.460 a 0.847 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.245sec\n",
      "Epoch 145 tr: l 0.339 a 0.880 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004834 30.409sec(train) 13.062sec(infer)\n",
      "Epoch 145 tst: l 0.460 a 0.847 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.538sec\n",
      "Epoch 146 tr: l 0.339 a 0.880 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004810 32.800sec(train) 10.356sec(infer)\n",
      "Epoch 146 tst: l 0.459 a 0.847 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.111sec\n",
      "Epoch 147 tr: l 0.339 a 0.880 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004786 33.806sec(train) 10.934sec(infer)\n",
      "Epoch 147 tst: l 0.460 a 0.847 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.043sec\n",
      "Epoch 148 tr: l 0.339 a 0.880 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004762 35.487sec(train) 10.258sec(infer)\n",
      "Epoch 148 tst: l 0.460 a 0.847 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.555sec\n",
      "Epoch 149 tr: l 0.339 a 0.880 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004738 32.431sec(train) 11.445sec(infer)\n",
      "Epoch 149 tst: l 0.459 a 0.847 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.238sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "---train cluster Ended in 2.26 hour (8137.104 sec) \n",
      "---------------------------------DFCA-LI, lr: 0.1, seed: 4012---------------------------------\n",
      "config: {'m': 200, 'm_test': 40, 'p': 4, 'n': 1500, 'uneven': True, 'local_model_init': True, 'Gp': 0.15, 'graph': 'er', 'agg': 'seq', '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:2\n",
      "Epoch -1 tr: l 3.863 a 0.024 clct[np.int64(52), np.int64(44), np.int64(48), np.int64(56)] cl_acc 0.305  11.183sec\n",
      "Epoch -1 tst: l 3.866 a 0.028 clct[np.int64(10), np.int64(13), np.int64(11), np.int64(6)] cl_acc 0.375  9.628sec\n",
      "Epoch 0 tr: l 3.596 a 0.303 clct[np.int64(52), np.int64(44), np.int64(48), np.int64(56)] cl_acc 0.305  lr 0.100000 34.752sec(train) 10.329sec(infer)\n",
      "Epoch 0 tst: l 3.790 a 0.088 clct[np.int64(10), np.int64(13), np.int64(7), np.int64(10)] cl_acc 0.350  8.468sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 1 tr: l 3.576 a 0.299 clct[np.int64(53), np.int64(43), np.int64(48), np.int64(56)] cl_acc 0.300  lr 0.099500 37.284sec(train) 10.422sec(infer)\n",
      "Epoch 1 tst: l 3.770 a 0.116 clct[np.int64(10), np.int64(10), np.int64(11), np.int64(9)] cl_acc 0.375  9.858sec\n",
      "Epoch 2 tr: l 3.568 a 0.241 clct[np.int64(52), np.int64(45), np.int64(49), np.int64(54)] cl_acc 0.315  lr 0.099003 35.070sec(train) 10.745sec(infer)\n",
      "Epoch 2 tst: l 3.744 a 0.119 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 0.425  8.539sec\n",
      "Epoch 3 tr: l 3.512 a 0.217 clct[np.int64(52), np.int64(45), np.int64(50), np.int64(53)] cl_acc 0.320  lr 0.098507 37.080sec(train) 10.523sec(infer)\n",
      "Epoch 3 tst: l 3.702 a 0.125 clct[np.int64(12), np.int64(10), np.int64(9), np.int64(9)] cl_acc 0.400  9.807sec\n",
      "Epoch 4 tr: l 3.399 a 0.224 clct[np.int64(51), np.int64(44), np.int64(51), np.int64(54)] cl_acc 0.330  lr 0.098015 34.356sec(train) 10.958sec(infer)\n",
      "Epoch 4 tst: l 3.623 a 0.139 clct[np.int64(9), np.int64(10), np.int64(10), np.int64(11)] cl_acc 0.525  8.608sec\n",
      "Epoch 5 tr: l 3.248 a 0.263 clct[np.int64(50), np.int64(43), np.int64(52), np.int64(55)] cl_acc 0.340  lr 0.097525 37.184sec(train) 10.493sec(infer)\n",
      "Epoch 5 tst: l 3.510 a 0.166 clct[np.int64(11), np.int64(8), np.int64(10), np.int64(11)] cl_acc 0.625  9.995sec\n",
      "Epoch 6 tr: l 3.060 a 0.285 clct[np.int64(50), np.int64(44), np.int64(50), np.int64(56)] cl_acc 0.355  lr 0.097037 35.392sec(train) 10.559sec(infer)\n",
      "Epoch 6 tst: l 3.353 a 0.188 clct[np.int64(11), np.int64(8), np.int64(10), np.int64(11)] cl_acc 0.525  8.145sec\n",
      "Epoch 7 tr: l 2.855 a 0.318 clct[np.int64(49), np.int64(48), np.int64(50), np.int64(53)] cl_acc 0.395  lr 0.096552 36.822sec(train) 10.306sec(infer)\n",
      "Epoch 7 tst: l 3.188 a 0.219 clct[np.int64(12), np.int64(7), np.int64(8), np.int64(13)] cl_acc 0.700  9.784sec\n",
      "Epoch 8 tr: l 2.714 a 0.322 clct[np.int64(48), np.int64(53), np.int64(50), np.int64(49)] cl_acc 0.490  lr 0.096069 34.426sec(train) 11.152sec(infer)\n",
      "Epoch 8 tst: l 3.008 a 0.244 clct[np.int64(11), np.int64(7), np.int64(9), np.int64(13)] cl_acc 0.775  8.954sec\n",
      "Epoch 9 tr: l 2.494 a 0.384 clct[np.int64(45), np.int64(50), np.int64(53), np.int64(52)] cl_acc 0.555  lr 0.095589 36.525sec(train) 9.183sec(infer)\n",
      "Epoch 9 tst: l 2.799 a 0.302 clct[np.int64(11), np.int64(10), np.int64(9), np.int64(10)] cl_acc 0.725  9.606sec\n",
      "Epoch 10 tr: l 2.314 a 0.417 clct[np.int64(48), np.int64(45), np.int64(60), np.int64(47)] cl_acc 0.650  lr 0.095111 34.342sec(train) 10.688sec(infer)\n",
      "Epoch 10 tst: l 2.598 a 0.349 clct[np.int64(11), np.int64(9), np.int64(10), np.int64(10)] cl_acc 0.775  9.463sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 11 tr: l 2.086 a 0.467 clct[np.int64(50), np.int64(48), np.int64(53), np.int64(49)] cl_acc 0.740  lr 0.094635 35.352sec(train) 9.573sec(infer)\n",
      "Epoch 11 tst: l 2.341 a 0.413 clct[np.int64(11), np.int64(7), np.int64(10), np.int64(12)] cl_acc 0.875  9.319sec\n",
      "Epoch 12 tr: l 1.862 a 0.513 clct[np.int64(53), np.int64(52), np.int64(51), np.int64(44)] cl_acc 0.785  lr 0.094162 35.642sec(train) 11.084sec(infer)\n",
      "Epoch 12 tst: l 2.092 a 0.472 clct[np.int64(10), np.int64(11), np.int64(10), np.int64(9)] cl_acc 0.925  9.687sec\n",
      "Epoch 13 tr: l 1.665 a 0.560 clct[np.int64(51), np.int64(53), np.int64(51), np.int64(45)] cl_acc 0.830  lr 0.093691 35.611sec(train) 9.298sec(infer)\n",
      "Epoch 13 tst: l 1.872 a 0.526 clct[np.int64(10), np.int64(9), np.int64(10), np.int64(11)] cl_acc 0.925  8.724sec\n",
      "Epoch 14 tr: l 1.501 a 0.587 clct[np.int64(49), np.int64(52), np.int64(50), np.int64(49)] cl_acc 0.875  lr 0.093223 36.515sec(train) 11.046sec(infer)\n",
      "Epoch 14 tst: l 1.676 a 0.572 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 0.950  10.140sec\n",
      "Epoch 15 tr: l 1.336 a 0.634 clct[np.int64(50), np.int64(56), np.int64(50), np.int64(44)] cl_acc 0.920  lr 0.092757 34.543sec(train) 9.949sec(infer)\n",
      "Epoch 15 tst: l 1.500 a 0.616 clct[np.int64(10), np.int64(11), np.int64(10), np.int64(9)] cl_acc 0.975  8.924sec\n",
      "Epoch 16 tr: l 1.217 a 0.660 clct[np.int64(50), np.int64(52), np.int64(50), np.int64(48)] cl_acc 0.970  lr 0.092293 36.311sec(train) 10.872sec(infer)\n",
      "Epoch 16 tst: l 1.361 a 0.643 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.806sec\n",
      "Epoch 17 tr: l 1.082 a 0.686 clct[np.int64(50), np.int64(51), np.int64(50), np.int64(49)] cl_acc 0.975  lr 0.091832 35.346sec(train) 10.099sec(infer)\n",
      "Epoch 17 tst: l 1.233 a 0.670 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  8.421sec\n",
      "Epoch 18 tr: l 0.991 a 0.705 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 0.980  lr 0.091372 36.806sec(train) 11.299sec(infer)\n",
      "Epoch 18 tst: l 1.131 a 0.690 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.665sec\n",
      "Epoch 19 tr: l 0.923 a 0.721 clct[np.int64(50), np.int64(52), np.int64(50), np.int64(48)] cl_acc 0.990  lr 0.090916 34.964sec(train) 10.341sec(infer)\n",
      "Epoch 19 tst: l 1.050 a 0.706 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  8.464sec\n",
      "Epoch 20 tr: l 0.866 a 0.733 clct[np.int64(50), np.int64(51), np.int64(50), np.int64(49)] cl_acc 0.995  lr 0.090461 35.770sec(train) 9.423sec(infer)\n",
      "Epoch 20 tst: l 0.990 a 0.717 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.653sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 21 tr: l 0.821 a 0.743 clct[np.int64(50), np.int64(51), np.int64(50), np.int64(49)] cl_acc 0.995  lr 0.090009 34.327sec(train) 10.675sec(infer)\n",
      "Epoch 21 tst: l 0.938 a 0.729 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  8.341sec\n",
      "Epoch 22 tr: l 0.782 a 0.752 clct[np.int64(50), np.int64(51), np.int64(50), np.int64(49)] cl_acc 0.995  lr 0.089559 35.327sec(train) 8.219sec(infer)\n",
      "Epoch 22 tst: l 0.896 a 0.737 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.524sec\n",
      "Epoch 23 tr: l 0.753 a 0.762 clct[np.int64(50), np.int64(51), np.int64(50), np.int64(49)] cl_acc 0.995  lr 0.089111 34.254sec(train) 11.318sec(infer)\n",
      "Epoch 23 tst: l 0.865 a 0.743 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.089sec\n",
      "Epoch 24 tr: l 0.720 a 0.767 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.088665 33.735sec(train) 10.628sec(infer)\n",
      "Epoch 24 tst: l 0.833 a 0.749 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  8.261sec\n",
      "Epoch 25 tr: l 0.698 a 0.774 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.088222 34.826sec(train) 10.795sec(infer)\n",
      "Epoch 25 tst: l 0.808 a 0.756 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.223sec\n",
      "Epoch 26 tr: l 0.690 a 0.777 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.087781 33.340sec(train) 12.247sec(infer)\n",
      "Epoch 26 tst: l 0.797 a 0.758 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.929sec\n",
      "Epoch 27 tr: l 0.665 a 0.786 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.087342 34.612sec(train) 10.120sec(infer)\n",
      "Epoch 27 tst: l 0.777 a 0.764 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.297sec\n",
      "Epoch 28 tr: l 0.634 a 0.789 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.086905 32.296sec(train) 12.836sec(infer)\n",
      "Epoch 28 tst: l 0.758 a 0.767 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.357sec\n",
      "Epoch 29 tr: l 0.622 a 0.793 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.086471 32.894sec(train) 11.862sec(infer)\n",
      "Epoch 29 tst: l 0.738 a 0.772 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.602sec\n",
      "Epoch 30 tr: l 0.604 a 0.797 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.086038 34.027sec(train) 11.779sec(infer)\n",
      "Epoch 30 tst: l 0.720 a 0.775 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.215sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 31 tr: l 0.588 a 0.802 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.085608 32.500sec(train) 12.887sec(infer)\n",
      "Epoch 31 tst: l 0.707 a 0.780 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  8.213sec\n",
      "Epoch 32 tr: l 0.578 a 0.805 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.085180 32.903sec(train) 11.394sec(infer)\n",
      "Epoch 32 tst: l 0.696 a 0.781 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.106sec\n",
      "Epoch 33 tr: l 0.569 a 0.808 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.084754 32.669sec(train) 12.584sec(infer)\n",
      "Epoch 33 tst: l 0.683 a 0.787 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.468sec\n",
      "Epoch 34 tr: l 0.559 a 0.811 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.084331 32.126sec(train) 12.392sec(infer)\n",
      "Epoch 34 tst: l 0.674 a 0.787 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.660sec\n",
      "Epoch 35 tr: l 0.544 a 0.813 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.083909 33.435sec(train) 11.554sec(infer)\n",
      "Epoch 35 tst: l 0.665 a 0.791 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.474sec\n",
      "Epoch 36 tr: l 0.538 a 0.818 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.083489 30.983sec(train) 12.785sec(infer)\n",
      "Epoch 36 tst: l 0.656 a 0.792 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.236sec\n",
      "Epoch 37 tr: l 0.526 a 0.820 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.083072 32.127sec(train) 11.869sec(infer)\n",
      "Epoch 37 tst: l 0.649 a 0.795 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.325sec\n",
      "Epoch 38 tr: l 0.517 a 0.822 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.082657 32.684sec(train) 12.615sec(infer)\n",
      "Epoch 38 tst: l 0.642 a 0.797 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.566sec\n",
      "Epoch 39 tr: l 0.513 a 0.823 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.082243 31.033sec(train) 12.803sec(infer)\n",
      "Epoch 39 tst: l 0.637 a 0.797 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  8.550sec\n",
      "Epoch 40 tr: l 0.505 a 0.825 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.081832 32.523sec(train) 11.026sec(infer)\n",
      "Epoch 40 tst: l 0.628 a 0.800 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.121sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 41 tr: l 0.497 a 0.828 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.081423 31.827sec(train) 13.014sec(infer)\n",
      "Epoch 41 tst: l 0.618 a 0.803 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.123sec\n",
      "Epoch 42 tr: l 0.491 a 0.830 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.081016 31.438sec(train) 12.048sec(infer)\n",
      "Epoch 42 tst: l 0.614 a 0.804 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  8.993sec\n",
      "Epoch 43 tr: l 0.484 a 0.831 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.080611 32.496sec(train) 12.351sec(infer)\n",
      "Epoch 43 tst: l 0.607 a 0.805 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.340sec\n",
      "Epoch 44 tr: l 0.478 a 0.834 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.080208 30.689sec(train) 12.770sec(infer)\n",
      "Epoch 44 tst: l 0.603 a 0.807 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.332sec\n",
      "Epoch 45 tr: l 0.469 a 0.835 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.079807 31.401sec(train) 11.139sec(infer)\n",
      "Epoch 45 tst: l 0.598 a 0.807 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.727sec\n",
      "Epoch 46 tr: l 0.464 a 0.837 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.079408 30.594sec(train) 13.112sec(infer)\n",
      "Epoch 46 tst: l 0.593 a 0.809 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.960sec\n",
      "Epoch 47 tr: l 0.467 a 0.837 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.079010 30.499sec(train) 12.349sec(infer)\n",
      "Epoch 47 tst: l 0.593 a 0.808 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.708sec\n",
      "Epoch 48 tr: l 0.457 a 0.839 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.078615 32.715sec(train) 11.944sec(infer)\n",
      "Epoch 48 tst: l 0.588 a 0.811 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.602sec\n",
      "Epoch 49 tr: l 0.450 a 0.841 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.078222 30.909sec(train) 13.488sec(infer)\n",
      "Epoch 49 tst: l 0.581 a 0.812 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.557sec\n",
      "Epoch 50 tr: l 0.446 a 0.842 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.077831 31.207sec(train) 11.268sec(infer)\n",
      "Epoch 50 tst: l 0.578 a 0.814 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.342sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 51 tr: l 0.437 a 0.844 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.077442 31.574sec(train) 12.870sec(infer)\n",
      "Epoch 51 tst: l 0.572 a 0.815 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.637sec\n",
      "Epoch 52 tr: l 0.434 a 0.846 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.077055 31.183sec(train) 12.465sec(infer)\n",
      "Epoch 52 tst: l 0.567 a 0.817 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.039sec\n",
      "Epoch 53 tr: l 0.431 a 0.846 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.076670 33.024sec(train) 12.134sec(infer)\n",
      "Epoch 53 tst: l 0.562 a 0.818 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.011sec\n",
      "Epoch 54 tr: l 0.426 a 0.847 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.076286 30.971sec(train) 12.864sec(infer)\n",
      "Epoch 54 tst: l 0.560 a 0.818 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.552sec\n",
      "Epoch 55 tr: l 0.423 a 0.849 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.075905 31.126sec(train) 11.562sec(infer)\n",
      "Epoch 55 tst: l 0.557 a 0.819 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.278sec\n",
      "Epoch 56 tr: l 0.422 a 0.850 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.075525 31.736sec(train) 13.029sec(infer)\n",
      "Epoch 56 tst: l 0.553 a 0.821 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.597sec\n",
      "Epoch 57 tr: l 0.418 a 0.851 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.075148 30.526sec(train) 12.531sec(infer)\n",
      "Epoch 57 tst: l 0.552 a 0.821 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.071sec\n",
      "Epoch 58 tr: l 0.414 a 0.851 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.074772 31.960sec(train) 11.423sec(infer)\n",
      "Epoch 58 tst: l 0.548 a 0.823 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.968sec\n",
      "Epoch 59 tr: l 0.412 a 0.853 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.074398 30.396sec(train) 13.095sec(infer)\n",
      "Epoch 59 tst: l 0.545 a 0.823 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.588sec\n",
      "Epoch 60 tr: l 0.406 a 0.854 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.074026 30.402sec(train) 11.863sec(infer)\n",
      "Epoch 60 tst: l 0.543 a 0.824 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.734sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 61 tr: l 0.403 a 0.855 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.073656 32.097sec(train) 12.144sec(infer)\n",
      "Epoch 61 tst: l 0.539 a 0.824 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.963sec\n",
      "Epoch 62 tr: l 0.401 a 0.855 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.073288 30.213sec(train) 13.162sec(infer)\n",
      "Epoch 62 tst: l 0.537 a 0.825 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.668sec\n",
      "Epoch 63 tr: l 0.396 a 0.857 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.072921 32.277sec(train) 11.306sec(infer)\n",
      "Epoch 63 tst: l 0.536 a 0.826 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.966sec\n",
      "Epoch 64 tr: l 0.392 a 0.858 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.072557 30.018sec(train) 12.917sec(infer)\n",
      "Epoch 64 tst: l 0.532 a 0.828 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.949sec\n",
      "Epoch 65 tr: l 0.388 a 0.860 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.072194 29.804sec(train) 12.345sec(infer)\n",
      "Epoch 65 tst: l 0.531 a 0.827 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.983sec\n",
      "Epoch 66 tr: l 0.388 a 0.860 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.071833 32.251sec(train) 12.633sec(infer)\n",
      "Epoch 66 tst: l 0.528 a 0.828 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.759sec\n",
      "Epoch 67 tr: l 0.381 a 0.861 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.071474 30.718sec(train) 12.821sec(infer)\n",
      "Epoch 67 tst: l 0.527 a 0.829 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.470sec\n",
      "Epoch 68 tr: l 0.386 a 0.861 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.071116 33.004sec(train) 11.103sec(infer)\n",
      "Epoch 68 tst: l 0.524 a 0.830 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.961sec\n",
      "Epoch 69 tr: l 0.380 a 0.862 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.070761 30.882sec(train) 12.787sec(infer)\n",
      "Epoch 69 tst: l 0.522 a 0.830 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.640sec\n",
      "Epoch 70 tr: l 0.378 a 0.862 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.070407 30.571sec(train) 12.075sec(infer)\n",
      "Epoch 70 tst: l 0.519 a 0.831 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.432sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 71 tr: l 0.375 a 0.864 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.070055 32.520sec(train) 12.567sec(infer)\n",
      "Epoch 71 tst: l 0.518 a 0.831 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.702sec\n",
      "Epoch 72 tr: l 0.375 a 0.862 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.069705 30.935sec(train) 12.937sec(infer)\n",
      "Epoch 72 tst: l 0.515 a 0.833 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.388sec\n",
      "Epoch 73 tr: l 0.367 a 0.867 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.069356 31.474sec(train) 11.195sec(infer)\n",
      "Epoch 73 tst: l 0.513 a 0.832 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.036sec\n",
      "Epoch 74 tr: l 0.367 a 0.866 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.069009 30.910sec(train) 12.787sec(infer)\n",
      "Epoch 74 tst: l 0.512 a 0.834 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.883sec\n",
      "Epoch 75 tr: l 0.361 a 0.868 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.068664 30.672sec(train) 12.214sec(infer)\n",
      "Epoch 75 tst: l 0.511 a 0.833 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.756sec\n",
      "Epoch 76 tr: l 0.358 a 0.868 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.068321 32.814sec(train) 12.429sec(infer)\n",
      "Epoch 76 tst: l 0.508 a 0.835 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.905sec\n",
      "Epoch 77 tr: l 0.361 a 0.868 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.067979 30.282sec(train) 12.954sec(infer)\n",
      "Epoch 77 tst: l 0.507 a 0.835 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.415sec\n",
      "Epoch 78 tr: l 0.358 a 0.868 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.067639 31.414sec(train) 11.341sec(infer)\n",
      "Epoch 78 tst: l 0.506 a 0.835 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.960sec\n",
      "Epoch 79 tr: l 0.353 a 0.871 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.067301 30.724sec(train) 12.966sec(infer)\n",
      "Epoch 79 tst: l 0.503 a 0.836 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.874sec\n",
      "Epoch 80 tr: l 0.352 a 0.870 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.066965 30.351sec(train) 12.405sec(infer)\n",
      "Epoch 80 tst: l 0.503 a 0.836 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.632sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 81 tr: l 0.351 a 0.871 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.066630 32.133sec(train) 12.167sec(infer)\n",
      "Epoch 81 tst: l 0.501 a 0.836 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.852sec\n",
      "Epoch 82 tr: l 0.348 a 0.871 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.066297 30.404sec(train) 12.704sec(infer)\n",
      "Epoch 82 tst: l 0.498 a 0.837 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.837sec\n",
      "Epoch 83 tr: l 0.346 a 0.873 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.065965 31.810sec(train) 10.974sec(infer)\n",
      "Epoch 83 tst: l 0.498 a 0.838 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.533sec\n",
      "Epoch 84 tr: l 0.346 a 0.872 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.065635 31.343sec(train) 8.856sec(infer)\n",
      "Epoch 84 tst: l 0.498 a 0.838 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.047sec\n",
      "Epoch 85 tr: l 0.339 a 0.875 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.065307 22.424sec(train) 8.760sec(infer)\n",
      "Epoch 85 tst: l 0.496 a 0.838 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.808sec\n",
      "Epoch 86 tr: l 0.341 a 0.873 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064981 22.166sec(train) 8.923sec(infer)\n",
      "Epoch 86 tst: l 0.494 a 0.839 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.986sec\n",
      "Epoch 87 tr: l 0.335 a 0.876 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064656 22.595sec(train) 8.285sec(infer)\n",
      "Epoch 87 tst: l 0.493 a 0.839 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.345sec\n",
      "Epoch 88 tr: l 0.338 a 0.874 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064333 21.785sec(train) 8.712sec(infer)\n",
      "Epoch 88 tst: l 0.491 a 0.840 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.196sec\n",
      "Epoch 89 tr: l 0.335 a 0.877 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064011 21.928sec(train) 9.016sec(infer)\n",
      "Epoch 89 tst: l 0.491 a 0.840 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.484sec\n",
      "Epoch 90 tr: l 0.332 a 0.875 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.063691 22.822sec(train) 9.232sec(infer)\n",
      "Epoch 90 tst: l 0.490 a 0.840 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.224sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 91 tr: l 0.331 a 0.878 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.063372 22.474sec(train) 8.502sec(infer)\n",
      "Epoch 91 tst: l 0.488 a 0.840 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.607sec\n",
      "Epoch 92 tr: l 0.330 a 0.877 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.063056 22.758sec(train) 8.850sec(infer)\n",
      "Epoch 92 tst: l 0.487 a 0.841 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.793sec\n",
      "Epoch 93 tr: l 0.327 a 0.879 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.062740 22.857sec(train) 8.945sec(infer)\n",
      "Epoch 93 tst: l 0.485 a 0.841 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.089sec\n",
      "Epoch 94 tr: l 0.328 a 0.878 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.062427 23.000sec(train) 9.019sec(infer)\n",
      "Epoch 94 tst: l 0.484 a 0.842 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.240sec\n",
      "Epoch 95 tr: l 0.328 a 0.879 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.062114 22.733sec(train) 8.570sec(infer)\n",
      "Epoch 95 tst: l 0.484 a 0.841 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.208sec\n",
      "Epoch 96 tr: l 0.323 a 0.879 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.061804 22.925sec(train) 8.667sec(infer)\n",
      "Epoch 96 tst: l 0.483 a 0.842 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.446sec\n",
      "Epoch 97 tr: l 0.323 a 0.880 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.061495 23.474sec(train) 8.497sec(infer)\n",
      "Epoch 97 tst: l 0.481 a 0.842 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.262sec\n",
      "Epoch 98 tr: l 0.318 a 0.881 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.061187 23.208sec(train) 8.433sec(infer)\n",
      "Epoch 98 tst: l 0.481 a 0.843 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.307sec\n",
      "Epoch 99 tr: l 0.318 a 0.881 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.060881 23.051sec(train) 8.854sec(infer)\n",
      "Epoch 99 tst: l 0.479 a 0.844 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.007sec\n",
      "Epoch 100 tr: l 0.332 a 0.879 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.006058 23.019sec(train) 8.486sec(infer)\n",
      "Epoch 100 tst: l 0.471 a 0.846 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.220sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 101 tr: l 0.347 a 0.876 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.006027 22.320sec(train) 8.710sec(infer)\n",
      "Epoch 101 tst: l 0.467 a 0.847 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.856sec\n",
      "Epoch 102 tr: l 0.349 a 0.875 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005997 22.553sec(train) 8.636sec(infer)\n",
      "Epoch 102 tst: l 0.465 a 0.848 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.576sec\n",
      "Epoch 103 tr: l 0.351 a 0.875 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005967 22.213sec(train) 8.906sec(infer)\n",
      "Epoch 103 tst: l 0.464 a 0.848 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.024sec\n",
      "Epoch 104 tr: l 0.352 a 0.875 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005937 22.269sec(train) 8.916sec(infer)\n",
      "Epoch 104 tst: l 0.463 a 0.848 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.932sec\n",
      "Epoch 105 tr: l 0.354 a 0.874 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005908 22.112sec(train) 8.313sec(infer)\n",
      "Epoch 105 tst: l 0.462 a 0.848 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.003sec\n",
      "Epoch 106 tr: l 0.355 a 0.874 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005878 21.921sec(train) 8.368sec(infer)\n",
      "Epoch 106 tst: l 0.462 a 0.848 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.330sec\n",
      "Epoch 107 tr: l 0.352 a 0.874 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005849 21.922sec(train) 8.793sec(infer)\n",
      "Epoch 107 tst: l 0.461 a 0.848 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.270sec\n",
      "Epoch 108 tr: l 0.355 a 0.875 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005820 22.287sec(train) 8.837sec(infer)\n",
      "Epoch 108 tst: l 0.461 a 0.849 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.865sec\n",
      "Epoch 109 tr: l 0.353 a 0.875 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005790 21.751sec(train) 8.250sec(infer)\n",
      "Epoch 109 tst: l 0.461 a 0.849 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.509sec\n",
      "Epoch 110 tr: l 0.353 a 0.874 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005762 22.559sec(train) 8.486sec(infer)\n",
      "Epoch 110 tst: l 0.460 a 0.849 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.809sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 111 tr: l 0.354 a 0.874 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005733 22.234sec(train) 8.547sec(infer)\n",
      "Epoch 111 tst: l 0.460 a 0.849 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.146sec\n",
      "Epoch 112 tr: l 0.351 a 0.875 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005704 22.098sec(train) 8.376sec(infer)\n",
      "Epoch 112 tst: l 0.460 a 0.849 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.324sec\n",
      "Epoch 113 tr: l 0.351 a 0.875 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005676 22.700sec(train) 8.718sec(infer)\n",
      "Epoch 113 tst: l 0.460 a 0.849 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.672sec\n",
      "Epoch 114 tr: l 0.352 a 0.875 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005647 22.721sec(train) 8.656sec(infer)\n",
      "Epoch 114 tst: l 0.459 a 0.849 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.630sec\n",
      "Epoch 115 tr: l 0.351 a 0.875 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005619 21.873sec(train) 8.566sec(infer)\n",
      "Epoch 115 tst: l 0.459 a 0.849 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.884sec\n",
      "Epoch 116 tr: l 0.351 a 0.875 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005591 22.060sec(train) 8.702sec(infer)\n",
      "Epoch 116 tst: l 0.459 a 0.849 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.084sec\n",
      "Epoch 117 tr: l 0.351 a 0.875 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005563 22.053sec(train) 8.414sec(infer)\n",
      "Epoch 117 tst: l 0.459 a 0.849 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.354sec\n",
      "Epoch 118 tr: l 0.350 a 0.875 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005535 22.253sec(train) 8.705sec(infer)\n",
      "Epoch 118 tst: l 0.459 a 0.849 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.010sec\n",
      "Epoch 119 tr: l 0.349 a 0.876 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005507 22.379sec(train) 8.470sec(infer)\n",
      "Epoch 119 tst: l 0.459 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.008sec\n",
      "Epoch 120 tr: l 0.350 a 0.876 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005480 22.715sec(train) 8.337sec(infer)\n",
      "Epoch 120 tst: l 0.458 a 0.849 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.935sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 121 tr: l 0.349 a 0.876 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005452 22.929sec(train) 8.371sec(infer)\n",
      "Epoch 121 tst: l 0.458 a 0.849 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.542sec\n",
      "Epoch 122 tr: l 0.348 a 0.876 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005425 21.529sec(train) 8.833sec(infer)\n",
      "Epoch 122 tst: l 0.458 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.237sec\n",
      "Epoch 123 tr: l 0.349 a 0.876 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005398 23.132sec(train) 8.804sec(infer)\n",
      "Epoch 123 tst: l 0.458 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.402sec\n",
      "Epoch 124 tr: l 0.347 a 0.876 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005371 22.306sec(train) 8.285sec(infer)\n",
      "Epoch 124 tst: l 0.458 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.933sec\n",
      "Epoch 125 tr: l 0.348 a 0.876 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005344 22.483sec(train) 8.867sec(infer)\n",
      "Epoch 125 tst: l 0.458 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.920sec\n",
      "Epoch 126 tr: l 0.346 a 0.877 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005318 22.240sec(train) 9.108sec(infer)\n",
      "Epoch 126 tst: l 0.458 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.689sec\n",
      "Epoch 127 tr: l 0.348 a 0.876 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005291 22.191sec(train) 8.125sec(infer)\n",
      "Epoch 127 tst: l 0.458 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.091sec\n",
      "Epoch 128 tr: l 0.348 a 0.876 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005264 21.871sec(train) 8.383sec(infer)\n",
      "Epoch 128 tst: l 0.457 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.326sec\n",
      "Epoch 129 tr: l 0.346 a 0.876 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005238 22.559sec(train) 8.189sec(infer)\n",
      "Epoch 129 tst: l 0.457 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.068sec\n",
      "Epoch 130 tr: l 0.346 a 0.877 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005212 21.771sec(train) 8.435sec(infer)\n",
      "Epoch 130 tst: l 0.457 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.458sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 131 tr: l 0.346 a 0.877 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005186 21.880sec(train) 9.099sec(infer)\n",
      "Epoch 131 tst: l 0.457 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.229sec\n",
      "Epoch 132 tr: l 0.347 a 0.877 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005160 21.860sec(train) 8.425sec(infer)\n",
      "Epoch 132 tst: l 0.457 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.326sec\n",
      "Epoch 133 tr: l 0.347 a 0.877 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005134 21.091sec(train) 8.609sec(infer)\n",
      "Epoch 133 tst: l 0.457 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.443sec\n",
      "Epoch 134 tr: l 0.346 a 0.877 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005108 22.004sec(train) 8.642sec(infer)\n",
      "Epoch 134 tst: l 0.457 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.773sec\n",
      "Epoch 135 tr: l 0.345 a 0.877 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005083 21.840sec(train) 8.450sec(infer)\n",
      "Epoch 135 tst: l 0.457 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.660sec\n",
      "Epoch 136 tr: l 0.347 a 0.877 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005058 21.859sec(train) 8.518sec(infer)\n",
      "Epoch 136 tst: l 0.457 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.474sec\n",
      "Epoch 137 tr: l 0.347 a 0.876 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005032 21.876sec(train) 8.515sec(infer)\n",
      "Epoch 137 tst: l 0.457 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.359sec\n",
      "Epoch 138 tr: l 0.346 a 0.877 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005007 22.474sec(train) 8.580sec(infer)\n",
      "Epoch 138 tst: l 0.456 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.409sec\n",
      "Epoch 139 tr: l 0.346 a 0.877 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004982 21.550sec(train) 8.589sec(infer)\n",
      "Epoch 139 tst: l 0.456 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.396sec\n",
      "Epoch 140 tr: l 0.344 a 0.877 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004957 22.426sec(train) 8.820sec(infer)\n",
      "Epoch 140 tst: l 0.456 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.986sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 141 tr: l 0.345 a 0.877 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004932 21.942sec(train) 8.794sec(infer)\n",
      "Epoch 141 tst: l 0.456 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.134sec\n",
      "Epoch 142 tr: l 0.344 a 0.877 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004908 22.344sec(train) 8.426sec(infer)\n",
      "Epoch 142 tst: l 0.456 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.238sec\n",
      "Epoch 143 tr: l 0.344 a 0.877 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004883 21.991sec(train) 8.707sec(infer)\n",
      "Epoch 143 tst: l 0.456 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.001sec\n",
      "Epoch 144 tr: l 0.345 a 0.877 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004859 22.516sec(train) 8.716sec(infer)\n",
      "Epoch 144 tst: l 0.456 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.783sec\n",
      "Epoch 145 tr: l 0.345 a 0.877 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004834 22.517sec(train) 6.375sec(infer)\n",
      "Epoch 145 tst: l 0.455 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  5.997sec\n",
      "Epoch 146 tr: l 0.345 a 0.877 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004810 27.039sec(train) 6.720sec(infer)\n",
      "Epoch 146 tst: l 0.455 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  5.900sec\n",
      "Epoch 147 tr: l 0.344 a 0.877 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004786 26.886sec(train) 6.896sec(infer)\n",
      "Epoch 147 tst: l 0.455 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.341sec\n",
      "Epoch 148 tr: l 0.344 a 0.878 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004762 27.231sec(train) 5.963sec(infer)\n",
      "Epoch 148 tst: l 0.455 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.115sec\n",
      "Epoch 149 tr: l 0.342 a 0.878 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004738 26.163sec(train) 6.733sec(infer)\n",
      "Epoch 149 tst: l 0.455 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.075sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "---train cluster Ended in 1.99 hour (7147.433 sec) \n",
      "---------------------------------DFCA-LI, lr: 0.1, seed: 3657---------------------------------\n",
      "config: {'m': 200, 'm_test': 40, 'p': 4, 'n': 1500, 'uneven': True, 'local_model_init': True, 'Gp': 0.15, 'graph': 'er', 'agg': 'seq', '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:2\n",
      "Epoch -1 tr: l 3.863 a 0.024 clct[np.int64(43), np.int64(55), np.int64(53), np.int64(49)] cl_acc 0.310  7.440sec\n",
      "Epoch -1 tst: l 3.862 a 0.028 clct[np.int64(14), np.int64(7), np.int64(8), np.int64(11)] cl_acc 0.350  5.475sec\n",
      "Epoch 0 tr: l 3.570 a 0.301 clct[np.int64(43), np.int64(54), np.int64(53), np.int64(50)] cl_acc 0.310  lr 0.100000 23.790sec(train) 8.606sec(infer)\n",
      "Epoch 0 tst: l 3.797 a 0.080 clct[np.int64(9), np.int64(6), np.int64(10), np.int64(15)] cl_acc 0.375  5.016sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 1 tr: l 3.541 a 0.305 clct[np.int64(44), np.int64(55), np.int64(52), np.int64(49)] cl_acc 0.315  lr 0.099500 22.625sec(train) 8.810sec(infer)\n",
      "Epoch 1 tst: l 3.763 a 0.115 clct[np.int64(11), np.int64(9), np.int64(10), np.int64(10)] cl_acc 0.350  5.727sec\n",
      "Epoch 2 tr: l 3.550 a 0.245 clct[np.int64(45), np.int64(54), np.int64(52), np.int64(49)] cl_acc 0.320  lr 0.099003 23.240sec(train) 8.500sec(infer)\n",
      "Epoch 2 tst: l 3.751 a 0.117 clct[np.int64(10), np.int64(10), np.int64(9), np.int64(11)] cl_acc 0.400  6.310sec\n",
      "Epoch 3 tr: l 3.474 a 0.231 clct[np.int64(45), np.int64(55), np.int64(52), np.int64(48)] cl_acc 0.320  lr 0.098507 22.387sec(train) 8.419sec(infer)\n",
      "Epoch 3 tst: l 3.704 a 0.122 clct[np.int64(11), np.int64(10), np.int64(9), np.int64(10)] cl_acc 0.325  6.643sec\n",
      "Epoch 4 tr: l 3.370 a 0.240 clct[np.int64(45), np.int64(54), np.int64(52), np.int64(49)] cl_acc 0.325  lr 0.098015 22.561sec(train) 8.442sec(infer)\n",
      "Epoch 4 tst: l 3.633 a 0.131 clct[np.int64(6), np.int64(11), np.int64(12), np.int64(11)] cl_acc 0.425  6.737sec\n",
      "Epoch 5 tr: l 3.191 a 0.273 clct[np.int64(45), np.int64(55), np.int64(49), np.int64(51)] cl_acc 0.345  lr 0.097525 22.016sec(train) 8.459sec(infer)\n",
      "Epoch 5 tst: l 3.514 a 0.153 clct[np.int64(9), np.int64(5), np.int64(13), np.int64(13)] cl_acc 0.425  7.394sec\n",
      "Epoch 6 tr: l 3.008 a 0.302 clct[np.int64(44), np.int64(56), np.int64(49), np.int64(51)] cl_acc 0.350  lr 0.097037 21.818sec(train) 8.660sec(infer)\n",
      "Epoch 6 tst: l 3.357 a 0.187 clct[np.int64(7), np.int64(11), np.int64(7), np.int64(15)] cl_acc 0.400  7.586sec\n",
      "Epoch 7 tr: l 2.848 a 0.311 clct[np.int64(41), np.int64(58), np.int64(48), np.int64(53)] cl_acc 0.380  lr 0.096552 21.966sec(train) 8.857sec(infer)\n",
      "Epoch 7 tst: l 3.211 a 0.200 clct[np.int64(11), np.int64(12), np.int64(7), np.int64(10)] cl_acc 0.500  7.484sec\n",
      "Epoch 8 tr: l 2.685 a 0.326 clct[np.int64(43), np.int64(54), np.int64(51), np.int64(52)] cl_acc 0.405  lr 0.096069 21.834sec(train) 8.837sec(infer)\n",
      "Epoch 8 tst: l 3.043 a 0.233 clct[np.int64(11), np.int64(11), np.int64(7), np.int64(11)] cl_acc 0.600  7.098sec\n",
      "Epoch 9 tr: l 2.529 a 0.359 clct[np.int64(41), np.int64(56), np.int64(51), np.int64(52)] cl_acc 0.450  lr 0.095589 20.998sec(train) 8.606sec(infer)\n",
      "Epoch 9 tst: l 2.874 a 0.266 clct[np.int64(13), np.int64(12), np.int64(9), np.int64(6)] cl_acc 0.625  7.819sec\n",
      "Epoch 10 tr: l 2.342 a 0.401 clct[np.int64(43), np.int64(52), np.int64(50), np.int64(55)] cl_acc 0.520  lr 0.095111 22.362sec(train) 8.761sec(infer)\n",
      "Epoch 10 tst: l 2.721 a 0.297 clct[np.int64(11), np.int64(13), np.int64(8), np.int64(8)] cl_acc 0.650  7.302sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 11 tr: l 2.132 a 0.448 clct[np.int64(47), np.int64(54), np.int64(45), np.int64(54)] cl_acc 0.590  lr 0.094635 21.728sec(train) 8.844sec(infer)\n",
      "Epoch 11 tst: l 2.537 a 0.338 clct[np.int64(12), np.int64(10), np.int64(8), np.int64(10)] cl_acc 0.750  7.352sec\n",
      "Epoch 12 tr: l 1.947 a 0.497 clct[np.int64(48), np.int64(57), np.int64(43), np.int64(52)] cl_acc 0.710  lr 0.094162 22.716sec(train) 8.538sec(infer)\n",
      "Epoch 12 tst: l 2.323 a 0.400 clct[np.int64(12), np.int64(9), np.int64(8), np.int64(11)] cl_acc 0.800  6.678sec\n",
      "Epoch 13 tr: l 1.753 a 0.552 clct[np.int64(55), np.int64(49), np.int64(45), np.int64(51)] cl_acc 0.820  lr 0.093691 21.555sec(train) 8.652sec(infer)\n",
      "Epoch 13 tst: l 2.082 a 0.468 clct[np.int64(13), np.int64(9), np.int64(9), np.int64(9)] cl_acc 0.875  7.086sec\n",
      "Epoch 14 tr: l 1.533 a 0.596 clct[np.int64(52), np.int64(50), np.int64(50), np.int64(48)] cl_acc 0.935  lr 0.093223 22.846sec(train) 8.656sec(infer)\n",
      "Epoch 14 tst: l 1.804 a 0.539 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.526sec\n",
      "Epoch 15 tr: l 1.334 a 0.637 clct[np.int64(51), np.int64(51), np.int64(50), np.int64(48)] cl_acc 0.975  lr 0.092757 23.039sec(train) 8.481sec(infer)\n",
      "Epoch 15 tst: l 1.549 a 0.604 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.299sec\n",
      "Epoch 16 tr: l 1.167 a 0.673 clct[np.int64(50), np.int64(51), np.int64(51), np.int64(48)] cl_acc 0.980  lr 0.092293 23.416sec(train) 8.793sec(infer)\n",
      "Epoch 16 tst: l 1.371 a 0.642 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.326sec\n",
      "Epoch 17 tr: l 1.064 a 0.691 clct[np.int64(50), np.int64(50), np.int64(51), np.int64(49)] cl_acc 0.995  lr 0.091832 23.798sec(train) 8.258sec(infer)\n",
      "Epoch 17 tst: l 1.250 a 0.667 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.036sec\n",
      "Epoch 18 tr: l 0.992 a 0.706 clct[np.int64(50), np.int64(50), np.int64(51), np.int64(49)] cl_acc 0.995  lr 0.091372 22.964sec(train) 8.983sec(infer)\n",
      "Epoch 18 tst: l 1.139 a 0.689 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  5.879sec\n",
      "Epoch 19 tr: l 0.922 a 0.725 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.090916 23.095sec(train) 8.650sec(infer)\n",
      "Epoch 19 tst: l 1.072 a 0.703 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  5.790sec\n",
      "Epoch 20 tr: l 0.872 a 0.735 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.090461 22.328sec(train) 8.741sec(infer)\n",
      "Epoch 20 tst: l 1.009 a 0.714 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.582sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 21 tr: l 0.831 a 0.745 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.090009 23.408sec(train) 8.811sec(infer)\n",
      "Epoch 21 tst: l 0.954 a 0.725 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  5.992sec\n",
      "Epoch 22 tr: l 0.778 a 0.755 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.089559 22.686sec(train) 8.578sec(infer)\n",
      "Epoch 22 tst: l 0.908 a 0.735 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.665sec\n",
      "Epoch 23 tr: l 0.745 a 0.764 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.089111 22.489sec(train) 8.913sec(infer)\n",
      "Epoch 23 tst: l 0.868 a 0.745 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.154sec\n",
      "Epoch 24 tr: l 0.720 a 0.770 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.088665 21.902sec(train) 8.455sec(infer)\n",
      "Epoch 24 tst: l 0.839 a 0.751 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.044sec\n",
      "Epoch 25 tr: l 0.696 a 0.775 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.088222 21.405sec(train) 8.752sec(infer)\n",
      "Epoch 25 tst: l 0.816 a 0.755 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.420sec\n",
      "Epoch 26 tr: l 0.671 a 0.782 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.087781 21.759sec(train) 8.201sec(infer)\n",
      "Epoch 26 tst: l 0.791 a 0.761 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.505sec\n",
      "Epoch 27 tr: l 0.655 a 0.786 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.087342 21.345sec(train) 8.488sec(infer)\n",
      "Epoch 27 tst: l 0.772 a 0.765 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.455sec\n",
      "Epoch 28 tr: l 0.636 a 0.792 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.086905 21.749sec(train) 8.772sec(infer)\n",
      "Epoch 28 tst: l 0.755 a 0.770 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.363sec\n",
      "Epoch 29 tr: l 0.614 a 0.796 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.086471 21.602sec(train) 8.906sec(infer)\n",
      "Epoch 29 tst: l 0.736 a 0.775 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.259sec\n",
      "Epoch 30 tr: l 0.601 a 0.799 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.086038 21.171sec(train) 8.832sec(infer)\n",
      "Epoch 30 tst: l 0.724 a 0.777 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.574sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 31 tr: l 0.595 a 0.802 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.085608 21.906sec(train) 8.599sec(infer)\n",
      "Epoch 31 tst: l 0.712 a 0.780 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.511sec\n",
      "Epoch 32 tr: l 0.580 a 0.805 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.085180 22.008sec(train) 8.514sec(infer)\n",
      "Epoch 32 tst: l 0.700 a 0.783 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.584sec\n",
      "Epoch 33 tr: l 0.576 a 0.808 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.084754 21.529sec(train) 8.402sec(infer)\n",
      "Epoch 33 tst: l 0.698 a 0.784 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.547sec\n",
      "Epoch 34 tr: l 0.552 a 0.813 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.084331 21.962sec(train) 8.203sec(infer)\n",
      "Epoch 34 tst: l 0.681 a 0.787 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.601sec\n",
      "Epoch 35 tr: l 0.549 a 0.816 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.083909 22.344sec(train) 8.765sec(infer)\n",
      "Epoch 35 tst: l 0.669 a 0.792 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.930sec\n",
      "Epoch 36 tr: l 0.535 a 0.817 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.083489 21.446sec(train) 8.339sec(infer)\n",
      "Epoch 36 tst: l 0.659 a 0.794 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.702sec\n",
      "Epoch 37 tr: l 0.530 a 0.819 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.083072 21.956sec(train) 8.252sec(infer)\n",
      "Epoch 37 tst: l 0.652 a 0.795 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.352sec\n",
      "Epoch 38 tr: l 0.516 a 0.823 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.082657 22.542sec(train) 8.564sec(infer)\n",
      "Epoch 38 tst: l 0.644 a 0.798 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.933sec\n",
      "Epoch 39 tr: l 0.512 a 0.825 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.082243 21.925sec(train) 8.303sec(infer)\n",
      "Epoch 39 tst: l 0.639 a 0.799 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.185sec\n",
      "Epoch 40 tr: l 0.503 a 0.826 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.081832 21.845sec(train) 8.263sec(infer)\n",
      "Epoch 40 tst: l 0.629 a 0.801 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.126sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 41 tr: l 0.497 a 0.829 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.081423 22.593sec(train) 8.677sec(infer)\n",
      "Epoch 41 tst: l 0.623 a 0.803 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.867sec\n",
      "Epoch 42 tr: l 0.488 a 0.831 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.081016 22.000sec(train) 8.658sec(infer)\n",
      "Epoch 42 tst: l 0.616 a 0.805 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.711sec\n",
      "Epoch 43 tr: l 0.481 a 0.832 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.080611 21.658sec(train) 8.781sec(infer)\n",
      "Epoch 43 tst: l 0.610 a 0.806 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.952sec\n",
      "Epoch 44 tr: l 0.477 a 0.833 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.080208 22.025sec(train) 8.704sec(infer)\n",
      "Epoch 44 tst: l 0.605 a 0.808 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.092sec\n",
      "Epoch 45 tr: l 0.472 a 0.836 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.079807 22.490sec(train) 8.652sec(infer)\n",
      "Epoch 45 tst: l 0.598 a 0.809 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.104sec\n",
      "Epoch 46 tr: l 0.466 a 0.837 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.079408 21.649sec(train) 8.881sec(infer)\n",
      "Epoch 46 tst: l 0.598 a 0.809 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.353sec\n",
      "Epoch 47 tr: l 0.462 a 0.839 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.079010 22.084sec(train) 8.648sec(infer)\n",
      "Epoch 47 tst: l 0.592 a 0.811 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.959sec\n",
      "Epoch 48 tr: l 0.453 a 0.840 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.078615 22.457sec(train) 8.442sec(infer)\n",
      "Epoch 48 tst: l 0.585 a 0.813 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.789sec\n",
      "Epoch 49 tr: l 0.462 a 0.842 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.078222 21.738sec(train) 8.634sec(infer)\n",
      "Epoch 49 tst: l 0.600 a 0.811 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.349sec\n",
      "Epoch 50 tr: l 0.443 a 0.843 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.077831 22.206sec(train) 8.495sec(infer)\n",
      "Epoch 50 tst: l 0.582 a 0.814 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.962sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 51 tr: l 0.442 a 0.845 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.077442 22.053sec(train) 8.530sec(infer)\n",
      "Epoch 51 tst: l 0.575 a 0.816 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.277sec\n",
      "Epoch 52 tr: l 0.437 a 0.846 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.077055 21.879sec(train) 8.600sec(infer)\n",
      "Epoch 52 tst: l 0.572 a 0.817 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.072sec\n",
      "Epoch 53 tr: l 0.443 a 0.847 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.076670 22.217sec(train) 8.229sec(infer)\n",
      "Epoch 53 tst: l 0.570 a 0.817 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.960sec\n",
      "Epoch 54 tr: l 0.427 a 0.848 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.076286 22.497sec(train) 8.296sec(infer)\n",
      "Epoch 54 tst: l 0.564 a 0.819 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.548sec\n",
      "Epoch 55 tr: l 0.424 a 0.850 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.075905 22.059sec(train) 8.672sec(infer)\n",
      "Epoch 55 tst: l 0.558 a 0.820 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.030sec\n",
      "Epoch 56 tr: l 0.421 a 0.850 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.075525 21.723sec(train) 9.295sec(infer)\n",
      "Epoch 56 tst: l 0.556 a 0.821 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.301sec\n",
      "Epoch 57 tr: l 0.418 a 0.853 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.075148 21.765sec(train) 8.675sec(infer)\n",
      "Epoch 57 tst: l 0.557 a 0.820 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.557sec\n",
      "Epoch 58 tr: l 0.412 a 0.853 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.074772 21.131sec(train) 8.622sec(infer)\n",
      "Epoch 58 tst: l 0.552 a 0.822 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.783sec\n",
      "Epoch 59 tr: l 0.410 a 0.855 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.074398 21.949sec(train) 8.510sec(infer)\n",
      "Epoch 59 tst: l 0.551 a 0.822 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.818sec\n",
      "Epoch 60 tr: l 0.403 a 0.855 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.074026 22.007sec(train) 9.052sec(infer)\n",
      "Epoch 60 tst: l 0.546 a 0.824 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.370sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 61 tr: l 0.402 a 0.858 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.073656 22.086sec(train) 8.440sec(infer)\n",
      "Epoch 61 tst: l 0.540 a 0.826 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.361sec\n",
      "Epoch 62 tr: l 0.401 a 0.857 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.073288 22.226sec(train) 8.583sec(infer)\n",
      "Epoch 62 tst: l 0.539 a 0.826 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.015sec\n",
      "Epoch 63 tr: l 0.395 a 0.859 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.072921 22.383sec(train) 8.611sec(infer)\n",
      "Epoch 63 tst: l 0.533 a 0.827 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.936sec\n",
      "Epoch 64 tr: l 0.392 a 0.859 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.072557 22.288sec(train) 8.635sec(infer)\n",
      "Epoch 64 tst: l 0.534 a 0.828 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.075sec\n",
      "Epoch 65 tr: l 0.392 a 0.860 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.072194 22.463sec(train) 8.613sec(infer)\n",
      "Epoch 65 tst: l 0.531 a 0.828 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.008sec\n",
      "Epoch 66 tr: l 0.389 a 0.861 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.071833 22.544sec(train) 8.458sec(infer)\n",
      "Epoch 66 tst: l 0.527 a 0.830 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.591sec\n",
      "Epoch 67 tr: l 0.383 a 0.862 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.071474 22.302sec(train) 9.108sec(infer)\n",
      "Epoch 67 tst: l 0.527 a 0.829 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.497sec\n",
      "Epoch 68 tr: l 0.380 a 0.864 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.071116 22.037sec(train) 8.412sec(infer)\n",
      "Epoch 68 tst: l 0.524 a 0.831 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.997sec\n",
      "Epoch 69 tr: l 0.377 a 0.864 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.070761 22.793sec(train) 8.745sec(infer)\n",
      "Epoch 69 tst: l 0.520 a 0.832 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.474sec\n",
      "Epoch 70 tr: l 0.374 a 0.865 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.070407 21.619sec(train) 8.271sec(infer)\n",
      "Epoch 70 tst: l 0.520 a 0.832 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.562sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 71 tr: l 0.371 a 0.866 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.070055 22.303sec(train) 8.294sec(infer)\n",
      "Epoch 71 tst: l 0.518 a 0.832 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.277sec\n",
      "Epoch 72 tr: l 0.369 a 0.866 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.069705 22.176sec(train) 8.602sec(infer)\n",
      "Epoch 72 tst: l 0.516 a 0.833 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.960sec\n",
      "Epoch 73 tr: l 0.367 a 0.867 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.069356 21.831sec(train) 8.729sec(infer)\n",
      "Epoch 73 tst: l 0.513 a 0.833 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.116sec\n",
      "Epoch 74 tr: l 0.365 a 0.868 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.069009 21.790sec(train) 8.578sec(infer)\n",
      "Epoch 74 tst: l 0.511 a 0.834 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.354sec\n",
      "Epoch 75 tr: l 0.366 a 0.868 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.068664 21.912sec(train) 8.516sec(infer)\n",
      "Epoch 75 tst: l 0.508 a 0.835 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.673sec\n",
      "Epoch 76 tr: l 0.368 a 0.869 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.068321 21.998sec(train) 8.658sec(infer)\n",
      "Epoch 76 tst: l 0.509 a 0.835 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.506sec\n",
      "Epoch 77 tr: l 0.355 a 0.870 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.067979 22.386sec(train) 8.340sec(infer)\n",
      "Epoch 77 tst: l 0.507 a 0.835 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.195sec\n",
      "Epoch 78 tr: l 0.356 a 0.870 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.067639 21.972sec(train) 8.516sec(infer)\n",
      "Epoch 78 tst: l 0.504 a 0.836 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.290sec\n",
      "Epoch 79 tr: l 0.358 a 0.869 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.067301 21.681sec(train) 8.568sec(infer)\n",
      "Epoch 79 tst: l 0.503 a 0.837 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.525sec\n",
      "Epoch 80 tr: l 0.350 a 0.872 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.066965 22.165sec(train) 8.431sec(infer)\n",
      "Epoch 80 tst: l 0.501 a 0.838 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.268sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 81 tr: l 0.351 a 0.871 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.066630 21.312sec(train) 8.404sec(infer)\n",
      "Epoch 81 tst: l 0.501 a 0.838 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.773sec\n",
      "Epoch 82 tr: l 0.348 a 0.873 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.066297 21.819sec(train) 8.884sec(infer)\n",
      "Epoch 82 tst: l 0.498 a 0.839 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.447sec\n",
      "Epoch 83 tr: l 0.348 a 0.873 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.065965 21.804sec(train) 8.756sec(infer)\n",
      "Epoch 83 tst: l 0.498 a 0.839 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.285sec\n",
      "Epoch 84 tr: l 0.344 a 0.874 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.065635 21.954sec(train) 8.456sec(infer)\n",
      "Epoch 84 tst: l 0.497 a 0.839 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.512sec\n",
      "Epoch 85 tr: l 0.340 a 0.875 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.065307 21.577sec(train) 8.646sec(infer)\n",
      "Epoch 85 tst: l 0.499 a 0.838 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.359sec\n",
      "Epoch 86 tr: l 0.336 a 0.877 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064981 22.336sec(train) 8.371sec(infer)\n",
      "Epoch 86 tst: l 0.492 a 0.841 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.136sec\n",
      "Epoch 87 tr: l 0.334 a 0.877 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064656 22.601sec(train) 8.431sec(infer)\n",
      "Epoch 87 tst: l 0.491 a 0.841 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.176sec\n",
      "Epoch 88 tr: l 0.333 a 0.877 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064333 22.168sec(train) 8.357sec(infer)\n",
      "Epoch 88 tst: l 0.490 a 0.842 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.044sec\n",
      "Epoch 89 tr: l 0.336 a 0.877 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064011 22.082sec(train) 8.596sec(infer)\n",
      "Epoch 89 tst: l 0.489 a 0.841 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.147sec\n",
      "Epoch 90 tr: l 0.341 a 0.878 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.063691 22.311sec(train) 8.428sec(infer)\n",
      "Epoch 90 tst: l 0.491 a 0.840 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.254sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 91 tr: l 0.332 a 0.877 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.063372 21.866sec(train) 8.296sec(infer)\n",
      "Epoch 91 tst: l 0.488 a 0.841 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.430sec\n",
      "Epoch 92 tr: l 0.329 a 0.879 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.063056 21.923sec(train) 8.381sec(infer)\n",
      "Epoch 92 tst: l 0.487 a 0.842 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.615sec\n",
      "Epoch 93 tr: l 0.327 a 0.880 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.062740 21.754sec(train) 8.430sec(infer)\n",
      "Epoch 93 tst: l 0.487 a 0.842 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.506sec\n",
      "Epoch 94 tr: l 0.325 a 0.880 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.062427 21.233sec(train) 8.249sec(infer)\n",
      "Epoch 94 tst: l 0.483 a 0.843 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.647sec\n",
      "Epoch 95 tr: l 0.323 a 0.881 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.062114 21.088sec(train) 8.518sec(infer)\n",
      "Epoch 95 tst: l 0.484 a 0.843 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.578sec\n",
      "Epoch 96 tr: l 0.326 a 0.882 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.061804 22.181sec(train) 8.168sec(infer)\n",
      "Epoch 96 tst: l 0.487 a 0.841 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.230sec\n",
      "Epoch 97 tr: l 0.320 a 0.882 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.061495 21.713sec(train) 8.337sec(infer)\n",
      "Epoch 97 tst: l 0.482 a 0.843 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.295sec\n",
      "Epoch 98 tr: l 0.316 a 0.883 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.061187 22.251sec(train) 8.200sec(infer)\n",
      "Epoch 98 tst: l 0.480 a 0.843 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.689sec\n",
      "Epoch 99 tr: l 0.315 a 0.884 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.060881 21.462sec(train) 8.335sec(infer)\n",
      "Epoch 99 tst: l 0.480 a 0.844 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.963sec\n",
      "Epoch 100 tr: l 0.331 a 0.880 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.006058 21.585sec(train) 8.625sec(infer)\n",
      "Epoch 100 tst: l 0.470 a 0.847 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.126sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 101 tr: l 0.343 a 0.878 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.006027 21.590sec(train) 8.527sec(infer)\n",
      "Epoch 101 tst: l 0.466 a 0.848 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.017sec\n",
      "Epoch 102 tr: l 0.350 a 0.876 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005997 21.557sec(train) 8.075sec(infer)\n",
      "Epoch 102 tst: l 0.464 a 0.848 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.227sec\n",
      "Epoch 103 tr: l 0.350 a 0.876 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005967 21.314sec(train) 8.567sec(infer)\n",
      "Epoch 103 tst: l 0.463 a 0.849 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.249sec\n",
      "Epoch 104 tr: l 0.351 a 0.876 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005937 21.317sec(train) 8.192sec(infer)\n",
      "Epoch 104 tst: l 0.462 a 0.849 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.173sec\n",
      "Epoch 105 tr: l 0.352 a 0.876 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005908 21.288sec(train) 8.595sec(infer)\n",
      "Epoch 105 tst: l 0.461 a 0.849 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.376sec\n",
      "Epoch 106 tr: l 0.353 a 0.875 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005878 21.624sec(train) 8.629sec(infer)\n",
      "Epoch 106 tst: l 0.461 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.584sec\n",
      "Epoch 107 tr: l 0.352 a 0.876 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005849 21.314sec(train) 8.414sec(infer)\n",
      "Epoch 107 tst: l 0.460 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.967sec\n",
      "Epoch 108 tr: l 0.350 a 0.876 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005820 22.710sec(train) 8.495sec(infer)\n",
      "Epoch 108 tst: l 0.460 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.129sec\n",
      "Epoch 109 tr: l 0.351 a 0.876 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005790 22.048sec(train) 8.855sec(infer)\n",
      "Epoch 109 tst: l 0.460 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.955sec\n",
      "Epoch 110 tr: l 0.350 a 0.876 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005762 22.789sec(train) 8.252sec(infer)\n",
      "Epoch 110 tst: l 0.460 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.821sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 111 tr: l 0.350 a 0.876 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005733 22.791sec(train) 8.533sec(infer)\n",
      "Epoch 111 tst: l 0.459 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.494sec\n",
      "Epoch 112 tr: l 0.349 a 0.877 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005704 22.586sec(train) 8.573sec(infer)\n",
      "Epoch 112 tst: l 0.459 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.817sec\n",
      "Epoch 113 tr: l 0.350 a 0.876 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005676 22.769sec(train) 8.361sec(infer)\n",
      "Epoch 113 tst: l 0.459 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.705sec\n",
      "Epoch 114 tr: l 0.351 a 0.876 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005647 21.700sec(train) 8.445sec(infer)\n",
      "Epoch 114 tst: l 0.458 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.167sec\n",
      "Epoch 115 tr: l 0.349 a 0.876 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005619 22.121sec(train) 8.431sec(infer)\n",
      "Epoch 115 tst: l 0.458 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.339sec\n",
      "Epoch 116 tr: l 0.351 a 0.877 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005591 21.982sec(train) 8.618sec(infer)\n",
      "Epoch 116 tst: l 0.458 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.398sec\n",
      "Epoch 117 tr: l 0.349 a 0.877 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005563 21.905sec(train) 8.623sec(infer)\n",
      "Epoch 117 tst: l 0.458 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.245sec\n",
      "Epoch 118 tr: l 0.348 a 0.877 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005535 22.185sec(train) 8.276sec(infer)\n",
      "Epoch 118 tst: l 0.458 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.347sec\n",
      "Epoch 119 tr: l 0.350 a 0.877 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005507 22.172sec(train) 8.424sec(infer)\n",
      "Epoch 119 tst: l 0.458 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.107sec\n",
      "Epoch 120 tr: l 0.347 a 0.877 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005480 21.464sec(train) 8.610sec(infer)\n",
      "Epoch 120 tst: l 0.458 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.492sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 121 tr: l 0.348 a 0.877 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005452 21.844sec(train) 8.593sec(infer)\n",
      "Epoch 121 tst: l 0.457 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.447sec\n",
      "Epoch 122 tr: l 0.348 a 0.877 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005425 22.795sec(train) 8.525sec(infer)\n",
      "Epoch 122 tst: l 0.457 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.797sec\n",
      "Epoch 123 tr: l 0.347 a 0.877 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005398 22.145sec(train) 8.228sec(infer)\n",
      "Epoch 123 tst: l 0.457 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.900sec\n",
      "Epoch 124 tr: l 0.346 a 0.877 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005371 21.909sec(train) 8.489sec(infer)\n",
      "Epoch 124 tst: l 0.457 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.158sec\n",
      "Epoch 125 tr: l 0.345 a 0.877 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005344 22.005sec(train) 8.602sec(infer)\n",
      "Epoch 125 tst: l 0.457 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.064sec\n",
      "Epoch 126 tr: l 0.347 a 0.877 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005318 21.423sec(train) 8.857sec(infer)\n",
      "Epoch 126 tst: l 0.456 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.548sec\n",
      "Epoch 127 tr: l 0.347 a 0.877 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005291 21.837sec(train) 8.646sec(infer)\n",
      "Epoch 127 tst: l 0.457 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.511sec\n",
      "Epoch 128 tr: l 0.346 a 0.878 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005264 21.755sec(train) 8.350sec(infer)\n",
      "Epoch 128 tst: l 0.456 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.665sec\n",
      "Epoch 129 tr: l 0.346 a 0.878 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005238 22.086sec(train) 8.880sec(infer)\n",
      "Epoch 129 tst: l 0.456 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.100sec\n",
      "Epoch 130 tr: l 0.346 a 0.878 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005212 21.899sec(train) 8.447sec(infer)\n",
      "Epoch 130 tst: l 0.456 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.312sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 131 tr: l 0.344 a 0.878 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005186 21.807sec(train) 8.659sec(infer)\n",
      "Epoch 131 tst: l 0.456 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.211sec\n",
      "Epoch 132 tr: l 0.345 a 0.878 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005160 22.028sec(train) 8.606sec(infer)\n",
      "Epoch 132 tst: l 0.456 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.126sec\n",
      "Epoch 133 tr: l 0.344 a 0.878 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005134 21.696sec(train) 8.891sec(infer)\n",
      "Epoch 133 tst: l 0.456 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.108sec\n",
      "Epoch 134 tr: l 0.345 a 0.878 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005108 22.245sec(train) 8.184sec(infer)\n",
      "Epoch 134 tst: l 0.456 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.399sec\n",
      "Epoch 135 tr: l 0.344 a 0.878 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005083 21.752sec(train) 8.537sec(infer)\n",
      "Epoch 135 tst: l 0.456 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.640sec\n",
      "Epoch 136 tr: l 0.343 a 0.879 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005058 22.129sec(train) 8.530sec(infer)\n",
      "Epoch 136 tst: l 0.456 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.471sec\n",
      "Epoch 137 tr: l 0.344 a 0.878 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005032 22.389sec(train) 8.571sec(infer)\n",
      "Epoch 137 tst: l 0.455 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.996sec\n",
      "Epoch 138 tr: l 0.345 a 0.878 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005007 21.772sec(train) 8.223sec(infer)\n",
      "Epoch 138 tst: l 0.455 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.330sec\n",
      "Epoch 139 tr: l 0.344 a 0.878 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004982 21.665sec(train) 8.435sec(infer)\n",
      "Epoch 139 tst: l 0.455 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.585sec\n",
      "Epoch 140 tr: l 0.343 a 0.878 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004957 21.467sec(train) 8.487sec(infer)\n",
      "Epoch 140 tst: l 0.455 a 0.852 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.570sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 141 tr: l 0.342 a 0.879 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004932 22.032sec(train) 8.447sec(infer)\n",
      "Epoch 141 tst: l 0.455 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.738sec\n",
      "Epoch 142 tr: l 0.342 a 0.879 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004908 21.497sec(train) 8.538sec(infer)\n",
      "Epoch 142 tst: l 0.455 a 0.852 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.508sec\n",
      "Epoch 143 tr: l 0.344 a 0.878 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004883 21.458sec(train) 8.522sec(infer)\n",
      "Epoch 143 tst: l 0.455 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.655sec\n",
      "Epoch 144 tr: l 0.341 a 0.879 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004859 21.759sec(train) 4.244sec(infer)\n",
      "Epoch 144 tst: l 0.455 a 0.852 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  3.959sec\n",
      "Epoch 145 tr: l 0.342 a 0.879 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004834 16.780sec(train) 4.679sec(infer)\n",
      "Epoch 145 tst: l 0.455 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  4.070sec\n",
      "Epoch 146 tr: l 0.342 a 0.879 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004810 16.642sec(train) 4.223sec(infer)\n",
      "Epoch 146 tst: l 0.455 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  4.058sec\n",
      "Epoch 147 tr: l 0.342 a 0.879 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004786 16.567sec(train) 4.815sec(infer)\n",
      "Epoch 147 tst: l 0.455 a 0.852 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  3.717sec\n",
      "Epoch 148 tr: l 0.343 a 0.879 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004762 16.727sec(train) 4.598sec(infer)\n",
      "Epoch 148 tst: l 0.455 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  3.801sec\n",
      "Epoch 149 tr: l 0.343 a 0.879 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004738 16.809sec(train) 4.195sec(infer)\n",
      "Epoch 149 tst: l 0.454 a 0.852 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  3.624sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "---train cluster Ended in 1.57 hour (5640.691 sec) \n"
     ]
    }
   ],
   "source": [
    "__.display_outputs()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-19T12:04:35.672761Z",
     "iopub.status.busy": "2025-09-19T12:04:35.672413Z",
     "iopub.status.idle": "2025-09-19T12:04:35.679967Z",
     "shell.execute_reply": "2025-09-19T12:04:35.679467Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "---------------------------------DFCA-GI, lr: 0.1, seed: 1824---------------------------------\n",
      "config: {'m': 200, 'm_test': 40, 'p': 4, 'n': 1500, 'uneven': True, 'local_model_init': False, 'Gp': 0.15, 'graph': 'er', 'agg': 'seq', '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:2\n",
      "Epoch -1 tr: l 3.864 a 0.026 clct[np.int64(89), np.int64(15), np.int64(44), np.int64(52)] cl_acc 0.665  6.606sec\n",
      "Epoch -1 tst: l 3.866 a 0.030 clct[np.int64(14), np.int64(4), np.int64(10), np.int64(12)] cl_acc 0.725  6.932sec\n",
      "Epoch 0 tr: l 3.084 a 0.383 clct[np.int64(87), np.int64(15), np.int64(45), np.int64(53)] cl_acc 0.685  lr 0.100000 23.717sec(train) 7.933sec(infer)\n",
      "Epoch 0 tst: l 3.493 a 0.206 clct[np.int64(19), np.int64(3), np.int64(9), np.int64(9)] cl_acc 0.750  7.153sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 1 tr: l 2.386 a 0.543 clct[np.int64(86), np.int64(15), np.int64(45), np.int64(54)] cl_acc 0.700  lr 0.099500 30.404sec(train) 11.711sec(infer)\n",
      "Epoch 1 tst: l 2.971 a 0.389 clct[np.int64(19), np.int64(2), np.int64(10), np.int64(9)] cl_acc 0.775  8.602sec\n",
      "Epoch 2 tr: l 1.886 a 0.608 clct[np.int64(89), np.int64(15), np.int64(43), np.int64(53)] cl_acc 0.710  lr 0.099003 31.789sec(train) 11.180sec(infer)\n",
      "Epoch 2 tst: l 2.453 a 0.488 clct[np.int64(18), np.int64(2), np.int64(10), np.int64(10)] cl_acc 0.800  10.219sec\n",
      "Epoch 3 tr: l 1.561 a 0.644 clct[np.int64(88), np.int64(15), np.int64(44), np.int64(53)] cl_acc 0.710  lr 0.098507 30.656sec(train) 12.299sec(infer)\n",
      "Epoch 3 tst: l 2.060 a 0.545 clct[np.int64(17), np.int64(4), np.int64(9), np.int64(10)] cl_acc 0.750  9.562sec\n",
      "Epoch 4 tr: l 1.348 a 0.669 clct[np.int64(89), np.int64(15), np.int64(43), np.int64(53)] cl_acc 0.715  lr 0.098015 31.183sec(train) 11.185sec(infer)\n",
      "Epoch 4 tst: l 1.790 a 0.580 clct[np.int64(18), np.int64(2), np.int64(10), np.int64(10)] cl_acc 0.800  9.622sec\n",
      "Epoch 5 tr: l 1.256 a 0.670 clct[np.int64(90), np.int64(14), np.int64(45), np.int64(51)] cl_acc 0.725  lr 0.097525 31.092sec(train) 11.747sec(infer)\n",
      "Epoch 5 tst: l 1.619 a 0.603 clct[np.int64(18), np.int64(2), np.int64(10), np.int64(10)] cl_acc 0.800  10.386sec\n",
      "Epoch 6 tr: l 1.138 a 0.688 clct[np.int64(88), np.int64(15), np.int64(46), np.int64(51)] cl_acc 0.740  lr 0.097037 30.376sec(train) 12.311sec(infer)\n",
      "Epoch 6 tst: l 1.489 a 0.621 clct[np.int64(17), np.int64(3), np.int64(10), np.int64(10)] cl_acc 0.825  9.134sec\n",
      "Epoch 7 tr: l 1.059 a 0.707 clct[np.int64(88), np.int64(15), np.int64(46), np.int64(51)] cl_acc 0.740  lr 0.096552 31.255sec(train) 10.507sec(infer)\n",
      "Epoch 7 tst: l 1.370 a 0.648 clct[np.int64(17), np.int64(3), np.int64(10), np.int64(10)] cl_acc 0.825  10.132sec\n",
      "Epoch 8 tr: l 0.987 a 0.721 clct[np.int64(87), np.int64(16), np.int64(46), np.int64(51)] cl_acc 0.745  lr 0.096069 30.734sec(train) 12.138sec(infer)\n",
      "Epoch 8 tst: l 1.299 a 0.659 clct[np.int64(18), np.int64(2), np.int64(10), np.int64(10)] cl_acc 0.800  10.425sec\n",
      "Epoch 9 tr: l 0.928 a 0.739 clct[np.int64(87), np.int64(16), np.int64(46), np.int64(51)] cl_acc 0.755  lr 0.095589 30.269sec(train) 12.032sec(infer)\n",
      "Epoch 9 tst: l 1.220 a 0.677 clct[np.int64(18), np.int64(2), np.int64(10), np.int64(10)] cl_acc 0.800  8.922sec\n",
      "Epoch 10 tr: l 0.886 a 0.746 clct[np.int64(86), np.int64(17), np.int64(46), np.int64(51)] cl_acc 0.760  lr 0.095111 31.428sec(train) 10.862sec(infer)\n",
      "Epoch 10 tst: l 1.165 a 0.684 clct[np.int64(17), np.int64(3), np.int64(10), np.int64(10)] cl_acc 0.825  10.515sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 11 tr: l 0.832 a 0.756 clct[np.int64(85), np.int64(18), np.int64(46), np.int64(51)] cl_acc 0.765  lr 0.094635 30.223sec(train) 12.229sec(infer)\n",
      "Epoch 11 tst: l 1.117 a 0.698 clct[np.int64(17), np.int64(3), np.int64(10), np.int64(10)] cl_acc 0.825  10.200sec\n",
      "Epoch 12 tr: l 0.803 a 0.764 clct[np.int64(85), np.int64(18), np.int64(46), np.int64(51)] cl_acc 0.765  lr 0.094162 30.329sec(train) 11.366sec(infer)\n",
      "Epoch 12 tst: l 1.078 a 0.705 clct[np.int64(17), np.int64(3), np.int64(10), np.int64(10)] cl_acc 0.825  9.525sec\n",
      "Epoch 13 tr: l 0.756 a 0.775 clct[np.int64(83), np.int64(19), np.int64(47), np.int64(51)] cl_acc 0.780  lr 0.093691 31.374sec(train) 11.495sec(infer)\n",
      "Epoch 13 tst: l 1.042 a 0.714 clct[np.int64(16), np.int64(4), np.int64(10), np.int64(10)] cl_acc 0.850  10.572sec\n",
      "Epoch 14 tr: l 0.730 a 0.783 clct[np.int64(77), np.int64(25), np.int64(48), np.int64(50)] cl_acc 0.815  lr 0.093223 30.389sec(train) 12.294sec(infer)\n",
      "Epoch 14 tst: l 1.009 a 0.718 clct[np.int64(16), np.int64(4), np.int64(10), np.int64(10)] cl_acc 0.850  9.689sec\n",
      "Epoch 15 tr: l 0.685 a 0.793 clct[np.int64(77), np.int64(24), np.int64(49), np.int64(50)] cl_acc 0.830  lr 0.092757 31.023sec(train) 10.845sec(infer)\n",
      "Epoch 15 tst: l 0.974 a 0.731 clct[np.int64(14), np.int64(6), np.int64(10), np.int64(10)] cl_acc 0.900  10.189sec\n",
      "Epoch 16 tr: l 0.681 a 0.794 clct[np.int64(76), np.int64(25), np.int64(49), np.int64(50)] cl_acc 0.845  lr 0.092293 30.880sec(train) 12.124sec(infer)\n",
      "Epoch 16 tst: l 0.946 a 0.735 clct[np.int64(14), np.int64(6), np.int64(10), np.int64(10)] cl_acc 0.900  10.604sec\n",
      "Epoch 17 tr: l 0.647 a 0.806 clct[np.int64(70), np.int64(31), np.int64(49), np.int64(50)] cl_acc 0.875  lr 0.091832 30.392sec(train) 12.326sec(infer)\n",
      "Epoch 17 tst: l 0.905 a 0.751 clct[np.int64(14), np.int64(6), np.int64(10), np.int64(10)] cl_acc 0.900  9.185sec\n",
      "Epoch 18 tr: l 0.616 a 0.811 clct[np.int64(63), np.int64(37), np.int64(50), np.int64(50)] cl_acc 0.915  lr 0.091372 31.490sec(train) 10.683sec(infer)\n",
      "Epoch 18 tst: l 0.866 a 0.759 clct[np.int64(13), np.int64(7), np.int64(10), np.int64(10)] cl_acc 0.925  10.684sec\n",
      "Epoch 19 tr: l 0.577 a 0.818 clct[np.int64(62), np.int64(38), np.int64(50), np.int64(50)] cl_acc 0.920  lr 0.090916 30.406sec(train) 12.277sec(infer)\n",
      "Epoch 19 tst: l 0.827 a 0.769 clct[np.int64(12), np.int64(8), np.int64(10), np.int64(10)] cl_acc 0.950  10.566sec\n",
      "Epoch 20 tr: l 0.556 a 0.825 clct[np.int64(57), np.int64(43), np.int64(50), np.int64(50)] cl_acc 0.945  lr 0.090461 30.366sec(train) 11.727sec(infer)\n",
      "Epoch 20 tst: l 0.789 a 0.780 clct[np.int64(12), np.int64(8), np.int64(10), np.int64(10)] cl_acc 0.950  9.281sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 21 tr: l 0.533 a 0.833 clct[np.int64(55), np.int64(45), np.int64(50), np.int64(50)] cl_acc 0.965  lr 0.090009 31.665sec(train) 11.234sec(infer)\n",
      "Epoch 21 tst: l 0.754 a 0.788 clct[np.int64(11), np.int64(9), np.int64(10), np.int64(10)] cl_acc 0.975  10.669sec\n",
      "Epoch 22 tr: l 0.509 a 0.834 clct[np.int64(53), np.int64(47), np.int64(50), np.int64(50)] cl_acc 0.975  lr 0.089559 30.328sec(train) 12.235sec(infer)\n",
      "Epoch 22 tst: l 0.720 a 0.793 clct[np.int64(11), np.int64(9), np.int64(10), np.int64(10)] cl_acc 0.975  10.060sec\n",
      "Epoch 23 tr: l 0.487 a 0.842 clct[np.int64(53), np.int64(47), np.int64(50), np.int64(50)] cl_acc 0.975  lr 0.089111 30.598sec(train) 11.051sec(infer)\n",
      "Epoch 23 tst: l 0.697 a 0.799 clct[np.int64(11), np.int64(9), np.int64(10), np.int64(10)] cl_acc 0.975  9.843sec\n",
      "Epoch 24 tr: l 0.483 a 0.842 clct[np.int64(51), np.int64(49), np.int64(50), np.int64(50)] cl_acc 0.985  lr 0.088665 31.273sec(train) 11.807sec(infer)\n",
      "Epoch 24 tst: l 0.680 a 0.803 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.790sec\n",
      "Epoch 25 tr: l 0.465 a 0.848 clct[np.int64(51), np.int64(49), np.int64(50), np.int64(50)] cl_acc 0.985  lr 0.088222 30.124sec(train) 12.370sec(infer)\n",
      "Epoch 25 tst: l 0.667 a 0.805 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.520sec\n",
      "Epoch 26 tr: l 0.457 a 0.850 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 0.990  lr 0.087781 31.336sec(train) 10.511sec(infer)\n",
      "Epoch 26 tst: l 0.654 a 0.809 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.430sec\n",
      "Epoch 27 tr: l 0.448 a 0.853 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 0.990  lr 0.087342 30.535sec(train) 12.292sec(infer)\n",
      "Epoch 27 tst: l 0.643 a 0.812 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.698sec\n",
      "Epoch 28 tr: l 0.437 a 0.855 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 0.990  lr 0.086905 30.235sec(train) 11.997sec(infer)\n",
      "Epoch 28 tst: l 0.634 a 0.814 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.214sec\n",
      "Epoch 29 tr: l 0.428 a 0.857 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 0.990  lr 0.086471 31.799sec(train) 10.931sec(infer)\n",
      "Epoch 29 tst: l 0.625 a 0.816 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.647sec\n",
      "Epoch 30 tr: l 0.417 a 0.860 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 0.990  lr 0.086038 30.273sec(train) 12.173sec(infer)\n",
      "Epoch 30 tst: l 0.618 a 0.817 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.452sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 31 tr: l 0.411 a 0.861 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.085608 30.544sec(train) 11.429sec(infer)\n",
      "Epoch 31 tst: l 0.612 a 0.819 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.650sec\n",
      "Epoch 32 tr: l 0.401 a 0.863 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.085180 31.498sec(train) 11.576sec(infer)\n",
      "Epoch 32 tst: l 0.607 a 0.819 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.680sec\n",
      "Epoch 33 tr: l 0.398 a 0.865 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.084754 30.409sec(train) 12.164sec(infer)\n",
      "Epoch 33 tst: l 0.599 a 0.822 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.721sec\n",
      "Epoch 34 tr: l 0.396 a 0.866 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.084331 31.346sec(train) 10.785sec(infer)\n",
      "Epoch 34 tst: l 0.593 a 0.823 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.233sec\n",
      "Epoch 35 tr: l 0.388 a 0.867 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.083909 31.040sec(train) 12.229sec(infer)\n",
      "Epoch 35 tst: l 0.588 a 0.824 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.617sec\n",
      "Epoch 36 tr: l 0.386 a 0.868 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.083489 30.377sec(train) 12.129sec(infer)\n",
      "Epoch 36 tst: l 0.583 a 0.825 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.098sec\n",
      "Epoch 37 tr: l 0.379 a 0.870 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.083072 31.876sec(train) 10.863sec(infer)\n",
      "Epoch 37 tst: l 0.578 a 0.826 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.593sec\n",
      "Epoch 38 tr: l 0.377 a 0.870 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.082657 30.281sec(train) 12.307sec(infer)\n",
      "Epoch 38 tst: l 0.574 a 0.827 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.482sec\n",
      "Epoch 39 tr: l 0.369 a 0.873 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.082243 30.395sec(train) 11.593sec(infer)\n",
      "Epoch 39 tst: l 0.570 a 0.828 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.459sec\n",
      "Epoch 40 tr: l 0.368 a 0.872 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.081832 31.354sec(train) 11.420sec(infer)\n",
      "Epoch 40 tst: l 0.568 a 0.829 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.626sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 41 tr: l 0.366 a 0.874 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.081423 30.305sec(train) 12.320sec(infer)\n",
      "Epoch 41 tst: l 0.562 a 0.830 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.856sec\n",
      "Epoch 42 tr: l 0.361 a 0.875 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.081016 30.747sec(train) 11.019sec(infer)\n",
      "Epoch 42 tst: l 0.562 a 0.829 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.022sec\n",
      "Epoch 43 tr: l 0.359 a 0.876 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.080611 30.996sec(train) 11.837sec(infer)\n",
      "Epoch 43 tst: l 0.556 a 0.831 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.643sec\n",
      "Epoch 44 tr: l 0.352 a 0.878 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.080208 30.431sec(train) 12.253sec(infer)\n",
      "Epoch 44 tst: l 0.554 a 0.831 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.316sec\n",
      "Epoch 45 tr: l 0.353 a 0.877 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.079807 31.422sec(train) 10.502sec(infer)\n",
      "Epoch 45 tst: l 0.550 a 0.833 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.563sec\n",
      "Epoch 46 tr: l 0.347 a 0.879 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.079408 30.504sec(train) 12.237sec(infer)\n",
      "Epoch 46 tst: l 0.547 a 0.833 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.663sec\n",
      "Epoch 47 tr: l 0.343 a 0.880 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.079010 30.311sec(train) 11.945sec(infer)\n",
      "Epoch 47 tst: l 0.545 a 0.834 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.222sec\n",
      "Epoch 48 tr: l 0.339 a 0.881 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.078615 31.940sec(train) 11.086sec(infer)\n",
      "Epoch 48 tst: l 0.540 a 0.835 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.643sec\n",
      "Epoch 49 tr: l 0.337 a 0.882 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.078222 30.503sec(train) 12.306sec(infer)\n",
      "Epoch 49 tst: l 0.539 a 0.836 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.131sec\n",
      "Epoch 50 tr: l 0.334 a 0.883 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.077831 30.834sec(train) 11.279sec(infer)\n",
      "Epoch 50 tst: l 0.537 a 0.835 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.794sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 51 tr: l 0.332 a 0.883 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.077442 31.360sec(train) 11.675sec(infer)\n",
      "Epoch 51 tst: l 0.534 a 0.836 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.683sec\n",
      "Epoch 52 tr: l 0.328 a 0.884 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.077055 30.457sec(train) 12.274sec(infer)\n",
      "Epoch 52 tst: l 0.533 a 0.836 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.554sec\n",
      "Epoch 53 tr: l 0.329 a 0.884 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.076670 31.559sec(train) 10.603sec(infer)\n",
      "Epoch 53 tst: l 0.531 a 0.837 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.390sec\n",
      "Epoch 54 tr: l 0.322 a 0.886 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.076286 30.780sec(train) 12.273sec(infer)\n",
      "Epoch 54 tst: l 0.528 a 0.837 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.684sec\n",
      "Epoch 55 tr: l 0.322 a 0.886 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.075905 30.651sec(train) 12.049sec(infer)\n",
      "Epoch 55 tst: l 0.526 a 0.839 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.074sec\n",
      "Epoch 56 tr: l 0.321 a 0.887 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.075525 32.003sec(train) 10.951sec(infer)\n",
      "Epoch 56 tst: l 0.523 a 0.838 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.534sec\n",
      "Epoch 57 tr: l 0.318 a 0.887 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.075148 30.494sec(train) 12.322sec(infer)\n",
      "Epoch 57 tst: l 0.522 a 0.840 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.118sec\n",
      "Epoch 58 tr: l 0.314 a 0.889 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.074772 30.785sec(train) 11.300sec(infer)\n",
      "Epoch 58 tst: l 0.521 a 0.839 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.620sec\n",
      "Epoch 59 tr: l 0.315 a 0.888 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.074398 31.275sec(train) 11.505sec(infer)\n",
      "Epoch 59 tst: l 0.520 a 0.840 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.534sec\n",
      "Epoch 60 tr: l 0.310 a 0.889 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.074026 30.527sec(train) 12.276sec(infer)\n",
      "Epoch 60 tst: l 0.516 a 0.840 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.402sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 61 tr: l 0.306 a 0.890 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.073656 31.193sec(train) 10.685sec(infer)\n",
      "Epoch 61 tst: l 0.517 a 0.841 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.296sec\n",
      "Epoch 62 tr: l 0.303 a 0.892 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.073288 30.694sec(train) 12.306sec(infer)\n",
      "Epoch 62 tst: l 0.514 a 0.841 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.505sec\n",
      "Epoch 63 tr: l 0.305 a 0.891 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.072921 30.599sec(train) 12.229sec(infer)\n",
      "Epoch 63 tst: l 0.513 a 0.842 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.126sec\n",
      "Epoch 64 tr: l 0.301 a 0.892 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.072557 32.211sec(train) 11.023sec(infer)\n",
      "Epoch 64 tst: l 0.511 a 0.842 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.543sec\n",
      "Epoch 65 tr: l 0.300 a 0.893 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.072194 30.171sec(train) 12.335sec(infer)\n",
      "Epoch 65 tst: l 0.510 a 0.843 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.318sec\n",
      "Epoch 66 tr: l 0.299 a 0.894 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.071833 30.387sec(train) 11.587sec(infer)\n",
      "Epoch 66 tst: l 0.507 a 0.843 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.546sec\n",
      "Epoch 67 tr: l 0.297 a 0.894 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.071474 31.980sec(train) 11.741sec(infer)\n",
      "Epoch 67 tst: l 0.508 a 0.844 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.696sec\n",
      "Epoch 68 tr: l 0.294 a 0.895 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.071116 30.864sec(train) 12.380sec(infer)\n",
      "Epoch 68 tst: l 0.506 a 0.843 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.620sec\n",
      "Epoch 69 tr: l 0.295 a 0.894 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.070761 31.450sec(train) 10.779sec(infer)\n",
      "Epoch 69 tst: l 0.505 a 0.844 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.186sec\n",
      "Epoch 70 tr: l 0.293 a 0.895 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.070407 31.093sec(train) 12.272sec(infer)\n",
      "Epoch 70 tst: l 0.503 a 0.844 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.630sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 71 tr: l 0.292 a 0.895 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.070055 30.717sec(train) 12.296sec(infer)\n",
      "Epoch 71 tst: l 0.502 a 0.845 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.122sec\n",
      "Epoch 72 tr: l 0.288 a 0.896 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.069705 32.012sec(train) 10.930sec(infer)\n",
      "Epoch 72 tst: l 0.501 a 0.845 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.570sec\n",
      "Epoch 73 tr: l 0.285 a 0.897 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.069356 30.235sec(train) 12.374sec(infer)\n",
      "Epoch 73 tst: l 0.499 a 0.846 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.489sec\n",
      "Epoch 74 tr: l 0.283 a 0.898 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.069009 30.409sec(train) 11.642sec(infer)\n",
      "Epoch 74 tst: l 0.498 a 0.845 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.485sec\n",
      "Epoch 75 tr: l 0.281 a 0.898 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.068664 31.902sec(train) 11.493sec(infer)\n",
      "Epoch 75 tst: l 0.498 a 0.846 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.681sec\n",
      "Epoch 76 tr: l 0.281 a 0.899 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.068321 30.485sec(train) 12.278sec(infer)\n",
      "Epoch 76 tst: l 0.495 a 0.846 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.929sec\n",
      "Epoch 77 tr: l 0.281 a 0.899 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.067979 30.894sec(train) 11.086sec(infer)\n",
      "Epoch 77 tst: l 0.495 a 0.847 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.999sec\n",
      "Epoch 78 tr: l 0.281 a 0.899 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.067639 31.262sec(train) 12.003sec(infer)\n",
      "Epoch 78 tst: l 0.494 a 0.846 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.671sec\n",
      "Epoch 79 tr: l 0.277 a 0.900 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.067301 30.377sec(train) 12.364sec(infer)\n",
      "Epoch 79 tst: l 0.494 a 0.847 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.359sec\n",
      "Epoch 80 tr: l 0.279 a 0.899 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.066965 31.265sec(train) 10.587sec(infer)\n",
      "Epoch 80 tst: l 0.492 a 0.847 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.450sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 81 tr: l 0.281 a 0.899 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.066630 30.794sec(train) 12.295sec(infer)\n",
      "Epoch 81 tst: l 0.491 a 0.848 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.698sec\n",
      "Epoch 82 tr: l 0.278 a 0.900 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.066297 30.071sec(train) 12.044sec(infer)\n",
      "Epoch 82 tst: l 0.490 a 0.848 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.237sec\n",
      "Epoch 83 tr: l 0.273 a 0.900 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.065965 31.814sec(train) 10.992sec(infer)\n",
      "Epoch 83 tst: l 0.491 a 0.848 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.670sec\n",
      "Epoch 84 tr: l 0.274 a 0.901 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.065635 30.278sec(train) 12.359sec(infer)\n",
      "Epoch 84 tst: l 0.489 a 0.848 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.456sec\n",
      "Epoch 85 tr: l 0.274 a 0.901 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.065307 30.533sec(train) 11.479sec(infer)\n",
      "Epoch 85 tst: l 0.488 a 0.848 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.555sec\n",
      "Epoch 86 tr: l 0.270 a 0.902 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.064981 31.672sec(train) 11.600sec(infer)\n",
      "Epoch 86 tst: l 0.488 a 0.848 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.683sec\n",
      "Epoch 87 tr: l 0.266 a 0.904 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.064656 30.224sec(train) 12.191sec(infer)\n",
      "Epoch 87 tst: l 0.486 a 0.849 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.807sec\n",
      "Epoch 88 tr: l 0.265 a 0.903 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.064333 31.323sec(train) 11.138sec(infer)\n",
      "Epoch 88 tst: l 0.487 a 0.848 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.283sec\n",
      "Epoch 89 tr: l 0.264 a 0.903 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.064011 30.954sec(train) 12.270sec(infer)\n",
      "Epoch 89 tst: l 0.486 a 0.849 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.698sec\n",
      "Epoch 90 tr: l 0.264 a 0.904 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.063691 30.258sec(train) 12.260sec(infer)\n",
      "Epoch 90 tst: l 0.484 a 0.849 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.186sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 91 tr: l 0.264 a 0.904 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.063372 31.549sec(train) 10.665sec(infer)\n",
      "Epoch 91 tst: l 0.484 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.746sec\n",
      "Epoch 92 tr: l 0.265 a 0.904 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.063056 30.495sec(train) 12.318sec(infer)\n",
      "Epoch 92 tst: l 0.482 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.745sec\n",
      "Epoch 93 tr: l 0.262 a 0.904 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.062740 30.259sec(train) 11.756sec(infer)\n",
      "Epoch 93 tst: l 0.482 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.335sec\n",
      "Epoch 94 tr: l 0.260 a 0.905 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.062427 31.989sec(train) 11.296sec(infer)\n",
      "Epoch 94 tst: l 0.481 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.716sec\n",
      "Epoch 95 tr: l 0.259 a 0.906 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.062114 30.398sec(train) 12.281sec(infer)\n",
      "Epoch 95 tst: l 0.481 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.177sec\n",
      "Epoch 96 tr: l 0.256 a 0.907 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.061804 30.716sec(train) 11.260sec(infer)\n",
      "Epoch 96 tst: l 0.480 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.891sec\n",
      "Epoch 97 tr: l 0.255 a 0.907 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.061495 31.638sec(train) 11.765sec(infer)\n",
      "Epoch 97 tst: l 0.480 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.739sec\n",
      "Epoch 98 tr: l 0.255 a 0.908 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.061187 30.797sec(train) 12.390sec(infer)\n",
      "Epoch 98 tst: l 0.479 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.451sec\n",
      "Epoch 99 tr: l 0.254 a 0.907 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.060881 31.511sec(train) 10.664sec(infer)\n",
      "Epoch 99 tst: l 0.480 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.516sec\n",
      "Epoch 100 tr: l 0.281 a 0.898 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.006058 30.872sec(train) 12.322sec(infer)\n",
      "Epoch 100 tst: l 0.475 a 0.852 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.659sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 101 tr: l 0.296 a 0.893 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.006027 30.396sec(train) 12.082sec(infer)\n",
      "Epoch 101 tst: l 0.474 a 0.852 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.192sec\n",
      "Epoch 102 tr: l 0.302 a 0.891 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.005997 31.710sec(train) 10.960sec(infer)\n",
      "Epoch 102 tst: l 0.472 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.725sec\n",
      "Epoch 103 tr: l 0.305 a 0.890 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.005967 30.478sec(train) 12.294sec(infer)\n",
      "Epoch 103 tst: l 0.472 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.439sec\n",
      "Epoch 104 tr: l 0.306 a 0.889 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.005937 30.591sec(train) 11.488sec(infer)\n",
      "Epoch 104 tst: l 0.472 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.625sec\n",
      "Epoch 105 tr: l 0.306 a 0.889 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.005908 31.575sec(train) 11.557sec(infer)\n",
      "Epoch 105 tst: l 0.471 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.698sec\n",
      "Epoch 106 tr: l 0.306 a 0.889 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.005878 30.156sec(train) 12.336sec(infer)\n",
      "Epoch 106 tst: l 0.471 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.892sec\n",
      "Epoch 107 tr: l 0.306 a 0.889 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.005849 31.035sec(train) 10.925sec(infer)\n",
      "Epoch 107 tst: l 0.471 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.156sec\n",
      "Epoch 108 tr: l 0.307 a 0.889 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.005820 31.118sec(train) 12.016sec(infer)\n",
      "Epoch 108 tst: l 0.471 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.672sec\n",
      "Epoch 109 tr: l 0.307 a 0.889 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.005790 28.956sec(train) 12.325sec(infer)\n",
      "Epoch 109 tst: l 0.471 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.637sec\n",
      "Epoch 110 tr: l 0.307 a 0.889 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.005762 30.521sec(train) 12.269sec(infer)\n",
      "Epoch 110 tst: l 0.470 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.074sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 111 tr: l 0.307 a 0.889 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.005733 31.966sec(train) 10.928sec(infer)\n",
      "Epoch 111 tst: l 0.470 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.607sec\n",
      "Epoch 112 tr: l 0.307 a 0.889 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.005704 30.377sec(train) 12.327sec(infer)\n",
      "Epoch 112 tst: l 0.470 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.369sec\n",
      "Epoch 113 tr: l 0.307 a 0.889 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.005676 30.397sec(train) 11.433sec(infer)\n",
      "Epoch 113 tst: l 0.470 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.567sec\n",
      "Epoch 114 tr: l 0.308 a 0.889 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.005647 31.498sec(train) 11.563sec(infer)\n",
      "Epoch 114 tst: l 0.470 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.608sec\n",
      "Epoch 115 tr: l 0.307 a 0.889 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.005619 30.412sec(train) 12.317sec(infer)\n",
      "Epoch 115 tst: l 0.470 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.685sec\n",
      "Epoch 116 tr: l 0.306 a 0.889 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.005591 30.973sec(train) 10.824sec(infer)\n",
      "Epoch 116 tst: l 0.470 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.304sec\n",
      "Epoch 117 tr: l 0.306 a 0.889 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.005563 31.180sec(train) 12.359sec(infer)\n",
      "Epoch 117 tst: l 0.469 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.738sec\n",
      "Epoch 118 tr: l 0.306 a 0.889 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.005535 30.473sec(train) 12.355sec(infer)\n",
      "Epoch 118 tst: l 0.469 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.143sec\n",
      "Epoch 119 tr: l 0.306 a 0.889 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.005507 31.991sec(train) 10.913sec(infer)\n",
      "Epoch 119 tst: l 0.469 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.701sec\n",
      "Epoch 120 tr: l 0.306 a 0.889 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.005480 30.748sec(train) 12.377sec(infer)\n",
      "Epoch 120 tst: l 0.469 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.385sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 121 tr: l 0.306 a 0.889 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.005452 30.586sec(train) 11.433sec(infer)\n",
      "Epoch 121 tst: l 0.469 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.569sec\n",
      "Epoch 122 tr: l 0.307 a 0.889 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.005425 31.424sec(train) 11.653sec(infer)\n",
      "Epoch 122 tst: l 0.469 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.642sec\n",
      "Epoch 123 tr: l 0.306 a 0.889 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.005398 30.480sec(train) 12.290sec(infer)\n",
      "Epoch 123 tst: l 0.469 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.618sec\n",
      "Epoch 124 tr: l 0.306 a 0.889 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.005371 31.092sec(train) 10.813sec(infer)\n",
      "Epoch 124 tst: l 0.469 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.258sec\n",
      "Epoch 125 tr: l 0.305 a 0.889 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.005344 30.768sec(train) 12.217sec(infer)\n",
      "Epoch 125 tst: l 0.469 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.619sec\n",
      "Epoch 126 tr: l 0.304 a 0.890 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.005318 30.560sec(train) 12.189sec(infer)\n",
      "Epoch 126 tst: l 0.469 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.163sec\n",
      "Epoch 127 tr: l 0.305 a 0.889 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.005291 32.076sec(train) 11.057sec(infer)\n",
      "Epoch 127 tst: l 0.469 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.648sec\n",
      "Epoch 128 tr: l 0.305 a 0.889 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.005264 30.439sec(train) 12.403sec(infer)\n",
      "Epoch 128 tst: l 0.468 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.426sec\n",
      "Epoch 129 tr: l 0.307 a 0.889 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.005238 30.454sec(train) 11.500sec(infer)\n",
      "Epoch 129 tst: l 0.468 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.706sec\n",
      "Epoch 130 tr: l 0.306 a 0.889 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.005212 31.625sec(train) 11.854sec(infer)\n",
      "Epoch 130 tst: l 0.468 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.872sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 131 tr: l 0.305 a 0.889 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.005186 30.575sec(train) 12.263sec(infer)\n",
      "Epoch 131 tst: l 0.468 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.755sec\n",
      "Epoch 132 tr: l 0.305 a 0.889 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.005160 31.143sec(train) 10.811sec(infer)\n",
      "Epoch 132 tst: l 0.468 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.330sec\n",
      "Epoch 133 tr: l 0.305 a 0.889 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.005134 30.853sec(train) 12.301sec(infer)\n",
      "Epoch 133 tst: l 0.468 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.713sec\n",
      "Epoch 134 tr: l 0.305 a 0.889 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.005108 30.639sec(train) 12.176sec(infer)\n",
      "Epoch 134 tst: l 0.468 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.349sec\n",
      "Epoch 135 tr: l 0.305 a 0.889 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.005083 32.094sec(train) 11.030sec(infer)\n",
      "Epoch 135 tst: l 0.468 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.698sec\n",
      "Epoch 136 tr: l 0.305 a 0.889 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.005058 30.730sec(train) 12.381sec(infer)\n",
      "Epoch 136 tst: l 0.468 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.373sec\n",
      "Epoch 137 tr: l 0.305 a 0.890 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.005032 30.766sec(train) 11.439sec(infer)\n",
      "Epoch 137 tst: l 0.468 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.725sec\n",
      "Epoch 138 tr: l 0.304 a 0.889 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.005007 31.636sec(train) 11.807sec(infer)\n",
      "Epoch 138 tst: l 0.468 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.719sec\n",
      "Epoch 139 tr: l 0.304 a 0.890 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.004982 30.415sec(train) 12.272sec(infer)\n",
      "Epoch 139 tst: l 0.467 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.655sec\n",
      "Epoch 140 tr: l 0.304 a 0.889 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.004957 31.604sec(train) 10.765sec(infer)\n",
      "Epoch 140 tst: l 0.467 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.467sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 141 tr: l 0.306 a 0.889 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.004932 30.835sec(train) 12.381sec(infer)\n",
      "Epoch 141 tst: l 0.467 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.562sec\n",
      "Epoch 142 tr: l 0.304 a 0.890 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.004908 30.651sec(train) 12.106sec(infer)\n",
      "Epoch 142 tst: l 0.467 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.229sec\n",
      "Epoch 143 tr: l 0.305 a 0.890 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.004883 32.102sec(train) 11.175sec(infer)\n",
      "Epoch 143 tst: l 0.467 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.618sec\n",
      "Epoch 144 tr: l 0.305 a 0.889 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.004859 30.508sec(train) 12.392sec(infer)\n",
      "Epoch 144 tst: l 0.467 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.140sec\n",
      "Epoch 145 tr: l 0.305 a 0.889 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.004834 30.496sec(train) 11.378sec(infer)\n",
      "Epoch 145 tst: l 0.467 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.793sec\n",
      "Epoch 146 tr: l 0.305 a 0.889 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.004810 31.549sec(train) 11.819sec(infer)\n",
      "Epoch 146 tst: l 0.467 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.668sec\n",
      "Epoch 147 tr: l 0.304 a 0.890 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.004786 30.543sec(train) 12.370sec(infer)\n",
      "Epoch 147 tst: l 0.467 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.456sec\n",
      "Epoch 148 tr: l 0.304 a 0.890 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.004762 31.618sec(train) 10.608sec(infer)\n",
      "Epoch 148 tst: l 0.467 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.492sec\n",
      "Epoch 149 tr: l 0.304 a 0.890 clct[np.int64(49), np.int64(51), np.int64(50), np.int64(50)] cl_acc 0.995  lr 0.004738 30.655sec(train) 12.326sec(infer)\n",
      "Epoch 149 tst: l 0.467 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.679sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "---train cluster Ended in 2.20 hour (7915.713 sec) \n",
      "---------------------------------DFCA-GI, lr: 0.1, seed: 409---------------------------------\n",
      "config: {'m': 200, 'm_test': 40, 'p': 4, 'n': 1500, 'uneven': True, 'local_model_init': False, 'Gp': 0.15, 'graph': 'er', 'agg': 'seq', '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:2\n",
      "Epoch -1 tr: l 3.863 a 0.024 clct[np.int64(112), np.int64(6), np.int64(64), np.int64(18)] cl_acc 0.420  8.835sec\n",
      "Epoch -1 tst: l 3.865 a 0.029 clct[np.int64(23), np.int64(2), np.int64(12), np.int64(3)] cl_acc 0.375  9.632sec\n",
      "Epoch 0 tr: l 3.272 a 0.295 clct[np.int64(108), np.int64(6), np.int64(68), np.int64(18)] cl_acc 0.450  lr 0.100000 33.228sec(train) 10.558sec(infer)\n",
      "Epoch 0 tst: l 3.529 a 0.171 clct[np.int64(21), np.int64(0), np.int64(15), np.int64(4)] cl_acc 0.450  9.692sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 1 tr: l 2.753 a 0.419 clct[np.int64(103), np.int64(7), np.int64(71), np.int64(19)] cl_acc 0.505  lr 0.099500 24.050sec(train) 7.334sec(infer)\n",
      "Epoch 1 tst: l 3.116 a 0.285 clct[np.int64(21), np.int64(0), np.int64(15), np.int64(4)] cl_acc 0.525  6.014sec\n",
      "Epoch 2 tr: l 2.338 a 0.484 clct[np.int64(91), np.int64(9), np.int64(78), np.int64(22)] cl_acc 0.565  lr 0.099003 25.163sec(train) 9.901sec(infer)\n",
      "Epoch 2 tst: l 2.720 a 0.366 clct[np.int64(19), np.int64(2), np.int64(16), np.int64(3)] cl_acc 0.575  10.045sec\n",
      "Epoch 3 tr: l 1.967 a 0.539 clct[np.int64(84), np.int64(11), np.int64(80), np.int64(25)] cl_acc 0.595  lr 0.098507 33.170sec(train) 10.485sec(infer)\n",
      "Epoch 3 tst: l 2.430 a 0.429 clct[np.int64(18), np.int64(2), np.int64(15), np.int64(5)] cl_acc 0.575  8.996sec\n",
      "Epoch 4 tr: l 1.685 a 0.587 clct[np.int64(82), np.int64(13), np.int64(81), np.int64(24)] cl_acc 0.610  lr 0.098015 34.120sec(train) 8.817sec(infer)\n",
      "Epoch 4 tst: l 2.152 a 0.488 clct[np.int64(16), np.int64(4), np.int64(17), np.int64(3)] cl_acc 0.675  9.911sec\n",
      "Epoch 5 tr: l 1.530 a 0.606 clct[np.int64(75), np.int64(21), np.int64(81), np.int64(23)] cl_acc 0.660  lr 0.097525 33.166sec(train) 10.604sec(infer)\n",
      "Epoch 5 tst: l 1.942 a 0.528 clct[np.int64(16), np.int64(4), np.int64(16), np.int64(4)] cl_acc 0.700  10.236sec\n",
      "Epoch 6 tr: l 1.380 a 0.635 clct[np.int64(69), np.int64(27), np.int64(82), np.int64(22)] cl_acc 0.695  lr 0.097037 33.082sec(train) 10.190sec(infer)\n",
      "Epoch 6 tst: l 1.764 a 0.571 clct[np.int64(14), np.int64(6), np.int64(16), np.int64(4)] cl_acc 0.750  8.801sec\n",
      "Epoch 7 tr: l 1.256 a 0.662 clct[np.int64(60), np.int64(38), np.int64(80), np.int64(22)] cl_acc 0.755  lr 0.096552 34.332sec(train) 9.660sec(infer)\n",
      "Epoch 7 tst: l 1.617 a 0.595 clct[np.int64(13), np.int64(7), np.int64(15), np.int64(5)] cl_acc 0.800  10.398sec\n",
      "Epoch 8 tr: l 1.109 a 0.707 clct[np.int64(51), np.int64(47), np.int64(78), np.int64(24)] cl_acc 0.810  lr 0.096069 32.634sec(train) 10.523sec(infer)\n",
      "Epoch 8 tst: l 1.461 a 0.636 clct[np.int64(11), np.int64(9), np.int64(15), np.int64(5)] cl_acc 0.800  9.776sec\n",
      "Epoch 9 tr: l 1.019 a 0.717 clct[np.int64(50), np.int64(48), np.int64(80), np.int64(22)] cl_acc 0.825  lr 0.095589 33.364sec(train) 9.351sec(infer)\n",
      "Epoch 9 tst: l 1.306 a 0.664 clct[np.int64(10), np.int64(10), np.int64(14), np.int64(6)] cl_acc 0.900  9.855sec\n",
      "Epoch 10 tr: l 0.923 a 0.743 clct[np.int64(50), np.int64(49), np.int64(77), np.int64(24)] cl_acc 0.845  lr 0.095111 33.233sec(train) 10.549sec(infer)\n",
      "Epoch 10 tst: l 1.193 a 0.689 clct[np.int64(10), np.int64(10), np.int64(14), np.int64(6)] cl_acc 0.900  10.581sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 11 tr: l 0.870 a 0.751 clct[np.int64(49), np.int64(50), np.int64(71), np.int64(30)] cl_acc 0.880  lr 0.094635 32.532sec(train) 10.683sec(infer)\n",
      "Epoch 11 tst: l 1.121 a 0.700 clct[np.int64(10), np.int64(10), np.int64(14), np.int64(6)] cl_acc 0.900  9.166sec\n",
      "Epoch 12 tr: l 0.810 a 0.766 clct[np.int64(50), np.int64(50), np.int64(61), np.int64(39)] cl_acc 0.935  lr 0.094162 34.127sec(train) 9.530sec(infer)\n",
      "Epoch 12 tst: l 1.043 a 0.723 clct[np.int64(10), np.int64(10), np.int64(12), np.int64(8)] cl_acc 0.950  10.778sec\n",
      "Epoch 13 tr: l 0.740 a 0.786 clct[np.int64(50), np.int64(50), np.int64(59), np.int64(41)] cl_acc 0.955  lr 0.093691 32.053sec(train) 10.836sec(infer)\n",
      "Epoch 13 tst: l 0.949 a 0.744 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.438sec\n",
      "Epoch 14 tr: l 0.687 a 0.796 clct[np.int64(50), np.int64(50), np.int64(56), np.int64(44)] cl_acc 0.970  lr 0.093223 32.564sec(train) 9.940sec(infer)\n",
      "Epoch 14 tst: l 0.875 a 0.760 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.730sec\n",
      "Epoch 15 tr: l 0.652 a 0.804 clct[np.int64(50), np.int64(50), np.int64(51), np.int64(49)] cl_acc 0.995  lr 0.092757 33.425sec(train) 10.708sec(infer)\n",
      "Epoch 15 tst: l 0.831 a 0.767 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.822sec\n",
      "Epoch 16 tr: l 0.617 a 0.814 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.092293 31.787sec(train) 11.171sec(infer)\n",
      "Epoch 16 tst: l 0.791 a 0.776 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.595sec\n",
      "Epoch 17 tr: l 0.590 a 0.821 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.091832 33.189sec(train) 9.570sec(infer)\n",
      "Epoch 17 tst: l 0.762 a 0.781 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.643sec\n",
      "Epoch 18 tr: l 0.560 a 0.826 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.091372 31.843sec(train) 11.307sec(infer)\n",
      "Epoch 18 tst: l 0.744 a 0.784 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.805sec\n",
      "Epoch 19 tr: l 0.541 a 0.830 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.090916 31.949sec(train) 10.795sec(infer)\n",
      "Epoch 19 tst: l 0.715 a 0.791 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.464sec\n",
      "Epoch 20 tr: l 0.526 a 0.834 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.090461 33.008sec(train) 10.776sec(infer)\n",
      "Epoch 20 tst: l 0.694 a 0.796 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.745sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 21 tr: l 0.506 a 0.839 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.090009 31.195sec(train) 11.598sec(infer)\n",
      "Epoch 21 tst: l 0.675 a 0.799 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.904sec\n",
      "Epoch 22 tr: l 0.493 a 0.842 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.089559 32.594sec(train) 10.199sec(infer)\n",
      "Epoch 22 tst: l 0.661 a 0.803 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.308sec\n",
      "Epoch 23 tr: l 0.486 a 0.844 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.089111 31.647sec(train) 11.741sec(infer)\n",
      "Epoch 23 tst: l 0.648 a 0.806 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.627sec\n",
      "Epoch 24 tr: l 0.474 a 0.847 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.088665 31.146sec(train) 11.558sec(infer)\n",
      "Epoch 24 tst: l 0.636 a 0.808 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.290sec\n",
      "Epoch 25 tr: l 0.467 a 0.848 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.088222 32.706sec(train) 10.638sec(infer)\n",
      "Epoch 25 tst: l 0.627 a 0.810 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.840sec\n",
      "Epoch 26 tr: l 0.452 a 0.852 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.087781 31.110sec(train) 11.897sec(infer)\n",
      "Epoch 26 tst: l 0.618 a 0.812 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.381sec\n",
      "Epoch 27 tr: l 0.446 a 0.853 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.087342 31.458sec(train) 10.906sec(infer)\n",
      "Epoch 27 tst: l 0.610 a 0.815 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.886sec\n",
      "Epoch 28 tr: l 0.437 a 0.856 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.086905 31.871sec(train) 11.580sec(infer)\n",
      "Epoch 28 tst: l 0.602 a 0.816 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.753sec\n",
      "Epoch 29 tr: l 0.430 a 0.857 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.086471 30.910sec(train) 12.018sec(infer)\n",
      "Epoch 29 tst: l 0.595 a 0.818 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.527sec\n",
      "Epoch 30 tr: l 0.421 a 0.860 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.086038 32.095sec(train) 10.384sec(infer)\n",
      "Epoch 30 tst: l 0.589 a 0.819 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.779sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 31 tr: l 0.413 a 0.862 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.085608 30.969sec(train) 12.204sec(infer)\n",
      "Epoch 31 tst: l 0.582 a 0.821 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.783sec\n",
      "Epoch 32 tr: l 0.412 a 0.863 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.085180 30.455sec(train) 11.662sec(infer)\n",
      "Epoch 32 tst: l 0.575 a 0.822 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.317sec\n",
      "Epoch 33 tr: l 0.405 a 0.865 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.084754 32.617sec(train) 11.216sec(infer)\n",
      "Epoch 33 tst: l 0.571 a 0.824 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.768sec\n",
      "Epoch 34 tr: l 0.399 a 0.867 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.084331 30.819sec(train) 12.245sec(infer)\n",
      "Epoch 34 tst: l 0.566 a 0.824 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.021sec\n",
      "Epoch 35 tr: l 0.392 a 0.868 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.083909 31.485sec(train) 10.961sec(infer)\n",
      "Epoch 35 tst: l 0.561 a 0.826 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.166sec\n",
      "Epoch 36 tr: l 0.390 a 0.869 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.083489 31.449sec(train) 12.135sec(infer)\n",
      "Epoch 36 tst: l 0.555 a 0.827 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.778sec\n",
      "Epoch 37 tr: l 0.389 a 0.868 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.083072 30.521sec(train) 12.160sec(infer)\n",
      "Epoch 37 tst: l 0.552 a 0.829 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.375sec\n",
      "Epoch 38 tr: l 0.381 a 0.871 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.082657 32.224sec(train) 10.889sec(infer)\n",
      "Epoch 38 tst: l 0.547 a 0.829 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.801sec\n",
      "Epoch 39 tr: l 0.379 a 0.871 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.082243 30.696sec(train) 12.322sec(infer)\n",
      "Epoch 39 tst: l 0.544 a 0.830 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.571sec\n",
      "Epoch 40 tr: l 0.373 a 0.874 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.081832 30.477sec(train) 11.572sec(infer)\n",
      "Epoch 40 tst: l 0.540 a 0.831 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.633sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 41 tr: l 0.367 a 0.874 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.081423 31.810sec(train) 11.558sec(infer)\n",
      "Epoch 41 tst: l 0.538 a 0.832 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.819sec\n",
      "Epoch 42 tr: l 0.365 a 0.875 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.081016 30.515sec(train) 12.283sec(infer)\n",
      "Epoch 42 tst: l 0.535 a 0.832 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.853sec\n",
      "Epoch 43 tr: l 0.361 a 0.877 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.080611 31.744sec(train) 10.757sec(infer)\n",
      "Epoch 43 tst: l 0.532 a 0.834 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.335sec\n",
      "Epoch 44 tr: l 0.360 a 0.877 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.080208 30.835sec(train) 12.250sec(infer)\n",
      "Epoch 44 tst: l 0.528 a 0.834 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.772sec\n",
      "Epoch 45 tr: l 0.357 a 0.878 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.079807 30.318sec(train) 12.078sec(infer)\n",
      "Epoch 45 tst: l 0.525 a 0.835 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.255sec\n",
      "Epoch 46 tr: l 0.354 a 0.879 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.079408 32.152sec(train) 10.888sec(infer)\n",
      "Epoch 46 tst: l 0.523 a 0.835 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.806sec\n",
      "Epoch 47 tr: l 0.349 a 0.880 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.079010 30.591sec(train) 12.346sec(infer)\n",
      "Epoch 47 tst: l 0.520 a 0.836 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.506sec\n",
      "Epoch 48 tr: l 0.348 a 0.881 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.078615 30.632sec(train) 11.399sec(infer)\n",
      "Epoch 48 tst: l 0.517 a 0.837 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.720sec\n",
      "Epoch 49 tr: l 0.344 a 0.881 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.078222 31.525sec(train) 11.625sec(infer)\n",
      "Epoch 49 tst: l 0.515 a 0.837 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.733sec\n",
      "Epoch 50 tr: l 0.339 a 0.883 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.077831 30.529sec(train) 12.265sec(infer)\n",
      "Epoch 50 tst: l 0.513 a 0.837 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.731sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 51 tr: l 0.336 a 0.883 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.077442 30.945sec(train) 10.758sec(infer)\n",
      "Epoch 51 tst: l 0.511 a 0.838 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.417sec\n",
      "Epoch 52 tr: l 0.337 a 0.884 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.077055 30.716sec(train) 12.287sec(infer)\n",
      "Epoch 52 tst: l 0.508 a 0.840 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.791sec\n",
      "Epoch 53 tr: l 0.333 a 0.884 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.076670 30.580sec(train) 12.164sec(infer)\n",
      "Epoch 53 tst: l 0.506 a 0.840 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.323sec\n",
      "Epoch 54 tr: l 0.329 a 0.885 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.076286 31.850sec(train) 10.865sec(infer)\n",
      "Epoch 54 tst: l 0.504 a 0.840 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.716sec\n",
      "Epoch 55 tr: l 0.325 a 0.887 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.075905 30.298sec(train) 12.308sec(infer)\n",
      "Epoch 55 tst: l 0.503 a 0.841 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.520sec\n",
      "Epoch 56 tr: l 0.325 a 0.887 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.075525 30.539sec(train) 11.504sec(infer)\n",
      "Epoch 56 tst: l 0.500 a 0.841 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.652sec\n",
      "Epoch 57 tr: l 0.322 a 0.888 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.075148 31.633sec(train) 11.573sec(infer)\n",
      "Epoch 57 tst: l 0.499 a 0.842 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.754sec\n",
      "Epoch 58 tr: l 0.320 a 0.888 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.074772 30.502sec(train) 12.207sec(infer)\n",
      "Epoch 58 tst: l 0.497 a 0.842 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.925sec\n",
      "Epoch 59 tr: l 0.317 a 0.889 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.074398 31.084sec(train) 10.805sec(infer)\n",
      "Epoch 59 tst: l 0.495 a 0.842 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.282sec\n",
      "Epoch 60 tr: l 0.318 a 0.888 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.074026 30.824sec(train) 12.209sec(infer)\n",
      "Epoch 60 tst: l 0.494 a 0.843 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.800sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 61 tr: l 0.319 a 0.889 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.073656 30.163sec(train) 12.251sec(infer)\n",
      "Epoch 61 tst: l 0.493 a 0.843 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.226sec\n",
      "Epoch 62 tr: l 0.314 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.073288 31.726sec(train) 10.712sec(infer)\n",
      "Epoch 62 tst: l 0.491 a 0.843 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.736sec\n",
      "Epoch 63 tr: l 0.314 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.072921 30.632sec(train) 12.310sec(infer)\n",
      "Epoch 63 tst: l 0.489 a 0.844 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.677sec\n",
      "Epoch 64 tr: l 0.311 a 0.891 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.072557 30.654sec(train) 11.638sec(infer)\n",
      "Epoch 64 tst: l 0.489 a 0.844 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.491sec\n",
      "Epoch 65 tr: l 0.307 a 0.892 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.072194 31.746sec(train) 11.409sec(infer)\n",
      "Epoch 65 tst: l 0.487 a 0.845 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.593sec\n",
      "Epoch 66 tr: l 0.302 a 0.893 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.071833 30.361sec(train) 12.262sec(infer)\n",
      "Epoch 66 tst: l 0.486 a 0.845 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.992sec\n",
      "Epoch 67 tr: l 0.303 a 0.893 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.071474 31.065sec(train) 10.848sec(infer)\n",
      "Epoch 67 tst: l 0.484 a 0.845 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.136sec\n",
      "Epoch 68 tr: l 0.305 a 0.893 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.071116 30.814sec(train) 10.905sec(infer)\n",
      "Epoch 68 tst: l 0.483 a 0.846 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.072sec\n",
      "Epoch 69 tr: l 0.301 a 0.894 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.070761 31.141sec(train) 11.915sec(infer)\n",
      "Epoch 69 tst: l 0.481 a 0.846 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.786sec\n",
      "Epoch 70 tr: l 0.300 a 0.894 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.070407 30.256sec(train) 12.284sec(infer)\n",
      "Epoch 70 tst: l 0.481 a 0.846 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.383sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 71 tr: l 0.298 a 0.895 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.070055 31.394sec(train) 10.495sec(infer)\n",
      "Epoch 71 tst: l 0.479 a 0.847 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.734sec\n",
      "Epoch 72 tr: l 0.298 a 0.895 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.069705 30.534sec(train) 12.328sec(infer)\n",
      "Epoch 72 tst: l 0.478 a 0.847 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.794sec\n",
      "Epoch 73 tr: l 0.296 a 0.895 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.069356 30.020sec(train) 11.800sec(infer)\n",
      "Epoch 73 tst: l 0.476 a 0.848 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.194sec\n",
      "Epoch 74 tr: l 0.293 a 0.896 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.069009 31.752sec(train) 11.056sec(infer)\n",
      "Epoch 74 tst: l 0.476 a 0.848 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.760sec\n",
      "Epoch 75 tr: l 0.295 a 0.896 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.068664 30.221sec(train) 12.304sec(infer)\n",
      "Epoch 75 tst: l 0.474 a 0.848 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.380sec\n",
      "Epoch 76 tr: l 0.291 a 0.897 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.068321 30.237sec(train) 11.323sec(infer)\n",
      "Epoch 76 tst: l 0.473 a 0.848 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.591sec\n",
      "Epoch 77 tr: l 0.290 a 0.897 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.067979 31.464sec(train) 11.601sec(infer)\n",
      "Epoch 77 tst: l 0.473 a 0.849 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.748sec\n",
      "Epoch 78 tr: l 0.285 a 0.899 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.067639 30.353sec(train) 12.254sec(infer)\n",
      "Epoch 78 tst: l 0.472 a 0.848 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.738sec\n",
      "Epoch 79 tr: l 0.286 a 0.899 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.067301 31.058sec(train) 10.725sec(infer)\n",
      "Epoch 79 tst: l 0.472 a 0.849 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.326sec\n",
      "Epoch 80 tr: l 0.283 a 0.900 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.066965 30.817sec(train) 12.236sec(infer)\n",
      "Epoch 80 tst: l 0.471 a 0.849 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.744sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 81 tr: l 0.286 a 0.898 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.066630 30.129sec(train) 12.084sec(infer)\n",
      "Epoch 81 tst: l 0.470 a 0.849 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.300sec\n",
      "Epoch 82 tr: l 0.283 a 0.899 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.066297 31.705sec(train) 10.706sec(infer)\n",
      "Epoch 82 tst: l 0.469 a 0.849 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.776sec\n",
      "Epoch 83 tr: l 0.282 a 0.900 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.065965 30.262sec(train) 12.318sec(infer)\n",
      "Epoch 83 tst: l 0.468 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.592sec\n",
      "Epoch 84 tr: l 0.279 a 0.901 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.065635 30.287sec(train) 11.360sec(infer)\n",
      "Epoch 84 tst: l 0.467 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.510sec\n",
      "Epoch 85 tr: l 0.278 a 0.901 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.065307 31.814sec(train) 11.420sec(infer)\n",
      "Epoch 85 tst: l 0.467 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.691sec\n",
      "Epoch 86 tr: l 0.279 a 0.901 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064981 30.021sec(train) 12.242sec(infer)\n",
      "Epoch 86 tst: l 0.465 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.965sec\n",
      "Epoch 87 tr: l 0.276 a 0.901 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064656 30.968sec(train) 10.935sec(infer)\n",
      "Epoch 87 tst: l 0.465 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.125sec\n",
      "Epoch 88 tr: l 0.273 a 0.902 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064333 31.152sec(train) 12.018sec(infer)\n",
      "Epoch 88 tst: l 0.464 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.753sec\n",
      "Epoch 89 tr: l 0.271 a 0.903 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064011 30.382sec(train) 12.262sec(infer)\n",
      "Epoch 89 tst: l 0.463 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.357sec\n",
      "Epoch 90 tr: l 0.270 a 0.903 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.063691 31.561sec(train) 10.510sec(infer)\n",
      "Epoch 90 tst: l 0.462 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.750sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 91 tr: l 0.269 a 0.904 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.063372 30.325sec(train) 12.325sec(infer)\n",
      "Epoch 91 tst: l 0.462 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.658sec\n",
      "Epoch 92 tr: l 0.268 a 0.905 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.063056 30.209sec(train) 11.787sec(infer)\n",
      "Epoch 92 tst: l 0.461 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.259sec\n",
      "Epoch 93 tr: l 0.267 a 0.905 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.062740 31.831sec(train) 11.039sec(infer)\n",
      "Epoch 93 tst: l 0.461 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.725sec\n",
      "Epoch 94 tr: l 0.268 a 0.904 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.062427 30.273sec(train) 12.320sec(infer)\n",
      "Epoch 94 tst: l 0.460 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.296sec\n",
      "Epoch 95 tr: l 0.266 a 0.905 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.062114 30.683sec(train) 11.360sec(infer)\n",
      "Epoch 95 tst: l 0.459 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.736sec\n",
      "Epoch 96 tr: l 0.264 a 0.906 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.061804 31.565sec(train) 11.764sec(infer)\n",
      "Epoch 96 tst: l 0.458 a 0.852 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.802sec\n",
      "Epoch 97 tr: l 0.265 a 0.906 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.061495 30.205sec(train) 12.365sec(infer)\n",
      "Epoch 97 tst: l 0.458 a 0.852 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.770sec\n",
      "Epoch 98 tr: l 0.264 a 0.906 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.061187 31.149sec(train) 10.717sec(infer)\n",
      "Epoch 98 tst: l 0.457 a 0.852 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.324sec\n",
      "Epoch 99 tr: l 0.260 a 0.907 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.060881 31.087sec(train) 12.338sec(infer)\n",
      "Epoch 99 tst: l 0.457 a 0.852 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.785sec\n",
      "Epoch 100 tr: l 0.290 a 0.897 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.006058 30.384sec(train) 12.151sec(infer)\n",
      "Epoch 100 tst: l 0.453 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.250sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 101 tr: l 0.302 a 0.892 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.006027 32.020sec(train) 10.834sec(infer)\n",
      "Epoch 101 tst: l 0.452 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.639sec\n",
      "Epoch 102 tr: l 0.307 a 0.891 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005997 30.338sec(train) 12.278sec(infer)\n",
      "Epoch 102 tst: l 0.451 a 0.855 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.502sec\n",
      "Epoch 103 tr: l 0.308 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005967 30.055sec(train) 11.547sec(infer)\n",
      "Epoch 103 tst: l 0.450 a 0.855 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.429sec\n",
      "Epoch 104 tr: l 0.310 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005937 31.723sec(train) 11.418sec(infer)\n",
      "Epoch 104 tst: l 0.450 a 0.855 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.781sec\n",
      "Epoch 105 tr: l 0.310 a 0.889 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005908 30.210sec(train) 12.259sec(infer)\n",
      "Epoch 105 tst: l 0.450 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.116sec\n",
      "Epoch 106 tr: l 0.310 a 0.889 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005878 30.922sec(train) 10.990sec(infer)\n",
      "Epoch 106 tst: l 0.449 a 0.855 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.057sec\n",
      "Epoch 107 tr: l 0.311 a 0.889 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005849 31.127sec(train) 11.967sec(infer)\n",
      "Epoch 107 tst: l 0.449 a 0.855 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.788sec\n",
      "Epoch 108 tr: l 0.311 a 0.889 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005820 30.362sec(train) 12.204sec(infer)\n",
      "Epoch 108 tst: l 0.449 a 0.855 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.340sec\n",
      "Epoch 109 tr: l 0.311 a 0.889 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005790 31.449sec(train) 10.498sec(infer)\n",
      "Epoch 109 tst: l 0.449 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.761sec\n",
      "Epoch 110 tr: l 0.311 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005762 30.510sec(train) 12.375sec(infer)\n",
      "Epoch 110 tst: l 0.449 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.778sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 111 tr: l 0.311 a 0.889 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005733 30.387sec(train) 11.766sec(infer)\n",
      "Epoch 111 tst: l 0.449 a 0.855 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.232sec\n",
      "Epoch 112 tr: l 0.310 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005704 31.720sec(train) 11.005sec(infer)\n",
      "Epoch 112 tst: l 0.448 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.738sec\n",
      "Epoch 113 tr: l 0.311 a 0.889 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005676 30.142sec(train) 12.264sec(infer)\n",
      "Epoch 113 tst: l 0.448 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.325sec\n",
      "Epoch 114 tr: l 0.310 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005647 30.656sec(train) 11.242sec(infer)\n",
      "Epoch 114 tst: l 0.448 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.761sec\n",
      "Epoch 115 tr: l 0.310 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005619 31.334sec(train) 11.548sec(infer)\n",
      "Epoch 115 tst: l 0.448 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.660sec\n",
      "Epoch 116 tr: l 0.311 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005591 30.170sec(train) 12.244sec(infer)\n",
      "Epoch 116 tst: l 0.448 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.740sec\n",
      "Epoch 117 tr: l 0.311 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005563 31.160sec(train) 10.647sec(infer)\n",
      "Epoch 117 tst: l 0.448 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.318sec\n",
      "Epoch 118 tr: l 0.310 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005535 30.794sec(train) 12.251sec(infer)\n",
      "Epoch 118 tst: l 0.448 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.771sec\n",
      "Epoch 119 tr: l 0.310 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005507 30.410sec(train) 12.144sec(infer)\n",
      "Epoch 119 tst: l 0.448 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.326sec\n",
      "Epoch 120 tr: l 0.311 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005480 32.159sec(train) 10.829sec(infer)\n",
      "Epoch 120 tst: l 0.448 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.772sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 121 tr: l 0.311 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005452 30.527sec(train) 12.212sec(infer)\n",
      "Epoch 121 tst: l 0.447 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.480sec\n",
      "Epoch 122 tr: l 0.310 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005425 30.553sec(train) 11.525sec(infer)\n",
      "Epoch 122 tst: l 0.448 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.494sec\n",
      "Epoch 123 tr: l 0.309 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005398 31.577sec(train) 11.484sec(infer)\n",
      "Epoch 123 tst: l 0.447 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.693sec\n",
      "Epoch 124 tr: l 0.309 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005371 30.270sec(train) 12.129sec(infer)\n",
      "Epoch 124 tst: l 0.447 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.911sec\n",
      "Epoch 125 tr: l 0.310 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005344 31.124sec(train) 10.844sec(infer)\n",
      "Epoch 125 tst: l 0.447 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.186sec\n",
      "Epoch 126 tr: l 0.309 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005318 31.132sec(train) 12.115sec(infer)\n",
      "Epoch 126 tst: l 0.447 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.736sec\n",
      "Epoch 127 tr: l 0.309 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005291 30.306sec(train) 12.378sec(infer)\n",
      "Epoch 127 tst: l 0.447 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.206sec\n",
      "Epoch 128 tr: l 0.309 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005264 31.743sec(train) 10.621sec(infer)\n",
      "Epoch 128 tst: l 0.447 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.770sec\n",
      "Epoch 129 tr: l 0.309 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005238 30.144sec(train) 12.265sec(infer)\n",
      "Epoch 129 tst: l 0.447 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.718sec\n",
      "Epoch 130 tr: l 0.309 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005212 30.088sec(train) 11.714sec(infer)\n",
      "Epoch 130 tst: l 0.447 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.354sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 131 tr: l 0.309 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005186 31.664sec(train) 11.130sec(infer)\n",
      "Epoch 131 tst: l 0.447 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.821sec\n",
      "Epoch 132 tr: l 0.309 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005160 30.444sec(train) 12.277sec(infer)\n",
      "Epoch 132 tst: l 0.447 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.128sec\n",
      "Epoch 133 tr: l 0.309 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005134 30.555sec(train) 11.124sec(infer)\n",
      "Epoch 133 tst: l 0.447 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.839sec\n",
      "Epoch 134 tr: l 0.309 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005108 30.925sec(train) 11.600sec(infer)\n",
      "Epoch 134 tst: l 0.446 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.715sec\n",
      "Epoch 135 tr: l 0.310 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005083 30.086sec(train) 12.268sec(infer)\n",
      "Epoch 135 tst: l 0.446 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.717sec\n",
      "Epoch 136 tr: l 0.309 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005058 30.879sec(train) 10.619sec(infer)\n",
      "Epoch 136 tst: l 0.446 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.468sec\n",
      "Epoch 137 tr: l 0.309 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005032 30.527sec(train) 12.280sec(infer)\n",
      "Epoch 137 tst: l 0.446 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.685sec\n",
      "Epoch 138 tr: l 0.310 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005007 30.410sec(train) 12.076sec(infer)\n",
      "Epoch 138 tst: l 0.446 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.226sec\n",
      "Epoch 139 tr: l 0.309 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004982 31.839sec(train) 10.813sec(infer)\n",
      "Epoch 139 tst: l 0.446 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.825sec\n",
      "Epoch 140 tr: l 0.309 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004957 30.428sec(train) 12.424sec(infer)\n",
      "Epoch 140 tst: l 0.446 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.517sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 141 tr: l 0.309 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004932 30.664sec(train) 11.505sec(infer)\n",
      "Epoch 141 tst: l 0.446 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.554sec\n",
      "Epoch 142 tr: l 0.308 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004908 31.733sec(train) 11.478sec(infer)\n",
      "Epoch 142 tst: l 0.446 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.786sec\n",
      "Epoch 143 tr: l 0.308 a 0.891 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004883 30.131sec(train) 12.247sec(infer)\n",
      "Epoch 143 tst: l 0.446 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.938sec\n",
      "Epoch 144 tr: l 0.308 a 0.891 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004859 31.012sec(train) 10.894sec(infer)\n",
      "Epoch 144 tst: l 0.446 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.171sec\n",
      "Epoch 145 tr: l 0.308 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004834 30.747sec(train) 12.075sec(infer)\n",
      "Epoch 145 tst: l 0.446 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.735sec\n",
      "Epoch 146 tr: l 0.309 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004810 30.287sec(train) 12.327sec(infer)\n",
      "Epoch 146 tst: l 0.446 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.324sec\n",
      "Epoch 147 tr: l 0.309 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004786 31.530sec(train) 10.589sec(infer)\n",
      "Epoch 147 tst: l 0.446 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.762sec\n",
      "Epoch 148 tr: l 0.308 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004762 30.834sec(train) 12.528sec(infer)\n",
      "Epoch 148 tst: l 0.445 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.700sec\n",
      "Epoch 149 tr: l 0.308 a 0.891 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004738 30.240sec(train) 11.756sec(infer)\n",
      "Epoch 149 tst: l 0.445 a 0.856 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.253sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "---train cluster Ended in 2.20 hour (7927.345 sec) \n",
      "---------------------------------DFCA-GI, lr: 0.1, seed: 4506---------------------------------\n",
      "config: {'m': 200, 'm_test': 40, 'p': 4, 'n': 1500, 'uneven': True, 'local_model_init': False, 'Gp': 0.15, 'graph': 'er', 'agg': 'seq', '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:2\n",
      "Epoch -1 tr: l 3.868 a 0.021 clct[np.int64(4), np.int64(39), np.int64(79), np.int64(78)] cl_acc 0.405  10.773sec\n",
      "Epoch -1 tst: l 3.867 a 0.026 clct[np.int64(2), np.int64(6), np.int64(19), np.int64(13)] cl_acc 0.475  9.837sec\n",
      "Epoch 0 tr: l 3.225 a 0.325 clct[np.int64(4), np.int64(40), np.int64(78), np.int64(78)] cl_acc 0.410  lr 0.100000 33.334sec(train) 9.923sec(infer)\n",
      "Epoch 0 tst: l 3.552 a 0.161 clct[np.int64(0), np.int64(4), np.int64(17), np.int64(19)] cl_acc 0.475  8.667sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 1 tr: l 2.708 a 0.452 clct[np.int64(4), np.int64(40), np.int64(81), np.int64(75)] cl_acc 0.420  lr 0.099500 34.466sec(train) 9.959sec(infer)\n",
      "Epoch 1 tst: l 3.175 a 0.275 clct[np.int64(0), np.int64(5), np.int64(16), np.int64(19)] cl_acc 0.500  10.128sec\n",
      "Epoch 2 tr: l 2.318 a 0.529 clct[np.int64(4), np.int64(41), np.int64(84), np.int64(71)] cl_acc 0.425  lr 0.099003 23.613sec(train) 8.196sec(infer)\n",
      "Epoch 2 tst: l 2.810 a 0.365 clct[np.int64(0), np.int64(4), np.int64(17), np.int64(19)] cl_acc 0.525  6.059sec\n",
      "Epoch 3 tr: l 1.987 a 0.568 clct[np.int64(4), np.int64(44), np.int64(80), np.int64(72)] cl_acc 0.435  lr 0.098507 24.985sec(train) 8.893sec(infer)\n",
      "Epoch 3 tst: l 2.508 a 0.420 clct[np.int64(0), np.int64(7), np.int64(16), np.int64(17)] cl_acc 0.525  10.370sec\n",
      "Epoch 4 tr: l 1.764 a 0.599 clct[np.int64(5), np.int64(43), np.int64(83), np.int64(69)] cl_acc 0.485  lr 0.098015 33.135sec(train) 10.652sec(infer)\n",
      "Epoch 4 tst: l 2.250 a 0.465 clct[np.int64(1), np.int64(6), np.int64(16), np.int64(17)] cl_acc 0.525  10.106sec\n",
      "Epoch 5 tr: l 1.589 a 0.622 clct[np.int64(5), np.int64(42), np.int64(79), np.int64(74)] cl_acc 0.505  lr 0.097525 33.573sec(train) 9.703sec(infer)\n",
      "Epoch 5 tst: l 2.035 a 0.503 clct[np.int64(1), np.int64(7), np.int64(15), np.int64(17)] cl_acc 0.525  9.333sec\n",
      "Epoch 6 tr: l 1.459 a 0.635 clct[np.int64(5), np.int64(41), np.int64(79), np.int64(75)] cl_acc 0.520  lr 0.097037 33.944sec(train) 10.214sec(infer)\n",
      "Epoch 6 tst: l 1.877 a 0.529 clct[np.int64(0), np.int64(8), np.int64(16), np.int64(16)] cl_acc 0.575  10.579sec\n",
      "Epoch 7 tr: l 1.345 a 0.660 clct[np.int64(5), np.int64(40), np.int64(81), np.int64(74)] cl_acc 0.520  lr 0.096552 32.948sec(train) 10.694sec(infer)\n",
      "Epoch 7 tst: l 1.748 a 0.554 clct[np.int64(1), np.int64(6), np.int64(15), np.int64(18)] cl_acc 0.575  9.176sec\n",
      "Epoch 8 tr: l 1.235 a 0.678 clct[np.int64(6), np.int64(37), np.int64(80), np.int64(77)] cl_acc 0.535  lr 0.096069 34.063sec(train) 9.069sec(infer)\n",
      "Epoch 8 tst: l 1.633 a 0.574 clct[np.int64(2), np.int64(7), np.int64(14), np.int64(17)] cl_acc 0.550  10.710sec\n",
      "Epoch 9 tr: l 1.155 a 0.694 clct[np.int64(6), np.int64(37), np.int64(80), np.int64(77)] cl_acc 0.535  lr 0.095589 32.110sec(train) 10.720sec(infer)\n",
      "Epoch 9 tst: l 1.542 a 0.597 clct[np.int64(2), np.int64(7), np.int64(15), np.int64(16)] cl_acc 0.525  10.511sec\n",
      "Epoch 10 tr: l 1.089 a 0.707 clct[np.int64(6), np.int64(37), np.int64(80), np.int64(77)] cl_acc 0.535  lr 0.095111 32.887sec(train) 9.938sec(infer)\n",
      "Epoch 10 tst: l 1.468 a 0.610 clct[np.int64(2), np.int64(7), np.int64(14), np.int64(17)] cl_acc 0.550  9.670sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 11 tr: l 1.051 a 0.712 clct[np.int64(6), np.int64(36), np.int64(80), np.int64(78)] cl_acc 0.540  lr 0.094635 33.481sec(train) 10.352sec(infer)\n",
      "Epoch 11 tst: l 1.401 a 0.622 clct[np.int64(2), np.int64(7), np.int64(14), np.int64(17)] cl_acc 0.550  10.791sec\n",
      "Epoch 12 tr: l 0.992 a 0.724 clct[np.int64(6), np.int64(37), np.int64(80), np.int64(77)] cl_acc 0.545  lr 0.094162 32.347sec(train) 10.879sec(infer)\n",
      "Epoch 12 tst: l 1.352 a 0.634 clct[np.int64(2), np.int64(9), np.int64(14), np.int64(15)] cl_acc 0.575  9.622sec\n",
      "Epoch 13 tr: l 0.958 a 0.734 clct[np.int64(7), np.int64(37), np.int64(79), np.int64(77)] cl_acc 0.540  lr 0.093691 33.472sec(train) 9.244sec(infer)\n",
      "Epoch 13 tst: l 1.302 a 0.642 clct[np.int64(2), np.int64(7), np.int64(14), np.int64(17)] cl_acc 0.550  11.090sec\n",
      "Epoch 14 tr: l 0.933 a 0.740 clct[np.int64(7), np.int64(39), np.int64(78), np.int64(76)] cl_acc 0.545  lr 0.093223 32.082sec(train) 10.936sec(infer)\n",
      "Epoch 14 tst: l 1.261 a 0.651 clct[np.int64(3), np.int64(5), np.int64(15), np.int64(17)] cl_acc 0.600  10.819sec\n",
      "Epoch 15 tr: l 0.884 a 0.749 clct[np.int64(7), np.int64(37), np.int64(79), np.int64(77)] cl_acc 0.550  lr 0.092757 32.395sec(train) 9.914sec(infer)\n",
      "Epoch 15 tst: l 1.218 a 0.661 clct[np.int64(1), np.int64(7), np.int64(15), np.int64(17)] cl_acc 0.575  10.110sec\n",
      "Epoch 16 tr: l 0.873 a 0.751 clct[np.int64(7), np.int64(36), np.int64(79), np.int64(78)] cl_acc 0.555  lr 0.092293 33.313sec(train) 10.702sec(infer)\n",
      "Epoch 16 tst: l 1.180 a 0.671 clct[np.int64(3), np.int64(7), np.int64(14), np.int64(16)] cl_acc 0.600  11.228sec\n",
      "Epoch 17 tr: l 0.840 a 0.759 clct[np.int64(7), np.int64(35), np.int64(79), np.int64(79)] cl_acc 0.560  lr 0.091832 31.592sec(train) 11.255sec(infer)\n",
      "Epoch 17 tst: l 1.151 a 0.676 clct[np.int64(3), np.int64(8), np.int64(14), np.int64(15)] cl_acc 0.625  9.764sec\n",
      "Epoch 18 tr: l 0.811 a 0.767 clct[np.int64(8), np.int64(36), np.int64(77), np.int64(79)] cl_acc 0.560  lr 0.091372 33.326sec(train) 10.040sec(infer)\n",
      "Epoch 18 tst: l 1.119 a 0.685 clct[np.int64(3), np.int64(8), np.int64(13), np.int64(16)] cl_acc 0.575  11.373sec\n",
      "Epoch 19 tr: l 0.781 a 0.771 clct[np.int64(9), np.int64(35), np.int64(76), np.int64(80)] cl_acc 0.560  lr 0.090916 31.042sec(train) 11.533sec(infer)\n",
      "Epoch 19 tst: l 1.094 a 0.689 clct[np.int64(3), np.int64(8), np.int64(14), np.int64(15)] cl_acc 0.625  10.912sec\n",
      "Epoch 20 tr: l 0.761 a 0.778 clct[np.int64(9), np.int64(35), np.int64(76), np.int64(80)] cl_acc 0.560  lr 0.090461 31.745sec(train) 10.601sec(infer)\n",
      "Epoch 20 tst: l 1.065 a 0.697 clct[np.int64(4), np.int64(9), np.int64(13), np.int64(14)] cl_acc 0.675  10.244sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 21 tr: l 0.737 a 0.785 clct[np.int64(9), np.int64(35), np.int64(77), np.int64(79)] cl_acc 0.570  lr 0.090009 32.269sec(train) 11.310sec(infer)\n",
      "Epoch 21 tst: l 1.047 a 0.701 clct[np.int64(5), np.int64(9), np.int64(12), np.int64(14)] cl_acc 0.700  11.157sec\n",
      "Epoch 22 tr: l 0.713 a 0.788 clct[np.int64(9), np.int64(36), np.int64(78), np.int64(77)] cl_acc 0.585  lr 0.089559 31.049sec(train) 11.677sec(infer)\n",
      "Epoch 22 tst: l 1.034 a 0.703 clct[np.int64(5), np.int64(9), np.int64(11), np.int64(15)] cl_acc 0.650  9.670sec\n",
      "Epoch 23 tr: l 0.686 a 0.794 clct[np.int64(9), np.int64(37), np.int64(78), np.int64(76)] cl_acc 0.590  lr 0.089111 32.478sec(train) 10.408sec(infer)\n",
      "Epoch 23 tst: l 0.998 a 0.711 clct[np.int64(5), np.int64(11), np.int64(11), np.int64(13)] cl_acc 0.700  11.316sec\n",
      "Epoch 24 tr: l 0.686 a 0.794 clct[np.int64(9), np.int64(37), np.int64(78), np.int64(76)] cl_acc 0.590  lr 0.088665 30.820sec(train) 11.910sec(infer)\n",
      "Epoch 24 tst: l 0.980 a 0.717 clct[np.int64(5), np.int64(11), np.int64(11), np.int64(13)] cl_acc 0.700  10.843sec\n",
      "Epoch 25 tr: l 0.661 a 0.801 clct[np.int64(9), np.int64(38), np.int64(78), np.int64(75)] cl_acc 0.595  lr 0.088222 31.118sec(train) 10.936sec(infer)\n",
      "Epoch 25 tst: l 0.963 a 0.718 clct[np.int64(4), np.int64(9), np.int64(13), np.int64(14)] cl_acc 0.675  10.239sec\n",
      "Epoch 26 tr: l 0.654 a 0.800 clct[np.int64(10), np.int64(41), np.int64(76), np.int64(73)] cl_acc 0.605  lr 0.087781 32.088sec(train) 10.125sec(infer)\n",
      "Epoch 26 tst: l 0.958 a 0.722 clct[np.int64(5), np.int64(10), np.int64(11), np.int64(14)] cl_acc 0.675  10.457sec\n",
      "Epoch 27 tr: l 0.631 a 0.808 clct[np.int64(11), np.int64(41), np.int64(75), np.int64(73)] cl_acc 0.620  lr 0.087342 31.227sec(train) 11.929sec(infer)\n",
      "Epoch 27 tst: l 0.944 a 0.724 clct[np.int64(5), np.int64(9), np.int64(11), np.int64(15)] cl_acc 0.650  11.242sec\n",
      "Epoch 28 tr: l 0.622 a 0.809 clct[np.int64(12), np.int64(41), np.int64(75), np.int64(72)] cl_acc 0.635  lr 0.086905 30.490sec(train) 12.209sec(infer)\n",
      "Epoch 28 tst: l 0.917 a 0.731 clct[np.int64(4), np.int64(11), np.int64(12), np.int64(13)] cl_acc 0.675  9.698sec\n",
      "Epoch 29 tr: l 0.602 a 0.815 clct[np.int64(12), np.int64(43), np.int64(76), np.int64(69)] cl_acc 0.655  lr 0.086471 32.345sec(train) 11.083sec(infer)\n",
      "Epoch 29 tst: l 0.901 a 0.736 clct[np.int64(5), np.int64(12), np.int64(12), np.int64(11)] cl_acc 0.775  11.192sec\n",
      "Epoch 30 tr: l 0.594 a 0.813 clct[np.int64(12), np.int64(46), np.int64(76), np.int64(66)] cl_acc 0.670  lr 0.086038 30.430sec(train) 12.400sec(infer)\n",
      "Epoch 30 tst: l 0.883 a 0.742 clct[np.int64(5), np.int64(12), np.int64(12), np.int64(11)] cl_acc 0.775  10.710sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 31 tr: l 0.569 a 0.823 clct[np.int64(13), np.int64(47), np.int64(75), np.int64(65)] cl_acc 0.680  lr 0.085608 30.897sec(train) 11.283sec(infer)\n",
      "Epoch 31 tst: l 0.871 a 0.744 clct[np.int64(5), np.int64(12), np.int64(12), np.int64(11)] cl_acc 0.775  10.400sec\n",
      "Epoch 32 tr: l 0.569 a 0.822 clct[np.int64(13), np.int64(48), np.int64(76), np.int64(63)] cl_acc 0.695  lr 0.085180 31.102sec(train) 12.072sec(infer)\n",
      "Epoch 32 tst: l 0.854 a 0.748 clct[np.int64(5), np.int64(11), np.int64(13), np.int64(11)] cl_acc 0.800  11.072sec\n",
      "Epoch 33 tr: l 0.561 a 0.826 clct[np.int64(15), np.int64(51), np.int64(74), np.int64(60)] cl_acc 0.720  lr 0.084754 29.968sec(train) 12.408sec(infer)\n",
      "Epoch 33 tst: l 0.839 a 0.752 clct[np.int64(6), np.int64(11), np.int64(12), np.int64(11)] cl_acc 0.825  9.805sec\n",
      "Epoch 34 tr: l 0.531 a 0.832 clct[np.int64(16), np.int64(52), np.int64(73), np.int64(59)] cl_acc 0.730  lr 0.084331 31.932sec(train) 10.792sec(infer)\n",
      "Epoch 34 tst: l 0.821 a 0.756 clct[np.int64(5), np.int64(12), np.int64(13), np.int64(10)] cl_acc 0.825  11.340sec\n",
      "Epoch 35 tr: l 0.541 a 0.830 clct[np.int64(18), np.int64(53), np.int64(73), np.int64(56)] cl_acc 0.765  lr 0.083909 30.185sec(train) 12.449sec(infer)\n",
      "Epoch 35 tst: l 0.805 a 0.761 clct[np.int64(6), np.int64(12), np.int64(12), np.int64(10)] cl_acc 0.850  11.112sec\n",
      "Epoch 36 tr: l 0.513 a 0.837 clct[np.int64(21), np.int64(55), np.int64(70), np.int64(54)] cl_acc 0.790  lr 0.083489 30.236sec(train) 11.653sec(infer)\n",
      "Epoch 36 tst: l 0.779 a 0.767 clct[np.int64(8), np.int64(12), np.int64(10), np.int64(10)] cl_acc 0.900  10.045sec\n",
      "Epoch 37 tr: l 0.509 a 0.839 clct[np.int64(25), np.int64(54), np.int64(67), np.int64(54)] cl_acc 0.815  lr 0.083072 31.756sec(train) 11.857sec(infer)\n",
      "Epoch 37 tst: l 0.759 a 0.770 clct[np.int64(9), np.int64(11), np.int64(10), np.int64(10)] cl_acc 0.950  11.288sec\n",
      "Epoch 38 tr: l 0.483 a 0.845 clct[np.int64(25), np.int64(56), np.int64(67), np.int64(52)] cl_acc 0.825  lr 0.082657 30.469sec(train) 12.461sec(infer)\n",
      "Epoch 38 tst: l 0.734 a 0.776 clct[np.int64(9), np.int64(12), np.int64(9), np.int64(10)] cl_acc 0.925  10.119sec\n",
      "Epoch 39 tr: l 0.477 a 0.846 clct[np.int64(28), np.int64(53), np.int64(67), np.int64(52)] cl_acc 0.855  lr 0.082243 31.373sec(train) 10.714sec(infer)\n",
      "Epoch 39 tst: l 0.713 a 0.782 clct[np.int64(9), np.int64(12), np.int64(9), np.int64(10)] cl_acc 0.925  10.957sec\n",
      "Epoch 40 tr: l 0.479 a 0.849 clct[np.int64(30), np.int64(53), np.int64(65), np.int64(52)] cl_acc 0.865  lr 0.081832 31.812sec(train) 12.477sec(infer)\n",
      "Epoch 40 tst: l 0.699 a 0.785 clct[np.int64(10), np.int64(11), np.int64(9), np.int64(10)] cl_acc 0.975  11.181sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 41 tr: l 0.446 a 0.855 clct[np.int64(33), np.int64(52), np.int64(63), np.int64(52)] cl_acc 0.885  lr 0.081423 30.529sec(train) 11.705sec(infer)\n",
      "Epoch 41 tst: l 0.674 a 0.791 clct[np.int64(10), np.int64(12), np.int64(8), np.int64(10)] cl_acc 0.950  10.013sec\n",
      "Epoch 42 tr: l 0.451 a 0.856 clct[np.int64(39), np.int64(52), np.int64(57), np.int64(52)] cl_acc 0.915  lr 0.081016 31.662sec(train) 11.729sec(infer)\n",
      "Epoch 42 tst: l 0.673 a 0.790 clct[np.int64(10), np.int64(11), np.int64(9), np.int64(10)] cl_acc 0.975  11.196sec\n",
      "Epoch 43 tr: l 0.430 a 0.859 clct[np.int64(43), np.int64(51), np.int64(54), np.int64(52)] cl_acc 0.940  lr 0.080611 30.669sec(train) 12.511sec(infer)\n",
      "Epoch 43 tst: l 0.649 a 0.797 clct[np.int64(10), np.int64(12), np.int64(8), np.int64(10)] cl_acc 0.950  10.082sec\n",
      "Epoch 44 tr: l 0.419 a 0.861 clct[np.int64(43), np.int64(50), np.int64(55), np.int64(52)] cl_acc 0.945  lr 0.080208 31.388sec(train) 10.762sec(infer)\n",
      "Epoch 44 tst: l 0.630 a 0.805 clct[np.int64(10), np.int64(11), np.int64(9), np.int64(10)] cl_acc 0.975  11.034sec\n",
      "Epoch 45 tr: l 0.407 a 0.865 clct[np.int64(45), np.int64(50), np.int64(53), np.int64(52)] cl_acc 0.955  lr 0.079807 30.728sec(train) 12.456sec(infer)\n",
      "Epoch 45 tst: l 0.617 a 0.808 clct[np.int64(10), np.int64(11), np.int64(9), np.int64(10)] cl_acc 0.975  11.094sec\n",
      "Epoch 46 tr: l 0.396 a 0.867 clct[np.int64(46), np.int64(50), np.int64(52), np.int64(52)] cl_acc 0.960  lr 0.079408 30.146sec(train) 12.056sec(infer)\n",
      "Epoch 46 tst: l 0.613 a 0.808 clct[np.int64(10), np.int64(11), np.int64(9), np.int64(10)] cl_acc 0.975  9.685sec\n",
      "Epoch 47 tr: l 0.395 a 0.868 clct[np.int64(46), np.int64(50), np.int64(52), np.int64(52)] cl_acc 0.960  lr 0.079010 32.105sec(train) 11.473sec(infer)\n",
      "Epoch 47 tst: l 0.603 a 0.810 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.237sec\n",
      "Epoch 48 tr: l 0.390 a 0.870 clct[np.int64(46), np.int64(50), np.int64(52), np.int64(52)] cl_acc 0.960  lr 0.078615 30.507sec(train) 12.525sec(infer)\n",
      "Epoch 48 tst: l 0.591 a 0.814 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.457sec\n",
      "Epoch 49 tr: l 0.390 a 0.870 clct[np.int64(47), np.int64(50), np.int64(51), np.int64(52)] cl_acc 0.965  lr 0.078222 31.145sec(train) 11.066sec(infer)\n",
      "Epoch 49 tst: l 0.585 a 0.816 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.723sec\n",
      "Epoch 50 tr: l 0.379 a 0.871 clct[np.int64(48), np.int64(50), np.int64(50), np.int64(52)] cl_acc 0.970  lr 0.077831 30.919sec(train) 12.373sec(infer)\n",
      "Epoch 50 tst: l 0.575 a 0.818 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.223sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 51 tr: l 0.377 a 0.873 clct[np.int64(48), np.int64(49), np.int64(51), np.int64(52)] cl_acc 0.975  lr 0.077442 30.288sec(train) 12.348sec(infer)\n",
      "Epoch 51 tst: l 0.569 a 0.820 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.618sec\n",
      "Epoch 52 tr: l 0.367 a 0.874 clct[np.int64(48), np.int64(49), np.int64(51), np.int64(52)] cl_acc 0.975  lr 0.077055 31.972sec(train) 11.321sec(infer)\n",
      "Epoch 52 tst: l 0.567 a 0.820 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.295sec\n",
      "Epoch 53 tr: l 0.367 a 0.874 clct[np.int64(48), np.int64(49), np.int64(51), np.int64(52)] cl_acc 0.975  lr 0.076670 30.408sec(train) 12.441sec(infer)\n",
      "Epoch 53 tst: l 0.560 a 0.822 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.579sec\n",
      "Epoch 54 tr: l 0.360 a 0.876 clct[np.int64(48), np.int64(48), np.int64(52), np.int64(52)] cl_acc 0.980  lr 0.076286 30.268sec(train) 11.296sec(infer)\n",
      "Epoch 54 tst: l 0.552 a 0.823 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.324sec\n",
      "Epoch 55 tr: l 0.357 a 0.878 clct[np.int64(48), np.int64(48), np.int64(52), np.int64(52)] cl_acc 0.980  lr 0.075905 30.877sec(train) 12.090sec(infer)\n",
      "Epoch 55 tst: l 0.549 a 0.824 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.099sec\n",
      "Epoch 56 tr: l 0.354 a 0.879 clct[np.int64(48), np.int64(48), np.int64(52), np.int64(52)] cl_acc 0.980  lr 0.075525 30.077sec(train) 12.460sec(infer)\n",
      "Epoch 56 tst: l 0.542 a 0.826 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.585sec\n",
      "Epoch 57 tr: l 0.351 a 0.879 clct[np.int64(48), np.int64(48), np.int64(52), np.int64(52)] cl_acc 0.980  lr 0.075148 31.604sec(train) 10.991sec(infer)\n",
      "Epoch 57 tst: l 0.540 a 0.827 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.283sec\n",
      "Epoch 58 tr: l 0.344 a 0.881 clct[np.int64(48), np.int64(48), np.int64(52), np.int64(52)] cl_acc 0.980  lr 0.074772 30.599sec(train) 12.501sec(infer)\n",
      "Epoch 58 tst: l 0.535 a 0.827 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.025sec\n",
      "Epoch 59 tr: l 0.341 a 0.881 clct[np.int64(48), np.int64(48), np.int64(52), np.int64(52)] cl_acc 0.980  lr 0.074398 30.722sec(train) 11.520sec(infer)\n",
      "Epoch 59 tst: l 0.533 a 0.828 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.202sec\n",
      "Epoch 60 tr: l 0.339 a 0.882 clct[np.int64(48), np.int64(48), np.int64(52), np.int64(52)] cl_acc 0.980  lr 0.074026 31.540sec(train) 12.049sec(infer)\n",
      "Epoch 60 tst: l 0.528 a 0.829 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.434sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 61 tr: l 0.331 a 0.885 clct[np.int64(48), np.int64(48), np.int64(52), np.int64(52)] cl_acc 0.980  lr 0.073656 30.859sec(train) 12.595sec(infer)\n",
      "Epoch 61 tst: l 0.526 a 0.829 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.972sec\n",
      "Epoch 62 tr: l 0.329 a 0.885 clct[np.int64(48), np.int64(48), np.int64(52), np.int64(52)] cl_acc 0.980  lr 0.073288 31.914sec(train) 10.963sec(infer)\n",
      "Epoch 62 tst: l 0.521 a 0.830 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.376sec\n",
      "Epoch 63 tr: l 0.325 a 0.887 clct[np.int64(49), np.int64(48), np.int64(51), np.int64(52)] cl_acc 0.985  lr 0.072921 30.548sec(train) 12.516sec(infer)\n",
      "Epoch 63 tst: l 0.520 a 0.831 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.072sec\n",
      "Epoch 64 tr: l 0.324 a 0.887 clct[np.int64(49), np.int64(48), np.int64(51), np.int64(52)] cl_acc 0.985  lr 0.072557 30.645sec(train) 11.762sec(infer)\n",
      "Epoch 64 tst: l 0.517 a 0.832 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.120sec\n",
      "Epoch 65 tr: l 0.321 a 0.888 clct[np.int64(49), np.int64(48), np.int64(51), np.int64(52)] cl_acc 0.985  lr 0.072194 31.801sec(train) 11.818sec(infer)\n",
      "Epoch 65 tst: l 0.515 a 0.832 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.206sec\n",
      "Epoch 66 tr: l 0.318 a 0.890 clct[np.int64(49), np.int64(48), np.int64(51), np.int64(52)] cl_acc 0.985  lr 0.071833 30.639sec(train) 12.363sec(infer)\n",
      "Epoch 66 tst: l 0.510 a 0.833 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.130sec\n",
      "Epoch 67 tr: l 0.318 a 0.888 clct[np.int64(49), np.int64(48), np.int64(51), np.int64(52)] cl_acc 0.985  lr 0.071474 31.406sec(train) 10.830sec(infer)\n",
      "Epoch 67 tst: l 0.510 a 0.833 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.066sec\n",
      "Epoch 68 tr: l 0.316 a 0.889 clct[np.int64(49), np.int64(48), np.int64(51), np.int64(52)] cl_acc 0.985  lr 0.071116 30.929sec(train) 12.581sec(infer)\n",
      "Epoch 68 tst: l 0.507 a 0.834 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.290sec\n",
      "Epoch 69 tr: l 0.311 a 0.890 clct[np.int64(49), np.int64(48), np.int64(51), np.int64(52)] cl_acc 0.985  lr 0.070761 30.918sec(train) 12.024sec(infer)\n",
      "Epoch 69 tst: l 0.506 a 0.835 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.882sec\n",
      "Epoch 70 tr: l 0.310 a 0.891 clct[np.int64(49), np.int64(48), np.int64(51), np.int64(52)] cl_acc 0.985  lr 0.070407 32.083sec(train) 11.448sec(infer)\n",
      "Epoch 70 tst: l 0.503 a 0.835 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.133sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 71 tr: l 0.309 a 0.892 clct[np.int64(49), np.int64(48), np.int64(51), np.int64(52)] cl_acc 0.985  lr 0.070055 31.178sec(train) 12.618sec(infer)\n",
      "Epoch 71 tst: l 0.503 a 0.835 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.945sec\n",
      "Epoch 72 tr: l 0.305 a 0.893 clct[np.int64(49), np.int64(48), np.int64(51), np.int64(52)] cl_acc 0.985  lr 0.069705 31.741sec(train) 11.027sec(infer)\n",
      "Epoch 72 tst: l 0.502 a 0.835 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.786sec\n",
      "Epoch 73 tr: l 0.302 a 0.893 clct[np.int64(49), np.int64(48), np.int64(51), np.int64(52)] cl_acc 0.985  lr 0.069356 31.181sec(train) 12.641sec(infer)\n",
      "Epoch 73 tst: l 0.500 a 0.836 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.835sec\n",
      "Epoch 74 tr: l 0.302 a 0.894 clct[np.int64(49), np.int64(48), np.int64(51), np.int64(52)] cl_acc 0.985  lr 0.069009 30.368sec(train) 12.095sec(infer)\n",
      "Epoch 74 tst: l 0.496 a 0.837 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.714sec\n",
      "Epoch 75 tr: l 0.299 a 0.895 clct[np.int64(49), np.int64(48), np.int64(51), np.int64(52)] cl_acc 0.985  lr 0.068664 31.927sec(train) 11.700sec(infer)\n",
      "Epoch 75 tst: l 0.495 a 0.837 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.102sec\n",
      "Epoch 76 tr: l 0.297 a 0.895 clct[np.int64(49), np.int64(48), np.int64(51), np.int64(52)] cl_acc 0.985  lr 0.068321 30.658sec(train) 12.597sec(infer)\n",
      "Epoch 76 tst: l 0.492 a 0.837 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.014sec\n",
      "Epoch 77 tr: l 0.294 a 0.896 clct[np.int64(49), np.int64(48), np.int64(51), np.int64(52)] cl_acc 0.985  lr 0.067979 30.363sec(train) 10.868sec(infer)\n",
      "Epoch 77 tst: l 0.493 a 0.838 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.984sec\n",
      "Epoch 78 tr: l 0.293 a 0.896 clct[np.int64(49), np.int64(48), np.int64(51), np.int64(52)] cl_acc 0.985  lr 0.067639 30.916sec(train) 12.829sec(infer)\n",
      "Epoch 78 tst: l 0.490 a 0.838 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.495sec\n",
      "Epoch 79 tr: l 0.293 a 0.897 clct[np.int64(49), np.int64(48), np.int64(51), np.int64(52)] cl_acc 0.985  lr 0.067301 30.229sec(train) 11.986sec(infer)\n",
      "Epoch 79 tst: l 0.491 a 0.838 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.806sec\n",
      "Epoch 80 tr: l 0.293 a 0.896 clct[np.int64(49), np.int64(48), np.int64(51), np.int64(52)] cl_acc 0.985  lr 0.066965 32.192sec(train) 11.545sec(infer)\n",
      "Epoch 80 tst: l 0.487 a 0.839 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.377sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 81 tr: l 0.287 a 0.898 clct[np.int64(49), np.int64(48), np.int64(51), np.int64(52)] cl_acc 0.985  lr 0.066630 30.406sec(train) 12.554sec(infer)\n",
      "Epoch 81 tst: l 0.487 a 0.839 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.435sec\n",
      "Epoch 82 tr: l 0.287 a 0.898 clct[np.int64(49), np.int64(48), np.int64(51), np.int64(52)] cl_acc 0.985  lr 0.066297 31.453sec(train) 10.914sec(infer)\n",
      "Epoch 82 tst: l 0.483 a 0.840 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.998sec\n",
      "Epoch 83 tr: l 0.284 a 0.900 clct[np.int64(49), np.int64(48), np.int64(51), np.int64(52)] cl_acc 0.985  lr 0.065965 30.869sec(train) 12.626sec(infer)\n",
      "Epoch 83 tst: l 0.484 a 0.840 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.455sec\n",
      "Epoch 84 tr: l 0.284 a 0.899 clct[np.int64(49), np.int64(48), np.int64(51), np.int64(52)] cl_acc 0.985  lr 0.065635 30.434sec(train) 12.204sec(infer)\n",
      "Epoch 84 tst: l 0.482 a 0.840 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.577sec\n",
      "Epoch 85 tr: l 0.281 a 0.900 clct[np.int64(49), np.int64(48), np.int64(51), np.int64(52)] cl_acc 0.985  lr 0.065307 31.998sec(train) 11.654sec(infer)\n",
      "Epoch 85 tst: l 0.483 a 0.840 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.562sec\n",
      "Epoch 86 tr: l 0.277 a 0.902 clct[np.int64(49), np.int64(48), np.int64(51), np.int64(52)] cl_acc 0.985  lr 0.064981 30.181sec(train) 12.615sec(infer)\n",
      "Epoch 86 tst: l 0.480 a 0.840 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.670sec\n",
      "Epoch 87 tr: l 0.282 a 0.900 clct[np.int64(49), np.int64(48), np.int64(51), np.int64(52)] cl_acc 0.985  lr 0.064656 30.704sec(train) 11.135sec(infer)\n",
      "Epoch 87 tst: l 0.480 a 0.841 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.708sec\n",
      "Epoch 88 tr: l 0.278 a 0.901 clct[np.int64(49), np.int64(48), np.int64(51), np.int64(52)] cl_acc 0.985  lr 0.064333 31.435sec(train) 12.564sec(infer)\n",
      "Epoch 88 tst: l 0.478 a 0.841 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.253sec\n",
      "Epoch 89 tr: l 0.275 a 0.901 clct[np.int64(49), np.int64(48), np.int64(51), np.int64(52)] cl_acc 0.985  lr 0.064011 30.428sec(train) 12.479sec(infer)\n",
      "Epoch 89 tst: l 0.477 a 0.841 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.798sec\n",
      "Epoch 90 tr: l 0.274 a 0.903 clct[np.int64(49), np.int64(48), np.int64(51), np.int64(52)] cl_acc 0.985  lr 0.063691 31.597sec(train) 11.192sec(infer)\n",
      "Epoch 90 tst: l 0.475 a 0.842 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.352sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 91 tr: l 0.274 a 0.903 clct[np.int64(49), np.int64(48), np.int64(51), np.int64(52)] cl_acc 0.985  lr 0.063372 30.745sec(train) 12.615sec(infer)\n",
      "Epoch 91 tst: l 0.475 a 0.842 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.771sec\n",
      "Epoch 92 tr: l 0.271 a 0.904 clct[np.int64(49), np.int64(48), np.int64(51), np.int64(52)] cl_acc 0.985  lr 0.063056 30.767sec(train) 11.279sec(infer)\n",
      "Epoch 92 tst: l 0.474 a 0.842 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.757sec\n",
      "Epoch 93 tr: l 0.270 a 0.904 clct[np.int64(49), np.int64(48), np.int64(51), np.int64(52)] cl_acc 0.985  lr 0.062740 31.334sec(train) 12.025sec(infer)\n",
      "Epoch 93 tst: l 0.474 a 0.842 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.394sec\n",
      "Epoch 94 tr: l 0.272 a 0.903 clct[np.int64(49), np.int64(48), np.int64(51), np.int64(52)] cl_acc 0.985  lr 0.062427 30.097sec(train) 12.591sec(infer)\n",
      "Epoch 94 tst: l 0.475 a 0.842 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.060sec\n",
      "Epoch 95 tr: l 0.269 a 0.904 clct[np.int64(49), np.int64(48), np.int64(51), np.int64(52)] cl_acc 0.985  lr 0.062114 32.215sec(train) 11.234sec(infer)\n",
      "Epoch 95 tst: l 0.472 a 0.842 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.307sec\n",
      "Epoch 96 tr: l 0.262 a 0.905 clct[np.int64(49), np.int64(48), np.int64(51), np.int64(52)] cl_acc 0.985  lr 0.061804 30.685sec(train) 12.464sec(infer)\n",
      "Epoch 96 tst: l 0.472 a 0.843 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.742sec\n",
      "Epoch 97 tr: l 0.268 a 0.904 clct[np.int64(49), np.int64(48), np.int64(51), np.int64(52)] cl_acc 0.985  lr 0.061495 31.086sec(train) 11.547sec(infer)\n",
      "Epoch 97 tst: l 0.471 a 0.843 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.268sec\n",
      "Epoch 98 tr: l 0.266 a 0.904 clct[np.int64(49), np.int64(48), np.int64(51), np.int64(52)] cl_acc 0.985  lr 0.061187 31.377sec(train) 13.264sec(infer)\n",
      "Epoch 98 tst: l 0.471 a 0.843 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.372sec\n",
      "Epoch 99 tr: l 0.260 a 0.907 clct[np.int64(49), np.int64(48), np.int64(51), np.int64(52)] cl_acc 0.985  lr 0.060881 30.806sec(train) 12.532sec(infer)\n",
      "Epoch 99 tst: l 0.470 a 0.843 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.707sec\n",
      "Epoch 100 tr: l 0.292 a 0.896 clct[np.int64(49), np.int64(48), np.int64(51), np.int64(52)] cl_acc 0.985  lr 0.006058 32.906sec(train) 12.089sec(infer)\n",
      "Epoch 100 tst: l 0.465 a 0.845 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.808sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 101 tr: l 0.307 a 0.892 clct[np.int64(49), np.int64(48), np.int64(51), np.int64(52)] cl_acc 0.985  lr 0.006027 30.585sec(train) 13.169sec(infer)\n",
      "Epoch 101 tst: l 0.464 a 0.845 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.546sec\n",
      "Epoch 102 tr: l 0.316 a 0.889 clct[np.int64(49), np.int64(48), np.int64(51), np.int64(52)] cl_acc 0.985  lr 0.005997 32.250sec(train) 11.512sec(infer)\n",
      "Epoch 102 tst: l 0.463 a 0.846 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.784sec\n",
      "Epoch 103 tr: l 0.321 a 0.888 clct[np.int64(49), np.int64(48), np.int64(51), np.int64(52)] cl_acc 0.985  lr 0.005967 31.550sec(train) 13.330sec(infer)\n",
      "Epoch 103 tst: l 0.461 a 0.846 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.211sec\n",
      "Epoch 104 tr: l 0.321 a 0.887 clct[np.int64(49), np.int64(48), np.int64(51), np.int64(52)] cl_acc 0.985  lr 0.005937 31.437sec(train) 12.058sec(infer)\n",
      "Epoch 104 tst: l 0.461 a 0.846 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.302sec\n",
      "Epoch 105 tr: l 0.323 a 0.886 clct[np.int64(49), np.int64(48), np.int64(51), np.int64(52)] cl_acc 0.985  lr 0.005908 31.944sec(train) 13.298sec(infer)\n",
      "Epoch 105 tst: l 0.461 a 0.846 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.401sec\n",
      "Epoch 106 tr: l 0.323 a 0.886 clct[np.int64(49), np.int64(48), np.int64(51), np.int64(52)] cl_acc 0.985  lr 0.005878 30.852sec(train) 12.657sec(infer)\n",
      "Epoch 106 tst: l 0.460 a 0.846 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.203sec\n",
      "Epoch 107 tr: l 0.324 a 0.886 clct[np.int64(49), np.int64(48), np.int64(51), np.int64(52)] cl_acc 0.985  lr 0.005849 31.832sec(train) 13.010sec(infer)\n",
      "Epoch 107 tst: l 0.460 a 0.847 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.869sec\n",
      "Epoch 108 tr: l 0.323 a 0.886 clct[np.int64(49), np.int64(48), np.int64(51), np.int64(52)] cl_acc 0.985  lr 0.005820 31.137sec(train) 13.187sec(infer)\n",
      "Epoch 108 tst: l 0.460 a 0.847 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.656sec\n",
      "Epoch 109 tr: l 0.325 a 0.886 clct[np.int64(49), np.int64(48), np.int64(51), np.int64(52)] cl_acc 0.985  lr 0.005790 31.985sec(train) 11.486sec(infer)\n",
      "Epoch 109 tst: l 0.460 a 0.847 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.129sec\n",
      "Epoch 110 tr: l 0.323 a 0.886 clct[np.int64(49), np.int64(48), np.int64(51), np.int64(52)] cl_acc 0.985  lr 0.005762 30.524sec(train) 13.188sec(infer)\n",
      "Epoch 110 tst: l 0.460 a 0.846 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.627sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 111 tr: l 0.324 a 0.886 clct[np.int64(49), np.int64(48), np.int64(51), np.int64(52)] cl_acc 0.985  lr 0.005733 30.851sec(train) 11.631sec(infer)\n",
      "Epoch 111 tst: l 0.459 a 0.847 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.604sec\n",
      "Epoch 112 tr: l 0.324 a 0.886 clct[np.int64(49), np.int64(48), np.int64(51), np.int64(52)] cl_acc 0.985  lr 0.005704 31.708sec(train) 13.049sec(infer)\n",
      "Epoch 112 tst: l 0.459 a 0.847 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.307sec\n",
      "Epoch 113 tr: l 0.323 a 0.886 clct[np.int64(49), np.int64(48), np.int64(51), np.int64(52)] cl_acc 0.985  lr 0.005676 29.646sec(train) 12.894sec(infer)\n",
      "Epoch 113 tst: l 0.458 a 0.847 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.096sec\n",
      "Epoch 114 tr: l 0.323 a 0.886 clct[np.int64(49), np.int64(48), np.int64(51), np.int64(52)] cl_acc 0.985  lr 0.005647 32.504sec(train) 12.055sec(infer)\n",
      "Epoch 114 tst: l 0.458 a 0.847 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.162sec\n",
      "Epoch 115 tr: l 0.325 a 0.886 clct[np.int64(49), np.int64(48), np.int64(51), np.int64(52)] cl_acc 0.985  lr 0.005619 29.529sec(train) 13.056sec(infer)\n",
      "Epoch 115 tst: l 0.458 a 0.847 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.686sec\n",
      "Epoch 116 tr: l 0.324 a 0.886 clct[np.int64(49), np.int64(48), np.int64(51), np.int64(52)] cl_acc 0.985  lr 0.005591 31.084sec(train) 11.483sec(infer)\n",
      "Epoch 116 tst: l 0.458 a 0.847 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.712sec\n",
      "Epoch 117 tr: l 0.323 a 0.886 clct[np.int64(49), np.int64(48), np.int64(51), np.int64(52)] cl_acc 0.985  lr 0.005563 30.251sec(train) 13.190sec(infer)\n",
      "Epoch 117 tst: l 0.458 a 0.847 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.588sec\n",
      "Epoch 118 tr: l 0.326 a 0.886 clct[np.int64(49), np.int64(48), np.int64(51), np.int64(52)] cl_acc 0.985  lr 0.005535 29.576sec(train) 12.012sec(infer)\n",
      "Epoch 118 tst: l 0.457 a 0.847 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.222sec\n",
      "Epoch 119 tr: l 0.324 a 0.886 clct[np.int64(49), np.int64(48), np.int64(51), np.int64(52)] cl_acc 0.985  lr 0.005507 32.760sec(train) 12.753sec(infer)\n",
      "Epoch 119 tst: l 0.457 a 0.847 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.435sec\n",
      "Epoch 120 tr: l 0.324 a 0.887 clct[np.int64(49), np.int64(49), np.int64(51), np.int64(51)] cl_acc 0.990  lr 0.005480 30.395sec(train) 13.092sec(infer)\n",
      "Epoch 120 tst: l 0.457 a 0.847 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.548sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 121 tr: l 0.323 a 0.887 clct[np.int64(49), np.int64(49), np.int64(51), np.int64(51)] cl_acc 0.990  lr 0.005452 32.590sec(train) 11.558sec(infer)\n",
      "Epoch 121 tst: l 0.457 a 0.847 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.801sec\n",
      "Epoch 122 tr: l 0.323 a 0.887 clct[np.int64(49), np.int64(49), np.int64(51), np.int64(51)] cl_acc 0.990  lr 0.005425 30.101sec(train) 13.203sec(infer)\n",
      "Epoch 122 tst: l 0.457 a 0.848 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.989sec\n",
      "Epoch 123 tr: l 0.325 a 0.886 clct[np.int64(49), np.int64(49), np.int64(51), np.int64(51)] cl_acc 0.990  lr 0.005398 30.446sec(train) 12.146sec(infer)\n",
      "Epoch 123 tst: l 0.456 a 0.848 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.157sec\n",
      "Epoch 124 tr: l 0.324 a 0.886 clct[np.int64(49), np.int64(49), np.int64(51), np.int64(51)] cl_acc 0.990  lr 0.005371 31.288sec(train) 13.128sec(infer)\n",
      "Epoch 124 tst: l 0.456 a 0.848 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.546sec\n",
      "Epoch 125 tr: l 0.323 a 0.887 clct[np.int64(49), np.int64(49), np.int64(51), np.int64(51)] cl_acc 0.990  lr 0.005344 29.435sec(train) 12.734sec(infer)\n",
      "Epoch 125 tst: l 0.455 a 0.848 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.026sec\n",
      "Epoch 126 tr: l 0.324 a 0.887 clct[np.int64(49), np.int64(49), np.int64(51), np.int64(51)] cl_acc 0.990  lr 0.005318 32.147sec(train) 12.177sec(infer)\n",
      "Epoch 126 tst: l 0.455 a 0.848 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.281sec\n",
      "Epoch 127 tr: l 0.323 a 0.887 clct[np.int64(49), np.int64(49), np.int64(51), np.int64(51)] cl_acc 0.990  lr 0.005291 29.739sec(train) 13.039sec(infer)\n",
      "Epoch 127 tst: l 0.456 a 0.847 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.461sec\n",
      "Epoch 128 tr: l 0.323 a 0.887 clct[np.int64(49), np.int64(49), np.int64(51), np.int64(51)] cl_acc 0.990  lr 0.005264 31.319sec(train) 11.547sec(infer)\n",
      "Epoch 128 tst: l 0.455 a 0.847 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.849sec\n",
      "Epoch 129 tr: l 0.322 a 0.887 clct[np.int64(49), np.int64(49), np.int64(51), np.int64(51)] cl_acc 0.990  lr 0.005238 31.118sec(train) 13.476sec(infer)\n",
      "Epoch 129 tst: l 0.455 a 0.848 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.242sec\n",
      "Epoch 130 tr: l 0.324 a 0.886 clct[np.int64(49), np.int64(49), np.int64(51), np.int64(51)] cl_acc 0.990  lr 0.005212 29.886sec(train) 12.431sec(infer)\n",
      "Epoch 130 tst: l 0.455 a 0.848 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.102sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 131 tr: l 0.322 a 0.887 clct[np.int64(49), np.int64(49), np.int64(51), np.int64(51)] cl_acc 0.990  lr 0.005186 32.256sec(train) 12.769sec(infer)\n",
      "Epoch 131 tst: l 0.455 a 0.848 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.938sec\n",
      "Epoch 132 tr: l 0.322 a 0.887 clct[np.int64(49), np.int64(49), np.int64(51), np.int64(51)] cl_acc 0.990  lr 0.005160 29.529sec(train) 13.089sec(infer)\n",
      "Epoch 132 tst: l 0.455 a 0.848 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.968sec\n",
      "Epoch 133 tr: l 0.322 a 0.887 clct[np.int64(49), np.int64(49), np.int64(51), np.int64(51)] cl_acc 0.990  lr 0.005134 30.827sec(train) 11.419sec(infer)\n",
      "Epoch 133 tst: l 0.455 a 0.848 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.920sec\n",
      "Epoch 134 tr: l 0.322 a 0.887 clct[np.int64(49), np.int64(49), np.int64(51), np.int64(51)] cl_acc 0.990  lr 0.005108 31.497sec(train) 11.176sec(infer)\n",
      "Epoch 134 tst: l 0.455 a 0.848 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.770sec\n",
      "Epoch 135 tr: l 0.322 a 0.887 clct[np.int64(49), np.int64(49), np.int64(51), np.int64(51)] cl_acc 0.990  lr 0.005083 30.577sec(train) 13.100sec(infer)\n",
      "Epoch 135 tst: l 0.454 a 0.848 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.149sec\n",
      "Epoch 136 tr: l 0.324 a 0.887 clct[np.int64(49), np.int64(49), np.int64(51), np.int64(51)] cl_acc 0.990  lr 0.005058 30.630sec(train) 12.199sec(infer)\n",
      "Epoch 136 tst: l 0.454 a 0.848 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.756sec\n",
      "Epoch 137 tr: l 0.321 a 0.887 clct[np.int64(49), np.int64(49), np.int64(51), np.int64(51)] cl_acc 0.990  lr 0.005032 31.183sec(train) 13.193sec(infer)\n",
      "Epoch 137 tst: l 0.454 a 0.848 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.185sec\n",
      "Epoch 138 tr: l 0.321 a 0.887 clct[np.int64(49), np.int64(49), np.int64(51), np.int64(51)] cl_acc 0.990  lr 0.005007 29.509sec(train) 13.152sec(infer)\n",
      "Epoch 138 tst: l 0.454 a 0.848 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.124sec\n",
      "Epoch 139 tr: l 0.319 a 0.887 clct[np.int64(49), np.int64(49), np.int64(51), np.int64(51)] cl_acc 0.990  lr 0.004982 33.110sec(train) 12.513sec(infer)\n",
      "Epoch 139 tst: l 0.454 a 0.848 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.019sec\n",
      "Epoch 140 tr: l 0.322 a 0.887 clct[np.int64(49), np.int64(49), np.int64(51), np.int64(51)] cl_acc 0.990  lr 0.004957 31.236sec(train) 13.338sec(infer)\n",
      "Epoch 140 tst: l 0.454 a 0.848 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.285sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 141 tr: l 0.321 a 0.887 clct[np.int64(49), np.int64(49), np.int64(51), np.int64(51)] cl_acc 0.990  lr 0.004932 32.957sec(train) 10.871sec(infer)\n",
      "Epoch 141 tst: l 0.453 a 0.848 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.827sec\n",
      "Epoch 142 tr: l 0.321 a 0.887 clct[np.int64(49), np.int64(49), np.int64(51), np.int64(51)] cl_acc 0.990  lr 0.004908 30.381sec(train) 13.403sec(infer)\n",
      "Epoch 142 tst: l 0.453 a 0.848 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.473sec\n",
      "Epoch 143 tr: l 0.321 a 0.887 clct[np.int64(49), np.int64(49), np.int64(51), np.int64(51)] cl_acc 0.990  lr 0.004883 30.356sec(train) 12.126sec(infer)\n",
      "Epoch 143 tst: l 0.453 a 0.848 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.064sec\n",
      "Epoch 144 tr: l 0.320 a 0.887 clct[np.int64(49), np.int64(49), np.int64(51), np.int64(51)] cl_acc 0.990  lr 0.004859 31.268sec(train) 12.354sec(infer)\n",
      "Epoch 144 tst: l 0.453 a 0.848 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.707sec\n",
      "Epoch 145 tr: l 0.321 a 0.887 clct[np.int64(49), np.int64(49), np.int64(51), np.int64(51)] cl_acc 0.990  lr 0.004834 29.561sec(train) 13.109sec(infer)\n",
      "Epoch 145 tst: l 0.453 a 0.848 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.301sec\n",
      "Epoch 146 tr: l 0.321 a 0.887 clct[np.int64(49), np.int64(49), np.int64(51), np.int64(51)] cl_acc 0.990  lr 0.004810 31.820sec(train) 11.488sec(infer)\n",
      "Epoch 146 tst: l 0.453 a 0.848 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.531sec\n",
      "Epoch 147 tr: l 0.321 a 0.887 clct[np.int64(49), np.int64(49), np.int64(51), np.int64(51)] cl_acc 0.990  lr 0.004786 30.600sec(train) 13.049sec(infer)\n",
      "Epoch 147 tst: l 0.453 a 0.848 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.137sec\n",
      "Epoch 148 tr: l 0.321 a 0.887 clct[np.int64(49), np.int64(49), np.int64(51), np.int64(51)] cl_acc 0.990  lr 0.004762 30.260sec(train) 11.391sec(infer)\n",
      "Epoch 148 tst: l 0.453 a 0.849 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.785sec\n",
      "Epoch 149 tr: l 0.321 a 0.887 clct[np.int64(49), np.int64(49), np.int64(51), np.int64(51)] cl_acc 0.990  lr 0.004738 31.749sec(train) 12.822sec(infer)\n",
      "Epoch 149 tst: l 0.453 a 0.849 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.592sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "---train cluster Ended in 2.24 hour (8073.808 sec) \n",
      "---------------------------------DFCA-GI, lr: 0.1, seed: 4012---------------------------------\n",
      "config: {'m': 200, 'm_test': 40, 'p': 4, 'n': 1500, 'uneven': True, 'local_model_init': False, 'Gp': 0.15, 'graph': 'er', 'agg': 'seq', '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:2\n",
      "Epoch -1 tr: l 3.851 a 0.029 clct[np.int64(12), np.int64(13), np.int64(162), np.int64(13)] cl_acc 0.365  9.329sec\n",
      "Epoch -1 tst: l 3.853 a 0.031 clct[np.int64(4), np.int64(4), np.int64(30), np.int64(2)] cl_acc 0.450  9.869sec\n",
      "Epoch 0 tr: l 3.314 a 0.207 clct[np.int64(15), np.int64(14), np.int64(158), np.int64(13)] cl_acc 0.385  lr 0.100000 34.311sec(train) 10.669sec(infer)\n",
      "Epoch 0 tst: l 3.550 a 0.151 clct[np.int64(5), np.int64(3), np.int64(30), np.int64(2)] cl_acc 0.475  9.074sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 1 tr: l 2.863 a 0.324 clct[np.int64(23), np.int64(19), np.int64(144), np.int64(14)] cl_acc 0.455  lr 0.099500 34.788sec(train) 9.017sec(infer)\n",
      "Epoch 1 tst: l 3.189 a 0.269 clct[np.int64(7), np.int64(4), np.int64(27), np.int64(2)] cl_acc 0.500  9.032sec\n",
      "Epoch 2 tr: l 2.430 a 0.428 clct[np.int64(38), np.int64(28), np.int64(118), np.int64(16)] cl_acc 0.585  lr 0.099003 34.964sec(train) 10.876sec(infer)\n",
      "Epoch 2 tst: l 2.815 a 0.382 clct[np.int64(7), np.int64(5), np.int64(26), np.int64(2)] cl_acc 0.575  9.494sec\n",
      "Epoch 3 tr: l 1.960 a 0.542 clct[np.int64(48), np.int64(41), np.int64(89), np.int64(22)] cl_acc 0.730  lr 0.098507 26.834sec(train) 7.440sec(infer)\n",
      "Epoch 3 tst: l 2.400 a 0.487 clct[np.int64(9), np.int64(8), np.int64(21), np.int64(2)] cl_acc 0.725  5.792sec\n",
      "Epoch 4 tr: l 1.594 a 0.628 clct[np.int64(51), np.int64(47), np.int64(76), np.int64(26)] cl_acc 0.815  lr 0.098015 27.629sec(train) 10.672sec(infer)\n",
      "Epoch 4 tst: l 2.010 a 0.567 clct[np.int64(10), np.int64(10), np.int64(17), np.int64(3)] cl_acc 0.825  9.627sec\n",
      "Epoch 5 tr: l 1.330 a 0.672 clct[np.int64(51), np.int64(50), np.int64(66), np.int64(33)] cl_acc 0.875  lr 0.097525 35.704sec(train) 10.493sec(infer)\n",
      "Epoch 5 tst: l 1.715 a 0.614 clct[np.int64(10), np.int64(10), np.int64(14), np.int64(6)] cl_acc 0.900  8.179sec\n",
      "Epoch 6 tr: l 1.139 a 0.703 clct[np.int64(50), np.int64(48), np.int64(61), np.int64(41)] cl_acc 0.930  lr 0.097037 36.971sec(train) 10.741sec(infer)\n",
      "Epoch 6 tst: l 1.482 a 0.654 clct[np.int64(10), np.int64(10), np.int64(11), np.int64(9)] cl_acc 0.975  9.789sec\n",
      "Epoch 7 tr: l 0.992 a 0.729 clct[np.int64(50), np.int64(48), np.int64(56), np.int64(46)] cl_acc 0.955  lr 0.096552 35.024sec(train) 10.425sec(infer)\n",
      "Epoch 7 tst: l 1.288 a 0.685 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  8.602sec\n",
      "Epoch 8 tr: l 0.876 a 0.754 clct[np.int64(50), np.int64(48), np.int64(52), np.int64(50)] cl_acc 0.975  lr 0.096069 37.739sec(train) 10.519sec(infer)\n",
      "Epoch 8 tst: l 1.152 a 0.707 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.262sec\n",
      "Epoch 9 tr: l 0.806 a 0.770 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 0.990  lr 0.095589 35.815sec(train) 10.623sec(infer)\n",
      "Epoch 9 tst: l 1.047 a 0.726 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  8.173sec\n",
      "Epoch 10 tr: l 0.739 a 0.782 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 0.990  lr 0.095111 37.092sec(train) 10.600sec(infer)\n",
      "Epoch 10 tst: l 0.962 a 0.740 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.876sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 11 tr: l 0.689 a 0.792 clct[np.int64(50), np.int64(50), np.int64(49), np.int64(51)] cl_acc 0.995  lr 0.094635 35.534sec(train) 10.869sec(infer)\n",
      "Epoch 11 tst: l 0.906 a 0.749 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  8.309sec\n",
      "Epoch 12 tr: l 0.652 a 0.799 clct[np.int64(50), np.int64(50), np.int64(49), np.int64(51)] cl_acc 0.995  lr 0.094162 36.048sec(train) 10.246sec(infer)\n",
      "Epoch 12 tst: l 0.856 a 0.758 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.717sec\n",
      "Epoch 13 tr: l 0.626 a 0.808 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.093691 34.651sec(train) 11.313sec(infer)\n",
      "Epoch 13 tst: l 0.817 a 0.766 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  8.094sec\n",
      "Epoch 14 tr: l 0.601 a 0.812 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.093223 36.603sec(train) 9.692sec(infer)\n",
      "Epoch 14 tst: l 0.785 a 0.772 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.258sec\n",
      "Epoch 15 tr: l 0.578 a 0.818 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.092757 34.108sec(train) 10.933sec(infer)\n",
      "Epoch 15 tst: l 0.757 a 0.778 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.139sec\n",
      "Epoch 16 tr: l 0.563 a 0.821 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.092293 36.092sec(train) 9.392sec(infer)\n",
      "Epoch 16 tst: l 0.731 a 0.783 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.375sec\n",
      "Epoch 17 tr: l 0.544 a 0.827 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.091832 35.021sec(train) 10.985sec(infer)\n",
      "Epoch 17 tst: l 0.712 a 0.788 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.772sec\n",
      "Epoch 18 tr: l 0.522 a 0.830 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.091372 35.078sec(train) 9.441sec(infer)\n",
      "Epoch 18 tst: l 0.693 a 0.792 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.609sec\n",
      "Epoch 19 tr: l 0.520 a 0.833 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.090916 35.619sec(train) 11.122sec(infer)\n",
      "Epoch 19 tst: l 0.681 a 0.795 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.965sec\n",
      "Epoch 20 tr: l 0.497 a 0.837 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.090461 35.018sec(train) 9.886sec(infer)\n",
      "Epoch 20 tst: l 0.665 a 0.798 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.291sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 21 tr: l 0.483 a 0.842 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.090009 36.444sec(train) 10.861sec(infer)\n",
      "Epoch 21 tst: l 0.652 a 0.802 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.074sec\n",
      "Epoch 22 tr: l 0.475 a 0.844 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.089559 34.533sec(train) 9.971sec(infer)\n",
      "Epoch 22 tst: l 0.639 a 0.804 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.286sec\n",
      "Epoch 23 tr: l 0.467 a 0.846 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.089111 36.309sec(train) 10.734sec(infer)\n",
      "Epoch 23 tst: l 0.630 a 0.807 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.048sec\n",
      "Epoch 24 tr: l 0.450 a 0.848 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.088665 34.876sec(train) 10.337sec(infer)\n",
      "Epoch 24 tst: l 0.619 a 0.809 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.173sec\n",
      "Epoch 25 tr: l 0.447 a 0.851 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.088222 36.082sec(train) 10.960sec(infer)\n",
      "Epoch 25 tst: l 0.611 a 0.811 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.353sec\n",
      "Epoch 26 tr: l 0.438 a 0.853 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.087781 33.940sec(train) 10.758sec(infer)\n",
      "Epoch 26 tst: l 0.604 a 0.813 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.128sec\n",
      "Epoch 27 tr: l 0.432 a 0.855 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.087342 35.736sec(train) 10.958sec(infer)\n",
      "Epoch 27 tst: l 0.598 a 0.814 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.353sec\n",
      "Epoch 28 tr: l 0.421 a 0.857 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.086905 32.858sec(train) 11.193sec(infer)\n",
      "Epoch 28 tst: l 0.589 a 0.816 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.851sec\n",
      "Epoch 29 tr: l 0.418 a 0.859 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.086471 34.857sec(train) 10.264sec(infer)\n",
      "Epoch 29 tst: l 0.582 a 0.818 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.977sec\n",
      "Epoch 30 tr: l 0.410 a 0.860 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.086038 32.677sec(train) 11.960sec(infer)\n",
      "Epoch 30 tst: l 0.574 a 0.820 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.504sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 31 tr: l 0.404 a 0.863 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.085608 33.496sec(train) 10.021sec(infer)\n",
      "Epoch 31 tst: l 0.570 a 0.821 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.468sec\n",
      "Epoch 32 tr: l 0.399 a 0.864 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.085180 33.116sec(train) 11.966sec(infer)\n",
      "Epoch 32 tst: l 0.565 a 0.821 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.304sec\n",
      "Epoch 33 tr: l 0.398 a 0.866 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.084754 32.034sec(train) 11.357sec(infer)\n",
      "Epoch 33 tst: l 0.560 a 0.823 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.897sec\n",
      "Epoch 34 tr: l 0.390 a 0.867 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.084331 33.049sec(train) 11.682sec(infer)\n",
      "Epoch 34 tst: l 0.554 a 0.824 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.768sec\n",
      "Epoch 35 tr: l 0.380 a 0.870 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.083909 30.994sec(train) 12.223sec(infer)\n",
      "Epoch 35 tst: l 0.551 a 0.825 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.740sec\n",
      "Epoch 36 tr: l 0.380 a 0.869 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.083489 33.456sec(train) 10.495sec(infer)\n",
      "Epoch 36 tst: l 0.546 a 0.826 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.160sec\n",
      "Epoch 37 tr: l 0.375 a 0.872 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.083072 32.359sec(train) 12.602sec(infer)\n",
      "Epoch 37 tst: l 0.543 a 0.827 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.529sec\n",
      "Epoch 38 tr: l 0.371 a 0.872 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.082657 32.036sec(train) 11.412sec(infer)\n",
      "Epoch 38 tst: l 0.538 a 0.828 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.435sec\n",
      "Epoch 39 tr: l 0.366 a 0.873 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.082243 32.016sec(train) 12.213sec(infer)\n",
      "Epoch 39 tst: l 0.536 a 0.829 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.815sec\n",
      "Epoch 40 tr: l 0.363 a 0.874 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.081832 31.211sec(train) 12.642sec(infer)\n",
      "Epoch 40 tst: l 0.531 a 0.830 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.304sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 41 tr: l 0.361 a 0.875 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.081423 33.036sec(train) 11.122sec(infer)\n",
      "Epoch 41 tst: l 0.529 a 0.831 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.926sec\n",
      "Epoch 42 tr: l 0.357 a 0.876 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.081016 30.346sec(train) 12.899sec(infer)\n",
      "Epoch 42 tst: l 0.525 a 0.831 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.775sec\n",
      "Epoch 43 tr: l 0.354 a 0.878 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.080611 31.230sec(train) 11.779sec(infer)\n",
      "Epoch 43 tst: l 0.523 a 0.832 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.277sec\n",
      "Epoch 44 tr: l 0.351 a 0.878 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.080208 32.898sec(train) 12.802sec(infer)\n",
      "Epoch 44 tst: l 0.519 a 0.833 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.373sec\n",
      "Epoch 45 tr: l 0.345 a 0.879 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.079807 29.781sec(train) 12.842sec(infer)\n",
      "Epoch 45 tst: l 0.519 a 0.833 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.560sec\n",
      "Epoch 46 tr: l 0.343 a 0.880 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.079408 32.448sec(train) 11.531sec(infer)\n",
      "Epoch 46 tst: l 0.514 a 0.834 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.027sec\n",
      "Epoch 47 tr: l 0.342 a 0.880 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.079010 31.334sec(train) 13.175sec(infer)\n",
      "Epoch 47 tst: l 0.513 a 0.834 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.384sec\n",
      "Epoch 48 tr: l 0.339 a 0.881 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.078615 30.628sec(train) 12.240sec(infer)\n",
      "Epoch 48 tst: l 0.509 a 0.835 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.047sec\n",
      "Epoch 49 tr: l 0.337 a 0.882 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.078222 32.155sec(train) 12.803sec(infer)\n",
      "Epoch 49 tst: l 0.508 a 0.836 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.329sec\n",
      "Epoch 50 tr: l 0.332 a 0.883 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.077831 30.743sec(train) 13.065sec(infer)\n",
      "Epoch 50 tst: l 0.505 a 0.836 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.207sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 51 tr: l 0.327 a 0.884 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.077442 31.965sec(train) 11.322sec(infer)\n",
      "Epoch 51 tst: l 0.503 a 0.837 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.727sec\n",
      "Epoch 52 tr: l 0.326 a 0.885 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.077055 30.271sec(train) 12.854sec(infer)\n",
      "Epoch 52 tst: l 0.500 a 0.837 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.775sec\n",
      "Epoch 53 tr: l 0.325 a 0.885 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.076670 30.404sec(train) 12.065sec(infer)\n",
      "Epoch 53 tst: l 0.498 a 0.839 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.870sec\n",
      "Epoch 54 tr: l 0.321 a 0.886 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.076286 31.649sec(train) 12.385sec(infer)\n",
      "Epoch 54 tst: l 0.497 a 0.838 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.812sec\n",
      "Epoch 55 tr: l 0.321 a 0.886 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.075905 30.569sec(train) 13.122sec(infer)\n",
      "Epoch 55 tst: l 0.495 a 0.839 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.766sec\n",
      "Epoch 56 tr: l 0.320 a 0.887 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.075525 31.209sec(train) 10.963sec(infer)\n",
      "Epoch 56 tst: l 0.493 a 0.839 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.004sec\n",
      "Epoch 57 tr: l 0.318 a 0.887 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.075148 30.648sec(train) 12.843sec(infer)\n",
      "Epoch 57 tst: l 0.492 a 0.840 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.131sec\n",
      "Epoch 58 tr: l 0.314 a 0.888 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.074772 29.851sec(train) 12.484sec(infer)\n",
      "Epoch 58 tst: l 0.489 a 0.841 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.729sec\n",
      "Epoch 59 tr: l 0.316 a 0.889 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.074398 32.899sec(train) 11.979sec(infer)\n",
      "Epoch 59 tst: l 0.488 a 0.842 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.975sec\n",
      "Epoch 60 tr: l 0.310 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.074026 30.683sec(train) 13.095sec(infer)\n",
      "Epoch 60 tst: l 0.487 a 0.841 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.247sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 61 tr: l 0.310 a 0.889 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.073656 31.978sec(train) 10.643sec(infer)\n",
      "Epoch 61 tst: l 0.485 a 0.842 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.782sec\n",
      "Epoch 62 tr: l 0.306 a 0.891 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.073288 31.480sec(train) 12.906sec(infer)\n",
      "Epoch 62 tst: l 0.483 a 0.842 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  11.031sec\n",
      "Epoch 63 tr: l 0.304 a 0.892 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.072921 30.051sec(train) 12.604sec(infer)\n",
      "Epoch 63 tst: l 0.483 a 0.843 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.727sec\n",
      "Epoch 64 tr: l 0.302 a 0.892 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.072557 32.907sec(train) 11.845sec(infer)\n",
      "Epoch 64 tst: l 0.481 a 0.843 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.593sec\n",
      "Epoch 65 tr: l 0.297 a 0.894 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.072194 30.540sec(train) 12.551sec(infer)\n",
      "Epoch 65 tst: l 0.479 a 0.844 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.890sec\n",
      "Epoch 66 tr: l 0.298 a 0.894 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.071833 32.568sec(train) 10.884sec(infer)\n",
      "Epoch 66 tst: l 0.479 a 0.843 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.529sec\n",
      "Epoch 67 tr: l 0.295 a 0.894 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.071474 31.566sec(train) 12.702sec(infer)\n",
      "Epoch 67 tst: l 0.478 a 0.844 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.658sec\n",
      "Epoch 68 tr: l 0.299 a 0.894 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.071116 30.795sec(train) 12.372sec(infer)\n",
      "Epoch 68 tst: l 0.476 a 0.844 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.468sec\n",
      "Epoch 69 tr: l 0.295 a 0.894 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.070761 32.871sec(train) 11.999sec(infer)\n",
      "Epoch 69 tst: l 0.475 a 0.845 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.730sec\n",
      "Epoch 70 tr: l 0.293 a 0.895 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.070407 31.240sec(train) 13.285sec(infer)\n",
      "Epoch 70 tst: l 0.473 a 0.845 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  8.735sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 71 tr: l 0.292 a 0.895 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.070055 32.157sec(train) 10.984sec(infer)\n",
      "Epoch 71 tst: l 0.472 a 0.846 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.324sec\n",
      "Epoch 72 tr: l 0.289 a 0.896 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.069705 30.756sec(train) 12.800sec(infer)\n",
      "Epoch 72 tst: l 0.471 a 0.845 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.813sec\n",
      "Epoch 73 tr: l 0.287 a 0.897 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.069356 30.539sec(train) 12.399sec(infer)\n",
      "Epoch 73 tst: l 0.470 a 0.846 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.275sec\n",
      "Epoch 74 tr: l 0.286 a 0.898 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.069009 32.608sec(train) 11.466sec(infer)\n",
      "Epoch 74 tst: l 0.469 a 0.846 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.647sec\n",
      "Epoch 75 tr: l 0.282 a 0.898 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.068664 31.014sec(train) 12.982sec(infer)\n",
      "Epoch 75 tst: l 0.469 a 0.847 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.975sec\n",
      "Epoch 76 tr: l 0.281 a 0.898 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.068321 30.337sec(train) 11.829sec(infer)\n",
      "Epoch 76 tst: l 0.468 a 0.846 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.545sec\n",
      "Epoch 77 tr: l 0.284 a 0.898 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.067979 31.999sec(train) 13.023sec(infer)\n",
      "Epoch 77 tst: l 0.466 a 0.847 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.911sec\n",
      "Epoch 78 tr: l 0.281 a 0.899 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.067639 30.954sec(train) 12.462sec(infer)\n",
      "Epoch 78 tst: l 0.466 a 0.847 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.132sec\n",
      "Epoch 79 tr: l 0.278 a 0.900 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.067301 32.354sec(train) 11.733sec(infer)\n",
      "Epoch 79 tst: l 0.465 a 0.848 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.754sec\n",
      "Epoch 80 tr: l 0.278 a 0.899 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.066965 31.145sec(train) 13.041sec(infer)\n",
      "Epoch 80 tst: l 0.465 a 0.847 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.992sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 81 tr: l 0.276 a 0.900 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.066630 31.707sec(train) 11.184sec(infer)\n",
      "Epoch 81 tst: l 0.463 a 0.848 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.563sec\n",
      "Epoch 82 tr: l 0.276 a 0.900 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.066297 31.414sec(train) 12.836sec(infer)\n",
      "Epoch 82 tst: l 0.462 a 0.847 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.702sec\n",
      "Epoch 83 tr: l 0.274 a 0.901 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.065965 30.653sec(train) 12.452sec(infer)\n",
      "Epoch 83 tst: l 0.462 a 0.848 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  9.422sec\n",
      "Epoch 84 tr: l 0.272 a 0.901 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.065635 32.419sec(train) 11.949sec(infer)\n",
      "Epoch 84 tst: l 0.461 a 0.848 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.542sec\n",
      "Epoch 85 tr: l 0.267 a 0.903 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.065307 30.570sec(train) 12.766sec(infer)\n",
      "Epoch 85 tst: l 0.460 a 0.849 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.031sec\n",
      "Epoch 86 tr: l 0.269 a 0.903 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064981 30.716sec(train) 11.425sec(infer)\n",
      "Epoch 86 tst: l 0.458 a 0.849 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.473sec\n",
      "Epoch 87 tr: l 0.265 a 0.904 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064656 32.221sec(train) 13.053sec(infer)\n",
      "Epoch 87 tst: l 0.458 a 0.849 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  10.599sec\n",
      "Epoch 88 tr: l 0.269 a 0.902 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064333 30.680sec(train) 12.823sec(infer)\n",
      "Epoch 88 tst: l 0.458 a 0.849 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  8.982sec\n",
      "Epoch 89 tr: l 0.267 a 0.903 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064011 23.145sec(train) 8.783sec(infer)\n",
      "Epoch 89 tst: l 0.457 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.313sec\n",
      "Epoch 90 tr: l 0.263 a 0.904 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.063691 21.716sec(train) 8.374sec(infer)\n",
      "Epoch 90 tst: l 0.457 a 0.849 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.318sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 91 tr: l 0.265 a 0.904 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.063372 21.891sec(train) 8.826sec(infer)\n",
      "Epoch 91 tst: l 0.456 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.389sec\n",
      "Epoch 92 tr: l 0.262 a 0.905 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.063056 22.793sec(train) 8.755sec(infer)\n",
      "Epoch 92 tst: l 0.455 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.779sec\n",
      "Epoch 93 tr: l 0.262 a 0.904 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.062740 22.916sec(train) 9.040sec(infer)\n",
      "Epoch 93 tst: l 0.455 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.518sec\n",
      "Epoch 94 tr: l 0.263 a 0.905 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.062427 21.824sec(train) 9.120sec(infer)\n",
      "Epoch 94 tst: l 0.454 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.036sec\n",
      "Epoch 95 tr: l 0.263 a 0.905 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.062114 21.868sec(train) 8.446sec(infer)\n",
      "Epoch 95 tst: l 0.454 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.342sec\n",
      "Epoch 96 tr: l 0.258 a 0.906 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.061804 22.115sec(train) 8.608sec(infer)\n",
      "Epoch 96 tst: l 0.453 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.206sec\n",
      "Epoch 97 tr: l 0.260 a 0.906 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.061495 22.531sec(train) 8.476sec(infer)\n",
      "Epoch 97 tst: l 0.452 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.116sec\n",
      "Epoch 98 tr: l 0.256 a 0.907 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.061187 22.337sec(train) 8.629sec(infer)\n",
      "Epoch 98 tst: l 0.452 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.985sec\n",
      "Epoch 99 tr: l 0.256 a 0.907 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.060881 21.627sec(train) 8.683sec(infer)\n",
      "Epoch 99 tst: l 0.451 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.296sec\n",
      "Epoch 100 tr: l 0.281 a 0.898 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.006058 21.971sec(train) 8.598sec(infer)\n",
      "Epoch 100 tst: l 0.448 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.458sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 101 tr: l 0.298 a 0.893 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.006027 21.790sec(train) 8.322sec(infer)\n",
      "Epoch 101 tst: l 0.446 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.684sec\n",
      "Epoch 102 tr: l 0.301 a 0.892 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005997 21.138sec(train) 8.470sec(infer)\n",
      "Epoch 102 tst: l 0.445 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.579sec\n",
      "Epoch 103 tr: l 0.304 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005967 22.180sec(train) 8.638sec(infer)\n",
      "Epoch 103 tst: l 0.445 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.421sec\n",
      "Epoch 104 tr: l 0.306 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005937 22.007sec(train) 8.591sec(infer)\n",
      "Epoch 104 tst: l 0.444 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.492sec\n",
      "Epoch 105 tr: l 0.308 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005908 22.148sec(train) 8.549sec(infer)\n",
      "Epoch 105 tst: l 0.444 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.599sec\n",
      "Epoch 106 tr: l 0.309 a 0.889 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005878 22.346sec(train) 8.876sec(infer)\n",
      "Epoch 106 tst: l 0.444 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.022sec\n",
      "Epoch 107 tr: l 0.308 a 0.889 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005849 22.541sec(train) 9.264sec(infer)\n",
      "Epoch 107 tst: l 0.444 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.685sec\n",
      "Epoch 108 tr: l 0.309 a 0.889 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005820 22.257sec(train) 8.472sec(infer)\n",
      "Epoch 108 tst: l 0.444 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.793sec\n",
      "Epoch 109 tr: l 0.308 a 0.889 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005790 22.020sec(train) 8.790sec(infer)\n",
      "Epoch 109 tst: l 0.443 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.229sec\n",
      "Epoch 110 tr: l 0.309 a 0.889 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005762 22.621sec(train) 8.739sec(infer)\n",
      "Epoch 110 tst: l 0.443 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.299sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 111 tr: l 0.310 a 0.889 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005733 21.866sec(train) 8.606sec(infer)\n",
      "Epoch 111 tst: l 0.443 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.288sec\n",
      "Epoch 112 tr: l 0.308 a 0.889 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005704 22.436sec(train) 8.666sec(infer)\n",
      "Epoch 112 tst: l 0.443 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.912sec\n",
      "Epoch 113 tr: l 0.308 a 0.889 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005676 22.325sec(train) 8.683sec(infer)\n",
      "Epoch 113 tst: l 0.443 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.829sec\n",
      "Epoch 114 tr: l 0.309 a 0.889 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005647 22.504sec(train) 8.553sec(infer)\n",
      "Epoch 114 tst: l 0.443 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.466sec\n",
      "Epoch 115 tr: l 0.308 a 0.889 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005619 22.536sec(train) 8.522sec(infer)\n",
      "Epoch 115 tst: l 0.443 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.992sec\n",
      "Epoch 116 tr: l 0.308 a 0.889 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005591 22.575sec(train) 8.370sec(infer)\n",
      "Epoch 116 tst: l 0.442 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.754sec\n",
      "Epoch 117 tr: l 0.309 a 0.889 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005563 22.335sec(train) 8.358sec(infer)\n",
      "Epoch 117 tst: l 0.442 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.095sec\n",
      "Epoch 118 tr: l 0.308 a 0.889 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005535 21.522sec(train) 8.350sec(infer)\n",
      "Epoch 118 tst: l 0.442 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.447sec\n",
      "Epoch 119 tr: l 0.307 a 0.889 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005507 22.316sec(train) 8.746sec(infer)\n",
      "Epoch 119 tst: l 0.442 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.074sec\n",
      "Epoch 120 tr: l 0.308 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005480 22.231sec(train) 8.834sec(infer)\n",
      "Epoch 120 tst: l 0.442 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.163sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 121 tr: l 0.308 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005452 22.829sec(train) 8.585sec(infer)\n",
      "Epoch 121 tst: l 0.442 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.476sec\n",
      "Epoch 122 tr: l 0.307 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005425 21.905sec(train) 8.425sec(infer)\n",
      "Epoch 122 tst: l 0.442 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.320sec\n",
      "Epoch 123 tr: l 0.307 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005398 21.724sec(train) 8.448sec(infer)\n",
      "Epoch 123 tst: l 0.442 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.282sec\n",
      "Epoch 124 tr: l 0.307 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005371 22.271sec(train) 8.857sec(infer)\n",
      "Epoch 124 tst: l 0.442 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.644sec\n",
      "Epoch 125 tr: l 0.307 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005344 21.882sec(train) 8.437sec(infer)\n",
      "Epoch 125 tst: l 0.442 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.602sec\n",
      "Epoch 126 tr: l 0.306 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005318 22.773sec(train) 8.458sec(infer)\n",
      "Epoch 126 tst: l 0.442 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.060sec\n",
      "Epoch 127 tr: l 0.307 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005291 22.350sec(train) 8.122sec(infer)\n",
      "Epoch 127 tst: l 0.442 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.866sec\n",
      "Epoch 128 tr: l 0.307 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005264 22.183sec(train) 8.623sec(infer)\n",
      "Epoch 128 tst: l 0.442 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.510sec\n",
      "Epoch 129 tr: l 0.306 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005238 22.561sec(train) 8.860sec(infer)\n",
      "Epoch 129 tst: l 0.442 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.527sec\n",
      "Epoch 130 tr: l 0.306 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005212 22.241sec(train) 8.266sec(infer)\n",
      "Epoch 130 tst: l 0.442 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.310sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 131 tr: l 0.306 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005186 21.879sec(train) 8.569sec(infer)\n",
      "Epoch 131 tst: l 0.442 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.299sec\n",
      "Epoch 132 tr: l 0.307 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005160 22.875sec(train) 8.951sec(infer)\n",
      "Epoch 132 tst: l 0.441 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.376sec\n",
      "Epoch 133 tr: l 0.307 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005134 22.275sec(train) 8.756sec(infer)\n",
      "Epoch 133 tst: l 0.441 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.584sec\n",
      "Epoch 134 tr: l 0.307 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005108 22.232sec(train) 8.841sec(infer)\n",
      "Epoch 134 tst: l 0.441 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.690sec\n",
      "Epoch 135 tr: l 0.306 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005083 23.231sec(train) 8.682sec(infer)\n",
      "Epoch 135 tst: l 0.441 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.548sec\n",
      "Epoch 136 tr: l 0.308 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005058 22.433sec(train) 8.668sec(infer)\n",
      "Epoch 136 tst: l 0.441 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.626sec\n",
      "Epoch 137 tr: l 0.308 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005032 22.972sec(train) 8.864sec(infer)\n",
      "Epoch 137 tst: l 0.441 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.265sec\n",
      "Epoch 138 tr: l 0.307 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005007 22.674sec(train) 8.432sec(infer)\n",
      "Epoch 138 tst: l 0.441 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.480sec\n",
      "Epoch 139 tr: l 0.307 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004982 22.784sec(train) 8.788sec(infer)\n",
      "Epoch 139 tst: l 0.441 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.643sec\n",
      "Epoch 140 tr: l 0.306 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004957 22.619sec(train) 8.723sec(infer)\n",
      "Epoch 140 tst: l 0.441 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.610sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 141 tr: l 0.306 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004932 23.077sec(train) 8.862sec(infer)\n",
      "Epoch 141 tst: l 0.441 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.178sec\n",
      "Epoch 142 tr: l 0.306 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004908 22.992sec(train) 8.705sec(infer)\n",
      "Epoch 142 tst: l 0.441 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  5.722sec\n",
      "Epoch 143 tr: l 0.306 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004883 22.774sec(train) 8.983sec(infer)\n",
      "Epoch 143 tst: l 0.441 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  5.944sec\n",
      "Epoch 144 tr: l 0.306 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004859 23.141sec(train) 8.565sec(infer)\n",
      "Epoch 144 tst: l 0.441 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  5.913sec\n",
      "Epoch 145 tr: l 0.306 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004834 22.525sec(train) 8.485sec(infer)\n",
      "Epoch 145 tst: l 0.440 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.875sec\n",
      "Epoch 146 tr: l 0.307 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004810 22.524sec(train) 8.716sec(infer)\n",
      "Epoch 146 tst: l 0.440 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.756sec\n",
      "Epoch 147 tr: l 0.307 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004786 21.968sec(train) 8.659sec(infer)\n",
      "Epoch 147 tst: l 0.440 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.040sec\n",
      "Epoch 148 tr: l 0.306 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004762 22.278sec(train) 8.602sec(infer)\n",
      "Epoch 148 tst: l 0.440 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.881sec\n",
      "Epoch 149 tr: l 0.305 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004738 22.190sec(train) 8.433sec(infer)\n",
      "Epoch 149 tst: l 0.440 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.214sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "---train cluster Ended in 1.99 hour (7165.879 sec) \n",
      "---------------------------------DFCA-GI, lr: 0.1, seed: 3657---------------------------------\n",
      "config: {'m': 200, 'm_test': 40, 'p': 4, 'n': 1500, 'uneven': True, 'local_model_init': False, 'Gp': 0.15, 'graph': 'er', 'agg': 'seq', '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:2\n",
      "Epoch -1 tr: l 3.866 a 0.025 clct[np.int64(48), np.int64(19), np.int64(50), np.int64(83)] cl_acc 0.480  7.173sec\n",
      "Epoch -1 tst: l 3.867 a 0.033 clct[np.int64(11), np.int64(7), np.int64(9), np.int64(13)] cl_acc 0.550  6.272sec\n",
      "Epoch 0 tr: l 3.151 a 0.333 clct[np.int64(47), np.int64(20), np.int64(50), np.int64(83)] cl_acc 0.485  lr 0.100000 27.091sec(train) 6.260sec(infer)\n",
      "Epoch 0 tst: l 3.549 a 0.168 clct[np.int64(8), np.int64(4), np.int64(7), np.int64(21)] cl_acc 0.525  6.349sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 1 tr: l 2.586 a 0.463 clct[np.int64(47), np.int64(20), np.int64(52), np.int64(81)] cl_acc 0.490  lr 0.099500 26.666sec(train) 6.195sec(infer)\n",
      "Epoch 1 tst: l 3.146 a 0.312 clct[np.int64(5), np.int64(3), np.int64(10), np.int64(22)] cl_acc 0.525  6.400sec\n",
      "Epoch 2 tr: l 2.175 a 0.524 clct[np.int64(47), np.int64(22), np.int64(53), np.int64(78)] cl_acc 0.495  lr 0.099003 26.524sec(train) 6.830sec(infer)\n",
      "Epoch 2 tst: l 2.758 a 0.406 clct[np.int64(5), np.int64(5), np.int64(9), np.int64(21)] cl_acc 0.525  6.221sec\n",
      "Epoch 3 tr: l 1.892 a 0.567 clct[np.int64(46), np.int64(24), np.int64(54), np.int64(76)] cl_acc 0.515  lr 0.098507 26.574sec(train) 6.572sec(infer)\n",
      "Epoch 3 tst: l 2.448 a 0.464 clct[np.int64(3), np.int64(4), np.int64(14), np.int64(19)] cl_acc 0.550  6.410sec\n",
      "Epoch 4 tr: l 1.683 a 0.594 clct[np.int64(46), np.int64(27), np.int64(54), np.int64(73)] cl_acc 0.535  lr 0.098015 17.862sec(train) 4.355sec(infer)\n",
      "Epoch 4 tst: l 2.165 a 0.505 clct[np.int64(9), np.int64(5), np.int64(12), np.int64(14)] cl_acc 0.725  4.046sec\n",
      "Epoch 5 tr: l 1.537 a 0.609 clct[np.int64(48), np.int64(31), np.int64(52), np.int64(69)] cl_acc 0.585  lr 0.097525 19.430sec(train) 8.155sec(infer)\n",
      "Epoch 5 tst: l 1.964 a 0.537 clct[np.int64(9), np.int64(8), np.int64(9), np.int64(14)] cl_acc 0.800  7.840sec\n",
      "Epoch 6 tr: l 1.413 a 0.635 clct[np.int64(49), np.int64(39), np.int64(48), np.int64(64)] cl_acc 0.660  lr 0.097037 23.342sec(train) 8.297sec(infer)\n",
      "Epoch 6 tst: l 1.789 a 0.568 clct[np.int64(11), np.int64(8), np.int64(10), np.int64(11)] cl_acc 0.875  7.696sec\n",
      "Epoch 7 tr: l 1.249 a 0.669 clct[np.int64(51), np.int64(42), np.int64(47), np.int64(60)] cl_acc 0.705  lr 0.096552 22.377sec(train) 8.528sec(infer)\n",
      "Epoch 7 tst: l 1.619 a 0.597 clct[np.int64(11), np.int64(10), np.int64(10), np.int64(9)] cl_acc 0.975  7.880sec\n",
      "Epoch 8 tr: l 1.126 a 0.695 clct[np.int64(54), np.int64(43), np.int64(48), np.int64(55)] cl_acc 0.775  lr 0.096069 22.572sec(train) 8.502sec(infer)\n",
      "Epoch 8 tst: l 1.466 a 0.629 clct[np.int64(11), np.int64(10), np.int64(9), np.int64(10)] cl_acc 0.950  7.900sec\n",
      "Epoch 9 tr: l 1.010 a 0.727 clct[np.int64(56), np.int64(43), np.int64(49), np.int64(52)] cl_acc 0.815  lr 0.095589 22.534sec(train) 8.191sec(infer)\n",
      "Epoch 9 tst: l 1.310 a 0.669 clct[np.int64(11), np.int64(10), np.int64(10), np.int64(9)] cl_acc 0.975  7.328sec\n",
      "Epoch 10 tr: l 0.933 a 0.742 clct[np.int64(54), np.int64(47), np.int64(51), np.int64(48)] cl_acc 0.885  lr 0.095111 22.634sec(train) 8.466sec(infer)\n",
      "Epoch 10 tst: l 1.190 a 0.692 clct[np.int64(11), np.int64(10), np.int64(10), np.int64(9)] cl_acc 0.975  7.264sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 11 tr: l 0.848 a 0.760 clct[np.int64(49), np.int64(47), np.int64(53), np.int64(51)] cl_acc 0.930  lr 0.094635 22.443sec(train) 8.720sec(infer)\n",
      "Epoch 11 tst: l 1.084 a 0.715 clct[np.int64(11), np.int64(10), np.int64(10), np.int64(9)] cl_acc 0.975  7.109sec\n",
      "Epoch 12 tr: l 0.761 a 0.777 clct[np.int64(46), np.int64(47), np.int64(54), np.int64(53)] cl_acc 0.960  lr 0.094162 22.613sec(train) 8.641sec(infer)\n",
      "Epoch 12 tst: l 0.978 a 0.735 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.596sec\n",
      "Epoch 13 tr: l 0.707 a 0.793 clct[np.int64(47), np.int64(48), np.int64(53), np.int64(52)] cl_acc 0.970  lr 0.093691 22.648sec(train) 8.559sec(infer)\n",
      "Epoch 13 tst: l 0.906 a 0.751 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.920sec\n",
      "Epoch 14 tr: l 0.667 a 0.799 clct[np.int64(48), np.int64(49), np.int64(52), np.int64(51)] cl_acc 0.980  lr 0.093223 22.531sec(train) 8.880sec(infer)\n",
      "Epoch 14 tst: l 0.861 a 0.757 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.446sec\n",
      "Epoch 15 tr: l 0.628 a 0.807 clct[np.int64(50), np.int64(49), np.int64(52), np.int64(49)] cl_acc 0.990  lr 0.092757 22.795sec(train) 8.457sec(infer)\n",
      "Epoch 15 tst: l 0.817 a 0.767 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.452sec\n",
      "Epoch 16 tr: l 0.597 a 0.815 clct[np.int64(50), np.int64(49), np.int64(52), np.int64(49)] cl_acc 0.990  lr 0.092293 22.224sec(train) 8.598sec(infer)\n",
      "Epoch 16 tst: l 0.782 a 0.773 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.921sec\n",
      "Epoch 17 tr: l 0.565 a 0.822 clct[np.int64(50), np.int64(49), np.int64(52), np.int64(49)] cl_acc 0.990  lr 0.091832 22.171sec(train) 8.547sec(infer)\n",
      "Epoch 17 tst: l 0.756 a 0.779 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.051sec\n",
      "Epoch 18 tr: l 0.556 a 0.826 clct[np.int64(50), np.int64(49), np.int64(52), np.int64(49)] cl_acc 0.990  lr 0.091372 22.002sec(train) 8.359sec(infer)\n",
      "Epoch 18 tst: l 0.728 a 0.785 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.448sec\n",
      "Epoch 19 tr: l 0.537 a 0.831 clct[np.int64(50), np.int64(50), np.int64(51), np.int64(49)] cl_acc 0.995  lr 0.090916 21.646sec(train) 8.464sec(infer)\n",
      "Epoch 19 tst: l 0.711 a 0.789 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.151sec\n",
      "Epoch 20 tr: l 0.528 a 0.834 clct[np.int64(50), np.int64(50), np.int64(51), np.int64(49)] cl_acc 0.995  lr 0.090461 21.814sec(train) 8.388sec(infer)\n",
      "Epoch 20 tst: l 0.696 a 0.792 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.572sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 21 tr: l 0.499 a 0.839 clct[np.int64(50), np.int64(50), np.int64(51), np.int64(49)] cl_acc 0.995  lr 0.090009 21.677sec(train) 8.464sec(infer)\n",
      "Epoch 21 tst: l 0.680 a 0.796 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.686sec\n",
      "Epoch 22 tr: l 0.485 a 0.843 clct[np.int64(50), np.int64(50), np.int64(51), np.int64(49)] cl_acc 0.995  lr 0.089559 21.027sec(train) 8.239sec(infer)\n",
      "Epoch 22 tst: l 0.660 a 0.800 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.659sec\n",
      "Epoch 23 tr: l 0.472 a 0.846 clct[np.int64(50), np.int64(50), np.int64(51), np.int64(49)] cl_acc 0.995  lr 0.089111 21.718sec(train) 8.495sec(infer)\n",
      "Epoch 23 tst: l 0.648 a 0.804 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.514sec\n",
      "Epoch 24 tr: l 0.466 a 0.848 clct[np.int64(50), np.int64(50), np.int64(51), np.int64(49)] cl_acc 0.995  lr 0.088665 21.390sec(train) 8.592sec(infer)\n",
      "Epoch 24 tst: l 0.635 a 0.806 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.780sec\n",
      "Epoch 25 tr: l 0.453 a 0.851 clct[np.int64(50), np.int64(50), np.int64(51), np.int64(49)] cl_acc 0.995  lr 0.088222 22.341sec(train) 8.713sec(infer)\n",
      "Epoch 25 tst: l 0.630 a 0.808 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.883sec\n",
      "Epoch 26 tr: l 0.442 a 0.852 clct[np.int64(50), np.int64(50), np.int64(51), np.int64(49)] cl_acc 0.995  lr 0.087781 21.623sec(train) 8.215sec(infer)\n",
      "Epoch 26 tst: l 0.617 a 0.810 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.823sec\n",
      "Epoch 27 tr: l 0.440 a 0.855 clct[np.int64(50), np.int64(50), np.int64(51), np.int64(49)] cl_acc 0.995  lr 0.087342 21.210sec(train) 8.559sec(infer)\n",
      "Epoch 27 tst: l 0.610 a 0.812 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.988sec\n",
      "Epoch 28 tr: l 0.428 a 0.858 clct[np.int64(50), np.int64(50), np.int64(51), np.int64(49)] cl_acc 0.995  lr 0.086905 22.052sec(train) 8.359sec(infer)\n",
      "Epoch 28 tst: l 0.603 a 0.813 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.869sec\n",
      "Epoch 29 tr: l 0.421 a 0.859 clct[np.int64(50), np.int64(50), np.int64(51), np.int64(49)] cl_acc 0.995  lr 0.086471 21.755sec(train) 8.406sec(infer)\n",
      "Epoch 29 tst: l 0.594 a 0.816 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.895sec\n",
      "Epoch 30 tr: l 0.414 a 0.860 clct[np.int64(50), np.int64(50), np.int64(51), np.int64(49)] cl_acc 0.995  lr 0.086038 22.024sec(train) 8.787sec(infer)\n",
      "Epoch 30 tst: l 0.586 a 0.818 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.272sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 31 tr: l 0.412 a 0.862 clct[np.int64(50), np.int64(50), np.int64(51), np.int64(49)] cl_acc 0.995  lr 0.085608 22.091sec(train) 8.603sec(infer)\n",
      "Epoch 31 tst: l 0.580 a 0.820 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.053sec\n",
      "Epoch 32 tr: l 0.405 a 0.863 clct[np.int64(50), np.int64(50), np.int64(51), np.int64(49)] cl_acc 0.995  lr 0.085180 22.644sec(train) 8.710sec(infer)\n",
      "Epoch 32 tst: l 0.573 a 0.821 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.527sec\n",
      "Epoch 33 tr: l 0.394 a 0.865 clct[np.int64(50), np.int64(50), np.int64(51), np.int64(49)] cl_acc 0.995  lr 0.084754 22.876sec(train) 8.839sec(infer)\n",
      "Epoch 33 tst: l 0.569 a 0.822 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.034sec\n",
      "Epoch 34 tr: l 0.391 a 0.867 clct[np.int64(50), np.int64(50), np.int64(51), np.int64(49)] cl_acc 0.995  lr 0.084331 22.249sec(train) 8.446sec(infer)\n",
      "Epoch 34 tst: l 0.562 a 0.824 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.712sec\n",
      "Epoch 35 tr: l 0.388 a 0.868 clct[np.int64(50), np.int64(50), np.int64(51), np.int64(49)] cl_acc 0.995  lr 0.083909 22.424sec(train) 8.482sec(infer)\n",
      "Epoch 35 tst: l 0.558 a 0.825 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.772sec\n",
      "Epoch 36 tr: l 0.381 a 0.868 clct[np.int64(50), np.int64(50), np.int64(51), np.int64(49)] cl_acc 0.995  lr 0.083489 22.177sec(train) 8.403sec(infer)\n",
      "Epoch 36 tst: l 0.553 a 0.825 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.050sec\n",
      "Epoch 37 tr: l 0.383 a 0.870 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.083072 22.481sec(train) 8.636sec(infer)\n",
      "Epoch 37 tst: l 0.547 a 0.827 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.009sec\n",
      "Epoch 38 tr: l 0.374 a 0.871 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.082657 22.286sec(train) 8.606sec(infer)\n",
      "Epoch 38 tst: l 0.545 a 0.828 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.187sec\n",
      "Epoch 39 tr: l 0.370 a 0.873 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.082243 22.402sec(train) 7.968sec(infer)\n",
      "Epoch 39 tst: l 0.541 a 0.829 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.024sec\n",
      "Epoch 40 tr: l 0.363 a 0.874 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.081832 21.791sec(train) 8.555sec(infer)\n",
      "Epoch 40 tst: l 0.536 a 0.830 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.138sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 41 tr: l 0.361 a 0.875 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.081423 21.968sec(train) 8.540sec(infer)\n",
      "Epoch 41 tst: l 0.533 a 0.830 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.222sec\n",
      "Epoch 42 tr: l 0.356 a 0.877 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.081016 21.916sec(train) 8.539sec(infer)\n",
      "Epoch 42 tst: l 0.529 a 0.832 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.072sec\n",
      "Epoch 43 tr: l 0.353 a 0.877 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.080611 21.481sec(train) 8.540sec(infer)\n",
      "Epoch 43 tst: l 0.526 a 0.833 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.431sec\n",
      "Epoch 44 tr: l 0.350 a 0.878 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.080208 21.457sec(train) 8.386sec(infer)\n",
      "Epoch 44 tst: l 0.523 a 0.833 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.353sec\n",
      "Epoch 45 tr: l 0.350 a 0.878 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.079807 21.682sec(train) 8.700sec(infer)\n",
      "Epoch 45 tst: l 0.520 a 0.834 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.484sec\n",
      "Epoch 46 tr: l 0.345 a 0.880 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.079408 21.625sec(train) 8.292sec(infer)\n",
      "Epoch 46 tst: l 0.518 a 0.834 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.524sec\n",
      "Epoch 47 tr: l 0.342 a 0.880 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.079010 21.736sec(train) 8.471sec(infer)\n",
      "Epoch 47 tst: l 0.515 a 0.835 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.518sec\n",
      "Epoch 48 tr: l 0.339 a 0.881 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.078615 21.501sec(train) 8.329sec(infer)\n",
      "Epoch 48 tst: l 0.511 a 0.836 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.569sec\n",
      "Epoch 49 tr: l 0.335 a 0.882 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.078222 22.019sec(train) 8.738sec(infer)\n",
      "Epoch 49 tst: l 0.510 a 0.836 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.498sec\n",
      "Epoch 50 tr: l 0.331 a 0.883 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.077831 21.925sec(train) 8.565sec(infer)\n",
      "Epoch 50 tst: l 0.507 a 0.837 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.172sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 51 tr: l 0.330 a 0.884 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.077442 21.872sec(train) 8.579sec(infer)\n",
      "Epoch 51 tst: l 0.506 a 0.837 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.586sec\n",
      "Epoch 52 tr: l 0.329 a 0.884 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.077055 21.544sec(train) 8.303sec(infer)\n",
      "Epoch 52 tst: l 0.503 a 0.838 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.614sec\n",
      "Epoch 53 tr: l 0.325 a 0.886 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.076670 21.656sec(train) 8.395sec(infer)\n",
      "Epoch 53 tst: l 0.501 a 0.838 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.569sec\n",
      "Epoch 54 tr: l 0.322 a 0.885 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.076286 21.846sec(train) 8.643sec(infer)\n",
      "Epoch 54 tst: l 0.498 a 0.839 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.629sec\n",
      "Epoch 55 tr: l 0.322 a 0.886 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.075905 21.970sec(train) 8.587sec(infer)\n",
      "Epoch 55 tst: l 0.497 a 0.839 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.190sec\n",
      "Epoch 56 tr: l 0.319 a 0.888 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.075525 21.782sec(train) 8.514sec(infer)\n",
      "Epoch 56 tst: l 0.495 a 0.839 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.392sec\n",
      "Epoch 57 tr: l 0.315 a 0.888 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.075148 22.459sec(train) 8.243sec(infer)\n",
      "Epoch 57 tst: l 0.495 a 0.839 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.217sec\n",
      "Epoch 58 tr: l 0.313 a 0.889 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.074772 21.686sec(train) 8.291sec(infer)\n",
      "Epoch 58 tst: l 0.493 a 0.840 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.394sec\n",
      "Epoch 59 tr: l 0.310 a 0.891 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.074398 22.297sec(train) 8.471sec(infer)\n",
      "Epoch 59 tst: l 0.491 a 0.841 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.383sec\n",
      "Epoch 60 tr: l 0.305 a 0.892 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.074026 22.005sec(train) 8.460sec(infer)\n",
      "Epoch 60 tst: l 0.489 a 0.841 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.557sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 61 tr: l 0.308 a 0.891 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.073656 22.679sec(train) 9.137sec(infer)\n",
      "Epoch 61 tst: l 0.487 a 0.842 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.806sec\n",
      "Epoch 62 tr: l 0.306 a 0.892 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.073288 22.162sec(train) 8.846sec(infer)\n",
      "Epoch 62 tst: l 0.484 a 0.842 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.903sec\n",
      "Epoch 63 tr: l 0.305 a 0.892 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.072921 22.997sec(train) 8.981sec(infer)\n",
      "Epoch 63 tst: l 0.484 a 0.843 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.362sec\n",
      "Epoch 64 tr: l 0.301 a 0.893 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.072557 22.951sec(train) 8.774sec(infer)\n",
      "Epoch 64 tst: l 0.482 a 0.843 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.426sec\n",
      "Epoch 65 tr: l 0.300 a 0.893 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.072194 22.613sec(train) 8.517sec(infer)\n",
      "Epoch 65 tst: l 0.482 a 0.843 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.622sec\n",
      "Epoch 66 tr: l 0.300 a 0.893 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.071833 22.207sec(train) 8.611sec(infer)\n",
      "Epoch 66 tst: l 0.478 a 0.844 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.834sec\n",
      "Epoch 67 tr: l 0.295 a 0.894 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.071474 22.099sec(train) 8.528sec(infer)\n",
      "Epoch 67 tst: l 0.479 a 0.844 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.166sec\n",
      "Epoch 68 tr: l 0.294 a 0.895 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.071116 21.550sec(train) 8.542sec(infer)\n",
      "Epoch 68 tst: l 0.477 a 0.844 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.353sec\n",
      "Epoch 69 tr: l 0.293 a 0.895 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.070761 22.092sec(train) 8.353sec(infer)\n",
      "Epoch 69 tst: l 0.476 a 0.845 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.477sec\n",
      "Epoch 70 tr: l 0.290 a 0.896 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.070407 22.225sec(train) 8.321sec(infer)\n",
      "Epoch 70 tst: l 0.474 a 0.845 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.659sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 71 tr: l 0.290 a 0.896 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.070055 21.529sec(train) 8.663sec(infer)\n",
      "Epoch 71 tst: l 0.474 a 0.845 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.333sec\n",
      "Epoch 72 tr: l 0.288 a 0.897 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.069705 21.766sec(train) 8.443sec(infer)\n",
      "Epoch 72 tst: l 0.472 a 0.846 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.358sec\n",
      "Epoch 73 tr: l 0.288 a 0.896 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.069356 21.616sec(train) 8.349sec(infer)\n",
      "Epoch 73 tst: l 0.471 a 0.846 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.645sec\n",
      "Epoch 74 tr: l 0.285 a 0.898 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.069009 21.990sec(train) 8.109sec(infer)\n",
      "Epoch 74 tst: l 0.470 a 0.846 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.864sec\n",
      "Epoch 75 tr: l 0.288 a 0.897 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.068664 22.190sec(train) 8.851sec(infer)\n",
      "Epoch 75 tst: l 0.468 a 0.847 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.307sec\n",
      "Epoch 76 tr: l 0.283 a 0.900 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.068321 22.115sec(train) 8.261sec(infer)\n",
      "Epoch 76 tst: l 0.467 a 0.847 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.231sec\n",
      "Epoch 77 tr: l 0.278 a 0.899 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.067979 22.152sec(train) 8.399sec(infer)\n",
      "Epoch 77 tst: l 0.467 a 0.847 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.049sec\n",
      "Epoch 78 tr: l 0.280 a 0.900 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.067639 21.830sec(train) 9.023sec(infer)\n",
      "Epoch 78 tst: l 0.465 a 0.847 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.983sec\n",
      "Epoch 79 tr: l 0.281 a 0.898 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.067301 22.465sec(train) 8.491sec(infer)\n",
      "Epoch 79 tst: l 0.465 a 0.848 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.117sec\n",
      "Epoch 80 tr: l 0.278 a 0.899 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.066965 22.529sec(train) 8.204sec(infer)\n",
      "Epoch 80 tst: l 0.464 a 0.848 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.215sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 81 tr: l 0.276 a 0.900 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.066630 23.077sec(train) 8.424sec(infer)\n",
      "Epoch 81 tst: l 0.464 a 0.848 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.985sec\n",
      "Epoch 82 tr: l 0.276 a 0.900 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.066297 22.069sec(train) 8.636sec(infer)\n",
      "Epoch 82 tst: l 0.463 a 0.848 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.998sec\n",
      "Epoch 83 tr: l 0.274 a 0.901 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.065965 22.217sec(train) 8.312sec(infer)\n",
      "Epoch 83 tst: l 0.462 a 0.849 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.153sec\n",
      "Epoch 84 tr: l 0.273 a 0.901 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.065635 22.235sec(train) 8.352sec(infer)\n",
      "Epoch 84 tst: l 0.461 a 0.848 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.208sec\n",
      "Epoch 85 tr: l 0.267 a 0.903 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.065307 22.211sec(train) 8.485sec(infer)\n",
      "Epoch 85 tst: l 0.460 a 0.849 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.119sec\n",
      "Epoch 86 tr: l 0.268 a 0.903 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064981 22.716sec(train) 9.081sec(infer)\n",
      "Epoch 86 tst: l 0.459 a 0.849 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.821sec\n",
      "Epoch 87 tr: l 0.266 a 0.903 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064656 22.090sec(train) 8.741sec(infer)\n",
      "Epoch 87 tst: l 0.459 a 0.849 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.533sec\n",
      "Epoch 88 tr: l 0.266 a 0.904 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064333 22.430sec(train) 8.433sec(infer)\n",
      "Epoch 88 tst: l 0.458 a 0.849 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.049sec\n",
      "Epoch 89 tr: l 0.269 a 0.902 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064011 22.362sec(train) 8.628sec(infer)\n",
      "Epoch 89 tst: l 0.457 a 0.849 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.774sec\n",
      "Epoch 90 tr: l 0.263 a 0.905 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.063691 21.695sec(train) 8.535sec(infer)\n",
      "Epoch 90 tst: l 0.457 a 0.849 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.431sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 91 tr: l 0.266 a 0.903 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.063372 22.277sec(train) 8.381sec(infer)\n",
      "Epoch 91 tst: l 0.455 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.850sec\n",
      "Epoch 92 tr: l 0.263 a 0.905 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.063056 22.483sec(train) 8.540sec(infer)\n",
      "Epoch 92 tst: l 0.455 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.038sec\n",
      "Epoch 93 tr: l 0.263 a 0.905 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.062740 21.559sec(train) 8.600sec(infer)\n",
      "Epoch 93 tst: l 0.455 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.373sec\n",
      "Epoch 94 tr: l 0.261 a 0.906 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.062427 22.365sec(train) 8.593sec(infer)\n",
      "Epoch 94 tst: l 0.454 a 0.850 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.125sec\n",
      "Epoch 95 tr: l 0.259 a 0.906 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.062114 22.091sec(train) 8.231sec(infer)\n",
      "Epoch 95 tst: l 0.454 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.276sec\n",
      "Epoch 96 tr: l 0.256 a 0.907 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.061804 22.404sec(train) 8.441sec(infer)\n",
      "Epoch 96 tst: l 0.453 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.198sec\n",
      "Epoch 97 tr: l 0.257 a 0.906 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.061495 22.705sec(train) 8.828sec(infer)\n",
      "Epoch 97 tst: l 0.452 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.699sec\n",
      "Epoch 98 tr: l 0.255 a 0.908 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.061187 22.448sec(train) 8.492sec(infer)\n",
      "Epoch 98 tst: l 0.451 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.844sec\n",
      "Epoch 99 tr: l 0.253 a 0.909 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.060881 22.471sec(train) 8.541sec(infer)\n",
      "Epoch 99 tst: l 0.452 a 0.851 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.566sec\n",
      "Epoch 100 tr: l 0.280 a 0.899 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.006058 21.858sec(train) 8.463sec(infer)\n",
      "Epoch 100 tst: l 0.448 a 0.852 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.938sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 101 tr: l 0.295 a 0.894 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.006027 22.126sec(train) 8.037sec(infer)\n",
      "Epoch 101 tst: l 0.446 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.704sec\n",
      "Epoch 102 tr: l 0.302 a 0.891 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005997 21.779sec(train) 8.187sec(infer)\n",
      "Epoch 102 tst: l 0.445 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.037sec\n",
      "Epoch 103 tr: l 0.304 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005967 21.893sec(train) 8.213sec(infer)\n",
      "Epoch 103 tst: l 0.445 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.068sec\n",
      "Epoch 104 tr: l 0.306 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005937 21.874sec(train) 8.242sec(infer)\n",
      "Epoch 104 tst: l 0.444 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.052sec\n",
      "Epoch 105 tr: l 0.307 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005908 21.713sec(train) 8.144sec(infer)\n",
      "Epoch 105 tst: l 0.444 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.019sec\n",
      "Epoch 106 tr: l 0.308 a 0.889 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005878 21.943sec(train) 8.259sec(infer)\n",
      "Epoch 106 tst: l 0.444 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.221sec\n",
      "Epoch 107 tr: l 0.308 a 0.889 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005849 21.868sec(train) 8.204sec(infer)\n",
      "Epoch 107 tst: l 0.444 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.030sec\n",
      "Epoch 108 tr: l 0.307 a 0.889 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005820 22.980sec(train) 8.140sec(infer)\n",
      "Epoch 108 tst: l 0.444 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.461sec\n",
      "Epoch 109 tr: l 0.308 a 0.889 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005790 21.814sec(train) 8.373sec(infer)\n",
      "Epoch 109 tst: l 0.443 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.599sec\n",
      "Epoch 110 tr: l 0.307 a 0.889 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005762 22.196sec(train) 8.319sec(infer)\n",
      "Epoch 110 tst: l 0.443 a 0.853 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.516sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 111 tr: l 0.308 a 0.889 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005733 21.996sec(train) 8.357sec(infer)\n",
      "Epoch 111 tst: l 0.443 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.808sec\n",
      "Epoch 112 tr: l 0.307 a 0.889 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005704 22.953sec(train) 8.537sec(infer)\n",
      "Epoch 112 tst: l 0.443 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.584sec\n",
      "Epoch 113 tr: l 0.308 a 0.889 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005676 22.338sec(train) 8.478sec(infer)\n",
      "Epoch 113 tst: l 0.443 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.725sec\n",
      "Epoch 114 tr: l 0.309 a 0.889 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005647 21.990sec(train) 8.538sec(infer)\n",
      "Epoch 114 tst: l 0.443 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.375sec\n",
      "Epoch 115 tr: l 0.308 a 0.889 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005619 21.433sec(train) 8.353sec(infer)\n",
      "Epoch 115 tst: l 0.442 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.326sec\n",
      "Epoch 116 tr: l 0.309 a 0.889 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005591 21.628sec(train) 8.441sec(infer)\n",
      "Epoch 116 tst: l 0.442 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.609sec\n",
      "Epoch 117 tr: l 0.308 a 0.889 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005563 22.272sec(train) 8.343sec(infer)\n",
      "Epoch 117 tst: l 0.442 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.703sec\n",
      "Epoch 118 tr: l 0.307 a 0.889 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005535 22.167sec(train) 8.476sec(infer)\n",
      "Epoch 118 tst: l 0.442 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.433sec\n",
      "Epoch 119 tr: l 0.308 a 0.889 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005507 21.932sec(train) 8.517sec(infer)\n",
      "Epoch 119 tst: l 0.442 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.407sec\n",
      "Epoch 120 tr: l 0.307 a 0.889 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005480 22.470sec(train) 8.398sec(infer)\n",
      "Epoch 120 tst: l 0.442 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.040sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 121 tr: l 0.308 a 0.889 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005452 22.375sec(train) 8.442sec(infer)\n",
      "Epoch 121 tst: l 0.442 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.095sec\n",
      "Epoch 122 tr: l 0.308 a 0.889 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005425 21.785sec(train) 8.536sec(infer)\n",
      "Epoch 122 tst: l 0.442 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.346sec\n",
      "Epoch 123 tr: l 0.307 a 0.889 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005398 22.218sec(train) 8.769sec(infer)\n",
      "Epoch 123 tst: l 0.442 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.833sec\n",
      "Epoch 124 tr: l 0.307 a 0.889 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005371 21.961sec(train) 8.732sec(infer)\n",
      "Epoch 124 tst: l 0.442 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.174sec\n",
      "Epoch 125 tr: l 0.306 a 0.889 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005344 22.485sec(train) 8.252sec(infer)\n",
      "Epoch 125 tst: l 0.442 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.994sec\n",
      "Epoch 126 tr: l 0.308 a 0.889 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005318 21.856sec(train) 8.647sec(infer)\n",
      "Epoch 126 tst: l 0.442 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.219sec\n",
      "Epoch 127 tr: l 0.307 a 0.889 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005291 22.226sec(train) 8.448sec(infer)\n",
      "Epoch 127 tst: l 0.442 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.141sec\n",
      "Epoch 128 tr: l 0.307 a 0.889 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005264 21.423sec(train) 8.642sec(infer)\n",
      "Epoch 128 tst: l 0.441 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.401sec\n",
      "Epoch 129 tr: l 0.307 a 0.889 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005238 22.501sec(train) 8.329sec(infer)\n",
      "Epoch 129 tst: l 0.441 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.049sec\n",
      "Epoch 130 tr: l 0.307 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005212 21.855sec(train) 8.364sec(infer)\n",
      "Epoch 130 tst: l 0.441 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.416sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 131 tr: l 0.306 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005186 22.334sec(train) 8.706sec(infer)\n",
      "Epoch 131 tst: l 0.441 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.110sec\n",
      "Epoch 132 tr: l 0.307 a 0.889 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005160 22.239sec(train) 8.568sec(infer)\n",
      "Epoch 132 tst: l 0.441 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.011sec\n",
      "Epoch 133 tr: l 0.306 a 0.889 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005134 22.000sec(train) 8.580sec(infer)\n",
      "Epoch 133 tst: l 0.441 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.011sec\n",
      "Epoch 134 tr: l 0.307 a 0.889 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005108 22.136sec(train) 8.657sec(infer)\n",
      "Epoch 134 tst: l 0.441 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.871sec\n",
      "Epoch 135 tr: l 0.306 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005083 21.821sec(train) 8.379sec(infer)\n",
      "Epoch 135 tst: l 0.441 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.473sec\n",
      "Epoch 136 tr: l 0.305 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005058 21.939sec(train) 8.384sec(infer)\n",
      "Epoch 136 tst: l 0.441 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.374sec\n",
      "Epoch 137 tr: l 0.306 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005032 22.216sec(train) 8.538sec(infer)\n",
      "Epoch 137 tst: l 0.441 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.244sec\n",
      "Epoch 138 tr: l 0.307 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005007 22.073sec(train) 8.906sec(infer)\n",
      "Epoch 138 tst: l 0.441 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.049sec\n",
      "Epoch 139 tr: l 0.306 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004982 22.014sec(train) 8.666sec(infer)\n",
      "Epoch 139 tst: l 0.441 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.998sec\n",
      "Epoch 140 tr: l 0.306 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004957 22.282sec(train) 8.837sec(infer)\n",
      "Epoch 140 tst: l 0.441 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.843sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 141 tr: l 0.306 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004932 21.856sec(train) 8.616sec(infer)\n",
      "Epoch 141 tst: l 0.441 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.127sec\n",
      "Epoch 142 tr: l 0.305 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004908 22.212sec(train) 8.620sec(infer)\n",
      "Epoch 142 tst: l 0.441 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.161sec\n",
      "Epoch 143 tr: l 0.306 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004883 22.075sec(train) 8.565sec(infer)\n",
      "Epoch 143 tst: l 0.440 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  7.206sec\n",
      "Epoch 144 tr: l 0.305 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004859 22.313sec(train) 8.585sec(infer)\n",
      "Epoch 144 tst: l 0.440 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.914sec\n",
      "Epoch 145 tr: l 0.305 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004834 22.677sec(train) 8.413sec(infer)\n",
      "Epoch 145 tst: l 0.440 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.721sec\n",
      "Epoch 146 tr: l 0.305 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004810 22.337sec(train) 8.671sec(infer)\n",
      "Epoch 146 tst: l 0.440 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.996sec\n",
      "Epoch 147 tr: l 0.306 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004786 22.435sec(train) 8.645sec(infer)\n",
      "Epoch 147 tst: l 0.440 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.962sec\n",
      "Epoch 148 tr: l 0.306 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004762 22.934sec(train) 8.557sec(infer)\n",
      "Epoch 148 tst: l 0.440 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.491sec\n",
      "Epoch 149 tr: l 0.306 a 0.890 clct[np.int64(50), np.int64(50), np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004738 22.452sec(train) 8.485sec(infer)\n",
      "Epoch 149 tst: l 0.440 a 0.854 clct[np.int64(10), np.int64(10), np.int64(10), np.int64(10)] cl_acc 1.000  6.500sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "---train cluster Ended in 1.58 hour (5679.486 sec) \n"
     ]
    }
   ],
   "source": [
    "___.display_outputs()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Plots"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-19T12:04:35.682316Z",
     "iopub.status.busy": "2025-09-19T12:04:35.681971Z",
     "iopub.status.idle": "2025-09-19T12:04:37.451143Z",
     "shell.execute_reply": "2025-09-19T12:04:37.450397Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "DFCA-GI Acc:  [np.float64(85.37208333333334), np.float64(85.63041666666666), np.float64(84.86083333333333), np.float64(85.43166666666666), np.float64(85.42833333333333)]\n",
      "DFCA-LI Acc:  [np.float64(85.16583333333332), np.float64(85.34666666666666), np.float64(84.73041666666667), np.float64(85.05833333333334), np.float64(85.15958333333333)]\n",
      "IFCA Acc:  [np.float64(85.685), np.float64(80.94333333333333), np.float64(83.99333333333333), np.float64(85.59833333333333), np.float64(85.61666666666666)]\n",
      "DFCA-GI Avg Acc (%):  [0.8534466666666667]\n",
      "DFCA-LI Avg Acc (%):  [0.8509216666666667]\n",
      "IFCA Avg Acc (%):  [0.8436733333333333]\n",
      "DFCA-GI Std:  0.25732024470168013\n",
      "DFCA-LI Std:  0.2033468916244656\n",
      "IFCA Std:  1.8262580443202567\n"
     ]
    },
    {
     "data": {
      "image/png": "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r9Cl3YmIqH5hYkVEREkhyzKee+45AMHLhz/44IPwer1x6xcXF+OVV16JW75hwwasXbs2an9paSmmTJmi32doPWTkyJFo3rw5AOD//u//8PXXX0f18cMPP2DWrFkAgheYKH9p9wkTJui/PTV79mzs3Lkz7jh//PHHuGVERFR38TtWRESUNI899hi2bNmC9evX44MPPsAXX3yBKVOmoE+fPsjIyEBxcTGOHTuGHTt2YMOGDbDZbHj88cdj9nXzzTfjvvvuw86dO5GTk4P09HQcPnwYCxcuxPHjxwEA06ZNww033BDRzmKxYPny5RgxYgSKi4vRr18/5ObmYtCgQVAUBZ999hkWLFigX8Vw8eLFaNSoUUQfNpsNb7/9NgYPHgyXy4U777wTDzzwAEaOHImWLVvC6/Xi2LFj+Oijj7Bhw4YKE0giIqqbJCGESPYgiIio/lJVFU8++SSWLVuGyl6S2rZtG/HjuHPnzsW8efMABGe9Bg0ahIKCgpht7733XqxZswYmU+zPFFetWoUpU6bETXoURcELL7yAZ599Nu74Pv74Y4wfPz7icu6xlH+cAwcOxM6dO3H77bdjx44dcduFP16+fBMR1S48FZCIiJLKbDZj6dKl+OqrrzB9+nT06NEDGRkZUBQFGRkZuOmmm/DII49g3bp1OHr0aNx+2rZti4MHD+K5555Dly5d4HA4kJGRgQEDBuCdd97BunXr4iZVADBx4kQcO3YMTz75JLp06YKUlBTY7Xa0b98ekydPxqFDhypMqgBgyJAhyM/Px/z589G3b180bNgQiqIgPT0dvXr1wowZM7Bv376EY0VERLUXZ6yIiKjO4gwOERHVFpyxIiIiIiIiMoiJFRERERERkUFMrIiIiIiIiAxiYkVERERERGQQEysiIiIiIiKDeFVAIiIiIiIigzhjRUREREREZBATKyIiIiIiIoOYWBERERERERnExIqIiIiIiMggJlZEREREREQGMbEiIiIiIiIyiIkVERERERGRQUysiIiIiIiIDPp/Lj9Zu/hPU/MAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 1000x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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HTt2SOs1Gk2Nn7mRRrPk7reGTM77PZJYEishGnfc6wqvsapncnJycOjQIbz88svo0qULFAoFNBoNevTogUWLFuHrr79GWlpaorvZYFT/XZ8LFy5EvYX7JXHuk8Rg3ONnMpmwbds2rFixAn379oXJZILVakWLFi0wduxY7N69G3PmzAnblnGPj8FgwGeffYZPPvkEDzzwAFq2bClNEtKqVSs8+OCD2LBhA1avXg2VShXSnnG/Pnr06IEjR45gxowZyMvLg8vlgslkwj333IMVK1Zg06ZN0Ol0Edvff//9OHToECZNmoScnBxUVVUhLS0N9913H9auXYt33nlHmgCGgj9zXS5XjZ+5kWZclLvfKD6Mu3wKIQKmhyIiIiIiIqJa44gVERERERGRTEysiIiIiIiIZGJiRUREREREJBMTKyIiIiIiIpmYWBEREREREcnExIqIiIiIiEgmJlZEREREREQyMbEiIiIiIiKSiYkVERERERGRTEysiIiIiIiIZGJiRURElGD9+/eHQqFA//79E90VIiKKExMrIiIiIiIimZhYERERERERycTEioiIiIiISCYmVkRERERERDIxsSIiIiIiIpKJiRUREdUL27Ztw4QJE9CmTRsYjUYkJyeja9euKCgowLlz58K2mTNnDhQKBRQKBQCgvLwchYWF6Ny5M8xmM9LT0zFgwAB89NFHMfXh5MmTmDFjBjp37oykpCQYjUbk5eVh8uTJOHz4cEzbsFgsWLx4MX77298iKysLWq0WycnJ6NatG6ZNm4bdu3fXuI2zZ8/iueeew6233gqDwYCMjAwMHjwYmzZtiqkPRESUAIKIiCiB7Ha7GDt2rAAQ8WYymcT69etD2hYWFkp1iouLRdu2bSNuY/To0cLlckXsx6pVq4ROp4vYXqVSiXnz5kV9LZs3bxaZmZlRX0u4j95+/foJAKJfv35i165dUbexcOHC2geZiIiuO45YERFRwgghkJ+fjzVr1gAAhg8fjvfffx+7d+/Gnj178Je//AWtW7dGZWUl8vPzsX///ojbGjNmDEpKSvDUU09hy5Yt2LdvH95++220a9cOAFBUVISCgoKwbTdu3IjHHnsMDocDZrMZhYWF2LlzJ/bs2YPFixcjMzMTHo8HL730Et56662w29i2bRuGDh2Ky5cvQ6VS4bHHHsO6detw4MAB7N69GytWrMDIkSOh0Wgivobz589jxIgRUCqVmD9/Pnbt2oW9e/fi9ddfR2pqKgDgxRdfxJEjR2IJLxER3UiJzuyIiKjxWr58uQAgNBqN2LRpU9g6paWlonPnzgKA6N27d1BZ4IgVALF69eqQ9hUVFeL2228XAIRSqRSHDx8OKnc6naJ58+YCgDCbzeLgwYMh2zh58qRo1qyZACCMRqO4dOlSULndbpe2YTQaxbZt2yK+5tOnT4es849YARDZ2dnizJkzIXV27twpFAqFACCeeeaZiNsnIqLE4IgVERElhBACCxYsAAA888wzGDJkSNh6aWlpWLhwIQBg9+7d+N///he23rBhwzBu3LiQ9UlJSVi+fDkAwOv1YtmyZUHl69atk67hmj17Nu64446QbWRnZ0t9sNlsePfdd4PK33vvPWkb8+bNQ//+/cP2EQBatWoVsQwA/va3v6FFixYh6++55x785je/AQDs3Lkz6jaIiOjGY2JFREQJ8cMPP+Cnn34CAOTn50et27dvX2l5z549Yes8/vjjEdv37NkTnTt3BgBs2bIlqMz/WKFQYOLEiRG3MWrUKKSkpITdxoYNGwAAJpMJkyZNiriNmqSmpuJ3v/tdxPIePXoAAIqLi+N+DiIiuj6YWBERUUIEXi919913S7P7hbuZzWap7i+//BJ2e3fddVfU5+vZsycA4MSJE3A6ndL677//HgCQm5uLJk2aRGyv1WrRrVu3oDZ+Bw8eBOBLfIxGY9R+RJOXlwelMvJHc3p6OgDfzINERFS/MLEiIqKEuHjxYlztbDZb2PW33HJL1HZNmzYF4DsFsaysTFpfWloaU3sAyMrKCmrjd/nyZQBAs2bNatxGNDUlZf6ky+v1ynoeIiKqe+pEd4CIiBonj8cjLf/73/9GTk5OTO0iJUD+37KKl9z2RETUuDGxIiKihMjIyJCWU1NT0aVLF1nbu3DhQtSJIS5cuADAl0ClpaVJ6/2n1/nLo/Gfhuhv45eZmYkzZ87g/Pnzte43ERHdHHgqIBERJYT/eiXAN9ufXPv27YupPC8vD1qtVlrvT+hKSkpw6dKliO1dLpd0LVX1JLB79+4AfNeNRTpVkYiIbm5MrIiIKCG6d++Oli1bAgCWL1+OqqoqWdtbtWpVxLJ9+/ZJE07ce++9QWX+x0KIkGnUA61duxZXr14Nu43hw4cD8F3/5Z/anYiIGhcmVkRElBBKpRIvvfQSAN/04Y8++igcDkfE+hUVFViyZEnE8vXr16OoqChkvdVqxeTJk6Xn9C/7jRgxAs2bNwcA/PGPf8Thw4dDtvHzzz9j5syZAHwTTFSf2n38+PHSb0/NmjULO3bsiNjPM2fORCwjIqKGi9dYERFRwjz11FPYvHkz1q1bh08++QTffPMNJk+ejJ49eyIlJQUVFRU4duwYtm/fjvXr10Ov1+Ppp58Ou60777wTDz30EHbs2IH8/HwkJyfj0KFDWLBgAY4fPw4AmDp1Km677bagdlqtFsuXL8fw4cNRUVGB3r17o6CgAAMHDoRKpcJXX32F+fPnS7MYLlq0CJmZmUHb0Ov1eP/99zFo0CDYbDbce++9eOSRRzBixAi0bNkSDocDx44dw2effYb169dHTSCJiKhhUgghRKI7QUREjZfL5cKzzz6LZcuWoaaPpNzc3KAfx50zZw7mzp0LwDfqNXDgQJSUlIRt++CDD2LNmjVQq8N/p7hq1SpMnjw5YtKjUqnwyiuv4MUXX4zYv88//xzjxo0Lms49nOqvs3///tixYwf69euH7du3R2wX+Hr58U1EVL/wVEAiIkoojUaDpUuX4rvvvsO0adPQtWtXpKSkQKVSISUlBXfccQeeeOIJrF27FkePHo24ndzcXBw4cAAvvfQSOnbsCKPRiJSUFPTt2xcffPAB1q5dGzGpAoAJEybg2LFjePbZZ9GxY0eYTCYYDAa0bdsWkyZNwsGDB6MmVQAwePBgFBcXY968eejVqxcyMjKgUqmQnJyM7t27Y/r06di7d2/csSIiovqLI1ZERNRgcQSHiIjqC45YERERERERycTEioiIiIiISCYmVkRERERERDIxsSIiIiIiIpKJiRUREREREZFMnBWQiIiIiIhIJo5YERERERERycTEioiIiIiISCYmVkRERERERDIxsSIiIiIiIpKJiRUREREREZFMTKyIiIiIiIhkYmJFREREREQkExMrIiIiIiIimf4/Myal2W9I1yoAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 1000x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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u0oCEO3bt3d5//7xxx+iqKjIed/T/5012dzF98wzz7gte/DgQbeP+8CBA27LP/vss1U+ZzXhr66SQggRFhbmUldddkulusfEjaiGvEncnn32WZdyffr08Vh3586dXcq//vrrFcpcnrhdc801wmazVRqzxWJxu78uE7exY8e6XKdFixYVysyaNculjEaj8Tg+pWfPni7lFQqF2Lp1a6WxXD6myF/11HXi1rJlS1FWVlZpjNW1c+dOt9fIzc2tUG7ChAluy1U13szdOC53X+7/8Y9/VCizaNEirz5D1eHp+Zw8ebLb8lOnTnVbvnzyOGfOHJfjaWlpwmQyua3zlltucSl/3333uZTz9MV13bp1Pj0H5dVl4vbll1+6lDWbzaJFixYuZevVq1eh3JgxY1zKhIWFuR0fduHCBbeJ9ODBgyuU89dnXwj3r5VMJnObTLt7vOPHj6/0mlX5v//7P5c6b7/99irP8zVxi4+PFzk5OVVep7YTt/vuu89t2fI/nJR3/Phxt+XdfQ79wZ+JW0pKiktd69ev92/AFFQ4qyRRHXA33uDkyZPOKYIv39x1W7x83EPHjh0r3D98+DD69euHN954Az/++CMOHTrkMt2+XC73+bH4Ij8/3+0SCxMmTKj0PmAfT/X999+77C8sLMRff/3lsn/MmDHo3r17pfGo1Wq/1xMITz31FMLCwqpVdvfu3fjnP/+JwYMHIy0tDZGRkZDL5c6Z4Tp37uz2vMtnOf31119dyvTo0QO33HJLpdd391w9/vjjLvu++OILmM1m53133STdjX3yB0/1upvpEwA2b97svO3us15UVIRevXq5/az/+eefLuWrO8apT58+GDhwYLXK+iIuLg5dunSpdGvZsmW169NoNJg4caLLfoVCgUmTJrnsP3/+PE6dOuW8v379epcyQ4cOddvlLT4+HjfffLPL/k2bNjnfX3Xx2R8+fDiaN2/usv+aa65x2VdZ9/bqcDfTZVxcnE91Vsd9992HhISEKsvNnDkTwt5w4PPmzeypwsMC1Z72hwJ3r+vl44DpysIxbkR14PTp0y77srKyvBqLcnkdTzzxhMuXvt9//73CAHi5XI5WrVrhuuuuw4QJE9C3b18vI/evb775xu3Co7fddluF+82bN0fnzp2xc+fOCvvnzZuHe+65p8K+c+fOuR2I7u0XWn/VEwgDBgyoskxx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e+21AYiMKLTFx8fj1VdfrbDvyy+/dLuuJgW/H374ocKkJHK53ON6rXRlYuJGRERBq2fPnvjkk08CHQZRyHrggQcg7Ms/QQgBg8GA5OTkQIdFNTBmzJgKr6XFYql0dla68jBxIyKioBIeHo4ePXrgvffew2+//eYyrTkREdHViLNKEhERERERBTnPK8NSrbDZbMjMzERERARnACIiIiIiuooJIVBcXIyUlBTIZJV3hmTiVscyMzPRoEGDQIdBRERERERB4uzZs6hfv36lZZi41bGIiAgA9heH4zaIiIiIiK5eRUVFaNCggTNHqAwTtzrm6B4ZGRnJxI2IiIiIiKo1hIqzShIREREREQU5Jm5ERERERERBjokbERERERFRkGPiRkREREREFOSYuBEREREREQU5Jm5ERERERERBjokbERERERFRkGPiRkREREREFOSYuBEREREREQU5Jm5ERERERERBjokbERERERFRkGPiRkREREREFOSYuBEREREREQU5RaADICIiIrraCCFgsBigN+uhN+tRZimDyWqC0WKEyWqCyWqCxWaBgIAQolb/2oStxmVtwlZlXVWd4209nkiSVPE+pCrLlH89BITzNgC/3K+yrBd1BiS+GtwPlTjVCjW2TtuKUMLEjYiIiAj2L3NWYYXVZoXFZoHFZoFV2G879lV1v8BQgLNFZ3Gm8AzOFp3FuaJzKDQUOhO08pvjSyQR1T2lVRnoELzGxI2IiIg8stgsMFvNsAorbMIGm7DBarPfrmyf1WaFwWJAsakYxcZiFJuKUWIqgU3YANhbQyRJghACRqsRRosRBosBRqsRFpulQgxCCJSYSpBvyLdvZfkoMhZBkiQoZArIJTnkMjkkSB4Tq+okX47Y6poSSqihhkIooLApILfJIbfKIbPJIAkJjvzOeVtcdht/34at4rHymyQkwOZhP6r319Pt6u6ryTme9l1OSN4nwkISFeq7vG5/3r8a6gqlOBVyBTALIYWJGxERUYBUSEjK8lFiKgEAyCQZZJIMkiTBbDWj2FSMImMRio325EdAQCFTODcJEvRmPUpMJSgxlaDUXAqDxeDS1azMUuasp8hY5KxLJsmciZRN2FBqKoXerEepuRQmqynAz1JwkEkyZ5KokCkgl8mdz3/5fRGqCKRqUxGtj4Y2Swv5cTmkTAmW8xagCFCalVCZVFCalVCa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fErcEhLss/4dPny42uc4ysbHx9f4usXFxc7blY2tK3+s/DmVyc/Pd97+v//7P6SkpODXX39FSUkJCgsLceDAAfTv3x9CCLz44ov44YcfKq3v9ddfR1RUlHNr0KBBteIIFRcNAunF9mS8S3zNWtwyijKw7PAyAKEzKcnxX47DXGpGVMMopPbw/OMBEREREZE/+JS4devWDUIIryb/mDdvHiRJQufOnX25dK1xdMEE4JxEZfDgwZDJ7E9V69atsXz5ciQlJQEAXnrppUrre/7551FYWOjcfOkiGox2XGptaxYpIVpds3Fpn+/8HFZhRd+GfdEmsY0/w6s1B747AABoPa51SIzHIyIiIqLQ5lPiduuttwIA1q1bh3feeafK8u+88w7Wr18PwD4TZU1FREQ4b+v1eo/lyh8rf0516x40aJDbBDM8PBwPPfQQAGDv3r04f/68x/rUajUiIyMrbFcSx/i2LjUc32axWfDZzs8AhE5rm6nUhKM/27vUth3veYwlEREREZG/+JS4jR8/Hh06dIAQAs888wxuvfVWbNq0qcL4NYvFgt9//x1jxozBM888A0mS0LZt2xovjA0AKSkpztsZGRkey5U/Vv6cypQfF9eqVSuP5Vq3bu28XZ017K5U23N9G9+2/MhyZBRnIEGbgFta3eLP0GrNsZXHYNabEd04GsldkgMdDhERERFdBXxaMViSJCxduhR9+vRBVlYWli5diqVLl0KpVCI2NhYAkJeXB7PZDMDe9TAlJQXLli3zqXtZq1atIJPJYLPZsH//fo9LAuzfb5/1LykpyRlPVVq3bg25XA6r1VppufITslzNXeV8nVHyPzv+AwC4u9PdUCvUfourNh383r52W5txba7q156IiIiI6o7Ps0qmpaVh165duPnmmwHYExqTyYTs7GxkZ2fDZDI5k5xbbrkFO3fudC4JUFNarRZ9+vQBAKxatcptGSEEVq9eDQAYMmRItesOCwvDddddB8C+7IAnBw/av7xLkuTz4wlVGaU2ZOkFZBLQMc77t9L5kvP49eSvAIC7O9/t7/BqhanEhKMr7N0k24wLjfF4RERERBT6fGpxc0hMTMQPP/yAo0ePYsWKFdi1axdyc3MB2GeP7Ny5M2688UY0b97cH5cDANx55534/fffsWHDBmzduhU9evSocHzRokU4efIkAGDy5Mle1T1lyhRs2LAB69atw86dO13GuZWUlODjjz8GAPTo0cM5u+bVZvul1rbWMTLolN63PH1/4HvYhA3dU7ujWWwzf4dXK46uOApLmQUxTWOQ1Ckp0OEQERER0VXCr6sGt2jRAo8//jgWLFiAlStXYuXKlViwYAEee+wxvyZtgD1xa9euHYQQGDNmDNatWwfAPivkokWLcM899wAAhg0bhkGDBlU4d+bMmZAkCZIkIT093aXu22+/Hd27d69Qt2O2yUOHDuGmm25CdnY2ZDIZXn31Vb8+rlDimFGya3zN3kbf7P8GADCxbWgsuA2wmyQRERERBYZfWtwCQaFQ4KeffsKAAQOQnp6OwYMHQ6vVwmazwWAwAAA6deqE//73v17XLZPJsGzZMgwaNAgHDx501q1UKlFYWAgAUCqVmD17NgYOHOjXxxVKtvswo+Sp/FPYfG4zZJIM49qM83dotcJYbMSxlccAsJskEREREdUtv7a41bW0tDTs3bsXL774Itq2bQtJkqBUKtGlSxe8/fbb2LJlC2JiYmpUd1JSEnbu3Im3334b3bp1g1KpRFlZGdLS0jB16lTs3LnT2ap3NRJCYOelGSW71mBGyW/3fwsAGJA2AMkRoTEz49Gfj8JisCCuRRzqdagX6HCIiIiI6CoiifLTI/pBeno6cnNzUVZWhqqqdkwCcjUpKipCVFQUCgsLQ3pNt+OFNrT5Xg+VDLh4lw4quXfdBtvNaYf9Ofvx+cjPQ2Ziku9Gf4fDPx5G33/2xcCXr96WViIiIiLyD29yA790lTxy5Ahee+01/PTTTygqKqrWOZIkVVjvjUKLY3xb+ziZ10nbvvP7sD9nP1RyVcis3WYsMuLYL+wmSURERESB4XPi9uOPP+L222+HwWCosoWNrhw7cms+vs0xKcnw5sMRo6lZV9a6dmT5EViNVsRfE4/EtomBDoeIiIiIrjI+JW5nz57FpEmTUFZWhtTUVDz99NPQarW49957IUkS1q5di7y8PGzfvh1fffUVMjMzce2112LmzJmQy2u2YDMFB+eMkl6ObxNCOBO329re5ve4asuJVScAANfccg1nkyQiIiKiOudT4vbBBx9Ar9cjIiICW7duRUpKCg4cOOA8PmDAAADAmDFj8OKLL+Luu+/Gd999hy+++KJGsz1ScLDaBHZdanHzdimALee2IL0gHeGqcIxoMaI2wvM7IQTS/5cOAGg8oHFggyEiIiKiq5JPs0quXbsWkiThwQcfREpKSqVlNRoNFi5ciE6dOuHbb7/FkiVLfLk0BdDhAhtKLYBOAbSM9u4t5Ghtu/mam6FVamsjPL8rSC9A0dkiyBQy1O9VP9DhEBEREdFVyKfEzbF4de/evZ37yncju3zyEZlMhkceeQRCCHz55Ze+XJoCyLF+W+d4GeSy6ncbtNgs+O7AdwBCa9Ht0/87DQBI7Z4KlU4V4GiIiIiI6GrkU+JWWloKAGjQoIFzn1b7dyuKY7Hq8tq0sc/It2fPHl8uTQG056I9cesU7904xfWn1iOnNAfx2ngMbjK4NkKrFekb0wEAjfo1CmwgRERERHTV8ilxi4qKAgAYDAbnvri4OOftEydOuJzjSOZyc3N9uTQFUKbenrilRXg3Scfig4sBALe2uhVKudLvcdUWR4sbEzciIiIiChSfEreWLVsCAE6ePOncFxERgUaN7F9w16xZ43LOr7/+CgCIjo725dIUQFml9mUfUnTVf/vYhA3Ljy4HgJBZuw0ACs8UoiC9AJJcQoPeDao+gYiIiIioFviUuPXq1QsAsGXLlgr7R4wYASEE3nrrLWzYsMG5//vvv8f7778PSZLQp08fXy5NAZSltyduSdrqt7j9lfEXskuyEamORL+0frUVmt85ZpNM6ZoCdYQ6sMEQERER0VXLp8Rt+PDhEELghx9+gNVqde53rOdWUlKCwYMHIyEhAREREbjttttgMBggk8nw9NNP+xw81T0hxN+Jm6b6iduPh38EYF90WyUPnQk+2E2SiIiIiIKBT4lb//79MWPGDEyZMgUZGRnO/Q0bNsSiRYsQFRUFIQQuXryI0tJSCCGgVqvx2WefoWfPnj4HT3Uv3wiY7EPckOxFi9uyI8sAADe3vLkWoqo9jolJ0vqlBTQOIiIiIrq6+bQAtyRJmDFjhttjw4YNw7Fjx7B48WIcOHAAFosFzZs3x7hx45CamurLZSmAsi9NTBKjBsIU1UvcjuQeweHcw1DKlBjWfFhthudXRRlFyD+RD0kmoeG1DQMdDhERERFdxXxK3KoSFxeH++67rzYvQXUs81I3yWRt9RtrHa1tAxsPRKQ6slbiqg2ObpJJnZKgjuT4NiIiIiIKHJ8St6lTpwKwt66NHTvWLwFRcMuuwcQkjvFto1qOqo2Qao1jYpK0/mkBjYOIiIiIyKfEbf78+QCA8ePH+yUYCn6OiUlSqpm4ZZdkY8s5+6yjN7W8qdbiqg2cmISIiIiIgoVPk5MkJCQAAOrVq+eXYCj4ebsUwPIjyyEg0C2lG1IjQ2dsY3FWMS4euQhIQKO+TNyIiIiIKLB8Stxat24NADh9+rRfgqHgl3VpcpLqzijpGN8Wat0kT/92aXxbhySERYcFOBoiIiIiutr5lLhNmjQJQghnl0m68mV7MTlJiakEa0+uBQDcfM3NtRmW37GbJBEREREFE58StylTpmDQoEFYtmwZZs6cCSGEv+KiIJXlTNyqbnFbfXw1jFYjmsY0ReuE1rUdml85EjdOTEJEREREwcCnyUl+//13PPXUU7hw4QJefvllfPfddxg/fjzat2+PmJgYyOXySs+/7rrrfLk81TEhhFdj3H488iMAe2ubJFV/FspAK80pxYWDFwAADfty/TYiIiIiCjyfErf+/ftX+EJ+9OhRvPzyy9U6V5IkWCwWXy5PdazQBBis9ttVtbiZrWasOLoCQOiOb0tslwhtnDbA0RARERER+WEBbnaPvHo4WtuiVYBGUXnitj1zO/IN+YjTxKF3g951EZ7fONZv4/g2IiIiIgoWPiVuGzZs8FccFAIcM0pWp5vk1oytAIDeDXpDLqu8y2ywcY5v65cW2ECIiIiIiC7xKXHr16+fv+KgEJDlxYySjsStR2qPWo3J3/QX9cjZlwMAaHQdW9yIiIiIKDj4NKskXV28mVFy67lLiVv90ErcHOPbElonQJeoC3A0RERERER2TNyo2rKrmbhdKL2AUwWnIEFCt5RudRGa33D9NiIiIiIKRkzcqNqquxSAo5vkNfHXICosqtbj8icmbkREREQUjHwa4zZw4MAanytJEtatW+fL5amOZV+anCSlqsQtRLtJluWXIXtPNgBOTEJEREREwcWnxG3jxo2QJKnSJQEuX3jZUTaUFmQmu0xni1vlDbWhOjHJmd/PAAKIaxmH8KTwQIdDREREROTkU+J23XXXVZmAlZaW4vjx4ygoKIAkSWjRogWSk5N9uSwFgBDCOcatsq6SNmHDXxl/AQi9xI3rtxERERFRsPK5xa26Vq5ciUceeQR5eXn44osv0KdPH18uTXWsyAzoLfbblU1OcvTiURQaC6FRaNCuXrs6is4/uH4bEREREQWrOpucZPjw4di0aRMUCgVGjx6NjIyMuro0+YFjYpJIJaBTek7cHOPbuqR0gULm0+8CdcpQaED2Lvv4Nra4EREREVGwqdNZJZOSkvD4448jNzcXb775Zl1emnyUVWqfmCRZV70ZJUOtm+TZP85C2ARim8UiMjUy0OEQEREREVVQ58sBXHvttQCAFStW1PWlyQfZZZfWcNNcmROTpG9MB8DWNiIiIiIKTnWeuKlUKgBAZmZmXV+afODoKllZi1uZuQx7z+8FEHpLAXD9NiIiIiIKZnWeuG3atAkAoNVq6/rS5IOs0qpnlNyZtRMWmwVJ4UloENmgrkLzmbHYiMwd9h8SODEJEREREQWjOk3cNm/ejFmzZkGSJHTv3r0uL00+cnaVrCRxK99NMpTW6Tv751kIq0B0WjSiGkYFOhwiIiIiIhc+Tfs3a9asKsvYbDbk5+dj+/bt2Lp1K2w2GyRJwuOPP+7LpamOOScnqWbiFkoc49vS+qcFNA4iIiIiIk98StxmzpzpVcuKEAIKhQJvvvkmrr/+el8uTXUsy7n4tudGWsdSABzfRkRERETkXz4vtCWEqPS4JEmIiIhA48aN0a9fP9x7771o3bq1r5elOuacnMRDi9v5kvM4XXgaEiR0Telal6H5xGKwIHO7fXxbo+uYuBERERFRcPIpcbPZbP6Kg4JYsUmg1GK/7Slxc3STbJ3QGpHq0FkHLWtnFmxmG3SJOkQ3jg50OEREREREbtX5rJIUehytbRFKIFzpIXE7F5rj285uPgsAqN+rfkhNqEJEREREVxcmblSlLL29ZbWypQCcE5OE2Pi2c5vPAbAnbkREREREwYqJG1Up+1KLW4qHiUmEENiVvQsA0C2lW53F5SshhDNxa9ArdNadIyIiIqKrj0+J2759+9CkSRM0b94cGRkZVZbPyMhAs2bN0LRpUxw9etSXS1MdytRXvvh2TmkO8sryIJNkuCb+mroMzSdFZ4tQnFkMmUKGlK4pgQ6HiIiIiMgjnxK3hQsXIj09Hc2aNUNqamqV5VNTU9GiRQukp6dj4cKFvlya6lB2FTNKHrxwEADQJKYJNEpNncXlK8f4tnod6kGpVQY4GiIiIiIiz3xK3P73v/9BkiTcdNNN1T5n1KhREEJg3bp1vlya6lBWFS1uBy4cAGCfUTKUcHwbEREREYUKnxI3R3fH9u3bV/uctm3bAgCOHDniy6WpDv09xq3yFrfW8aGZuHF8GxEREREFO58St5KSEgBAeHh4tc9xlC0qKvLl0lSHqppV0pm4hVCLm8VgQdauLABscSMiIiKi4OdT4hYTEwMAyM7OrvY5jrIRERG+XJrq0N9dJd2/XUIxccvckWlfeLueDtFp0YEOh4iIiIioUj4lbs2bNwcArFq1qtrn/PLLLwCApk2b+nJpqiMlZoFis/22u66SF0ov4IL+AiRIaJXQqo6jq7ny3SS58DYRERERBTufErcbbrgBQgh8+umnOHToUJXlDxw4gM8++wySJGHo0KG+XJrqiKO1TacAIlSuCc6hXPvrnhadBq1SW6ex+YITkxARERFRKPEpcXvggQeg0+lgMBgwcOBA/Pzzzx7L/vTTTxg8eDDKysqg0Wjw0EMP+XJpqiPZVc0omRN6M0oKIZxLATBxIyIiIqJQoPDl5Pj4eHzyySe44447kJOTg1GjRqFJkya49tprkZycDADIysrC77//jlOnTkEIAUmSMGfOHNSrV88vD4BqV6HJnrjFqK+ciUkKzxSiJKuEC28TERERUcjwKXEDgNtvvx02mw0PPPAA9Ho9Tpw4gZMnT1YoI8Sl7nY6HebMmYNJkyb5elmqI3qLo6ukh8QtN/QSN0c3yaSOSVBquPA2EREREQU/n7pKOtxxxx04fvw4nnvuObRr1w6APVlztLC1b98eL7zwAo4fP86kLcSUXpqYROshxQ/FFjd2kyQiIiKiUONzi5tDUlISXnvtNbz22muwWCzIy8sDAMTGxkKh8NtlqI45W9yUri1ueWV5yC6xL+/QKj70ZpRk4kZEREREoaJWMiqFQoHExMTaqJrqmN5i/6tz805xtLY1jGqICHVorMtnLjMje5c92WzQq0GAoyEiIiIiqh6/dJWkK1fppRY3rZsxbqHYTTJrRxZsFhvCk8IR1Sgq0OEQEREREVWLT4lbdnY2pk6diqlTpyIjI6PK8hkZGZg6dSruvvtuZ1dKCm6VjXFzJm7xoZO4lR/fxoW3iYiIiChU+JS4ffXVV5g3bx52796N1NTUKsunpqZi9+7dmDdvHhYuXOjLpamOlFYyxi0UW9wyttp/YKjfk+PbiIiIiCh0+JS4rVmzBpIk4dZbb632OePHj4cQAr/88osvl6Y64hjjVmmLWwglbpnbMgEAKd24fhsRERERhQ6fErf9+/cDALp3717tc7p27QoA2Lt3ry+XpjriaR23QkMhMortrVetEkJjRsnSnFIUnikEAKR0YeJGRERERKHDp8Tt4sWLAICEhIRqnxMfH1/hXApujjFuusvWqXa0tqVEpCA6LLpug6qhzO321ra4lnFQR6oDHA0RERERUfX5lLiFh4cDAAoLC6t9TlFREQBApVL5cmmqI55a3ByJW5uENnUeU005ErfUblWPxyQiIiIiCiY+JW7169sneNi8eXO1z/njjz8AoFqTmVRHcXExZs6ciXbt2iE8PBxRUVHo1q0b3nnnHZhMJr9cw+H++++HJEmQJAlpaWl+rTtYlV4a46a5bIxbKI9vS+6aHOBIiIiIiIi841Pi1r9/fwgh8OGHHzpb0ipTVFSEjz76CJIkoX///r5cGgBw+vRptG/fHi+99BL2798PIQSMRiO2b9+Op556Cj179kR+fr7P1wGADRs24NNPP/VLXaGk1OyhxS03tBI3IQRb3IiIiIgoZPmUuN13332QJAlZWVm48cYbcf78eY9ls7OzceONNyIzMxOSJOG+++7z5dKwWCwYOXIk0tPTkZycjF9//RWlpaXQ6/X49ttvERERgV27dmHSpEk+XQcA9Ho97rnnHigUCufkKlcLx6ySnsa4hUriVpxRjJLsEkhyCUkdkwIdDhERERGRV9xM8l59bdq0waOPPor33nsPf/75J5o1a4bx48ejb9++SE62d0fLysrCb7/9hu+//x56vR6SJOGhhx5Cx44dfQp8/vz52LdvHwBgyZIl6NWrFwBAJpNh/PjxsNlsmDhxIlauXIl169Zh0KBBNb7WCy+8gBMnTuCFF17AuXPnsH37dp9iDyWOddy05Vrcio3FOFN4BgDQKj40ZpR0tLYltkmEUqusojQRERERUXDxKXEDgLfffhuFhYWYO3cuSktLMXfuXMydO9elnBD2BGDatGl47733fL0s5s+fDwAYMGCAM2krb8KECXjhhRdw6tQpLFiwoMaJ25YtW/DBBx+gRYsW+Oc//4n777/fp7hDjbPFrdw75VDuIQBAPV09xGnjAhCV9zK22Zcu4Pg2IiIiIgpFPnWVBOwtXF988QV+/PFHZwIlhKiwAUCfPn3w008/4dNPP4UkSZVVWSW9Xu+c5GTYsGFuy0iShKFDhwKwLxReE0ajEVOnToUQAp9++inCwsJqFnCIMtsEzDb7bZ3y79fMOaNkYujMKJm1PQsAx7cRERERUWjyucXN4aabbsJNN92EvLw87N69G7m5uQDs67Z16tQJMTEx/roUDh06BJvNnlG0bdvWYznHsezsbOTl5SE2Ntar68yaNQuHDh3CtGnT0K9fvxrFajQaYTQanferM4lLsHCs4QYA2nLvFEfiFirdJMtPTJLSjQtvExEREVHo8Vvi5hAbG4uBAwf6u9oKMjMznbcrW1ag/LHMzEyvErddu3bhzTffRL169fDWW2/VLFAAr7/+Ol566aUanx9IjvFtcglQlWubTS9IBwA0i20WgKi8V3CqAGV5ZZCr5KjXrl6gwyEiIiIi8prPXSUDobi42Hlbq9V6LFf+WPlzqmKxWDB16lRYLBZ88MEHiI6OrlGcAPD888+jsLDQuZ09e7bGddU1R4ubToEK3VsdE5M0jGoYiLC85hjfVq9DPchV8gBHQ0RERETkPb+3uF0J/vWvf2H37t0YMWIExo0b51NdarUaarXaT5HVLf2lFrfy49uA0EvcnN0ku7KbJBERERGFJr8lbsXFxVi7di327NmD3NxclJWVOScmcUeSJHzxxRc1ulZERITztl6v91iu/LHy51Tm4MGDePnllxEeHo6PP/64RvFdKRwzSpYf32aympBdkg0ghBK3bRzfRkREREShzefEzWaz4eWXX8Y777yD0tLSap0jhPApcUtJ+fsLeEZGBtq3b++2XEZGhttzKvPQQw/BZDLhpZdeQkxMDEpKSioct1js2YwQwnlMrVZDqbzy1gZzjHHTlVvDLaMoAwICarkaCdqEQIVWbcImkLXDPqMkW9yIiIiIKFT5PMbtrrvuwqxZs1BSUgKZTIaEhARnS1v9+vWh0+kqLAsQHx+PRo0aoWHDmrfWtGrVCjKZPfT9+/d7LOc4lpSUVO2JSU6dOgXAPjYtIiLCZfvvf/8LADhz5oxz3+zZs2v8WIKZ/tIYt/ItbuW7Sfq6rENdyD2SC1OJCUqtEgmtgj/RJCIiIiJyx6fEbfXq1Vi4cCEAewKXk5ODtWvXOo+fPn0aRUVFOHToEB555BHIZDLExMTgl19+cSZINaHVatGnTx8AwKpVq9yWEUJg9erVAIAhQ4bU+FpXM0eLm1bpOjFJg6gGAYnJW47xbUmdkiBThORcPEREREREviVuc+fOBQC0adMGX375JWJiYty2wrRs2RLvvfcefvjhB5w4cQLDhw9HYWGhL5fGnXfeCQDYsGEDtm7d6nJ80aJFOHnyJABg8uTJ1a43PT3dZQHx8pvjuo0aNXLue+yxx3x6LMGq9NIYN52HFrdQwPFtRERERHQl8Clx27JlCyRJwkMPPVSt8iNHjsSdd96J06dP44MPPvDl0rjzzjvRrl07CCEwZswYrFu3DoB9zN2iRYtwzz33AACGDRuGQYMGVTh35syZkCQJkiQhPT3dpziuZKVm1zFuzsQtMkQSN84oSURERERXAJ8St5ycHABAixYtnPvk8r/XyTIajS7n3HrrrRBCYOnSpb5cGgqFAj/99BPS0tKQkZGBwYMHQ6fTQafTYdy4cSgqKkKnTp2cY9LIe2WOWSXLzbtypih0WtysZiuyd9lnwEzt5nmhdiIiIiKiYOeXQT/lJ/4oP+2+I7ErLzExEQD80tKVlpaGvXv34sUXX0Tbtm0hSRKUSiW6dOmCt99+G1u2bEFMTIzP17lauZtVMpS6Sl44eAEWgwXqSDVim1VvchoiIiIiomDkU+JWr149AEBeXl6FfSqVCgCwd+9el3NOnz4NADAYDL5c2ikiIgIvvfQS9u3bh5KSEhQVFWH79u148sknnXFcbubMmc7xaWlpaV5db968eRBCXBVdLEsvW8dNCBFSiZtzfFvXFEiy4J8Bk4iIiIjIE58St3bt2gGwL1rtoFAo0KlTJwB/T15S3pw5cwDYJ/eg4Ka/bIxbgaEAJSb72nWhMKukY3xbctfkAEdCREREROQbnxK3/v37QwhRYQkAAJg0aZJzHNudd96JFStW4Pvvv8eNN96ItWvXQpIkjBo1yqfAqfaVXjbG7WzRWQBAvDYeWqU2QFFVn6PFjePbiIiIiCjU+ZS4jR49GoB9LbXz58879993333o3LkzhBBYuHAhbrrpJtx2223ONdcaNmyIZ5991pdLUx24fIxbKHWTtBgsOL/P/p7kjJJEREREFOp8StwaN26MkydPYv/+/YiMjHTuVygU+PXXX3H77bdDoVA4x5MBwI033ojff/+dk4aEAP1l67iFUuJ2fu952Mw2aOO1iGoUFehwiIiIiIh8oqi6SOU8Te4RExODr776Ch9//DGOHTsGi8WCZs2aVZiBkoKb/lKLm1Z5WYtbCKzhVn79NneLwhMRERERhRKfE7eqREREoHPnzrV9GaoFpWb7X+1lLW4hMTGJY0bJbuwmSUREREShzy/ruNGVKZTHuJVvcSMiIiIiCnVM3MijUB3jZio14cLBCwCYuBERERHRlYGJG3lUav57jJvFZkFGcQaA4E/csndlQ9gEIlIiEJESEehwiIiIiIh8xsSN3BJCVGhxyyzOhE3YoJQpkRSeFNjgqpCxzZ5gcnwbEREREV0pmLiRWwYrIC7d1ikkZzfJ+pH1IZOC+22TtT0LALtJEhEREdGVI7i/gVPAlFr+vq1VAGcLzwII/m6SAFvciIiIiOjKw8SN3HKMb1PLAblMCpmJSQwFBuQdywMApHRh4kZEREREVwYmbuRWqM4ombnDvgxAdONoaOO1AY6GiIiIiMg/mLiRWy5ruBWFSOLG9duIiIiI6ArkU+I2depU3H333cjKyqr2ORcuXHCeR8Hr76UA7PdDpsVt26XEjePbiIiIiOgKovDl5Hnz5kGSJDz55JNITk6u1jlFRUXO87744gtfLk+16O+ukpda3C4lbg0iGwQqpGphixsREVFg2Ww2WCwW2Gy2QIdCVKtkMhmUSiUkSaqT6/mUuNGVy5G4aRVAkbEIBYYCAECDqOBN3EovlKLwdCEATkxCRERU1woLC1FUVAS9Xs+kja4aSqUSERERiI+Ph1wur9Vr1XniZjAYAABqtbquL01ecIxx0yok51IA0WHRiFRHBjKsSjla2+JaxkEdyfcXERFRXRBC4Pz588jPz4dWq0V8fDzCwsIgk8nqrCWCqK4JIWC1WlFSUoKCggKUlZWhQYMGtZq81Xni9scffwAA6tWrV9eXJi84xrjplKE3vi21W2qAIyEiIrp65OfnIz8/H0lJSYiJiQl0OER1Kjw8HFFRUThz5gxyc3NrNcfxKnGbNWuW2/0ff/wxEhMTKz3XaDTixIkT+OmnnyBJEvr06ePNpamOlZYb43a2KDQW33a0uCV3rd54SyIiIvKNEAIFBQWIiIhg0kZXLY1Gg8jISBQXFyMxMbHWWpq9StxmzpzpEogQAnPmzKl2HUIIhIWF4emnn/bm0lTH9M6ukuVa3CKDN3ETQrDFjYiIqI5ZLBYYjUYkJCQEOhSigIqIiEBBQQHMZjNUKlWtXMPr5QCEEM5NkiRIklRhn6dNrVYjLS0Nt99+OzZv3owOHTrUxuMhP3HOKqmUQqKrZO6hXJRkl0CuliOpY1KgwyEiIroqWK1WAIBCwfnu6OrmGNtWmxPzePUpuzwQx6DT/fv3o3Xr1n4NjALLuY6bIjTGuB1dcRQA0HhAYygdi88RERFRneAkJHS1q4vPgE8/jzRs2BCSJNVacyAFzt/LAYRGi9uxFccAAM1vbB7gSIiIiIiI/M+nxC09Pd1PYVCwcSwHoJFbca7oHIDgTdwMhQac2WRPLpsPZ+JGRERERFcer8e40dWh1Gz/a7HkwGwzQy7JkRwRnLM1nlhzAsIqEH9NPGKacEYrIiIiIrry+JS4mc1mHDx4EAcPHoTRaHQ5bjAY8OSTT6JBgwbQaDRo3bo1PvzwQ18uSXXEMauk3mhfCiAlIgUKWXAOPD6+8jgAdpMkIiIioiuXT9/Ely5dittuuw2xsbE4d+6cy/HRo0djzZo1EMKeBBw+fBiPPfYYjhw5go8++siXS1Mtc4xx05uyAdgTt2AkbALHVl4a38ZukkRERER0hfKpxW316tUQQuDmm2+GWq2ucGzFihVYvXo1AKB+/foYPXo0UlNTneu+/fnnn75cmmqZY4xbmekCACBRV/kC64GSuSMTpTmlUEWo0PDa4ByDR0REROQv8+bNcy7J5Wm+iT/++AOjR49GUlISFAqFs3xBQUGdxkr+5VOL286dOyFJEvr16+dy7MsvvwQAtGjRAn/99RciIiJQWFiI3r174/Dhw/j888/Ru3dvXy5PtUh/aYyb3pQLAEjQBufCmo7WtqZDmkKukgc4GiIiIqLAWr58OUaPHu1cY4+uHD61uOXk5AAAmjVrVmG/zWbDunXrIEkSpk+fjoiICABAVFQUHn74YQghsHnzZl8uTbXM0eJW4kjcdEGauK1gN0kiIiIihyeffBJWqxUpKSlYsGABduzYgX379mHfvn2IjIwMdHjkA59a3HJz7V/qNRpNhf27d+9GUVERJEnCjTfeWOFY27ZtAQBnz5715dJUy0ovjXErMti7SgZji1vJ+RJkbssEwMSNiIiIrg533XUX7rrrLrfHzpw5g2PH7D9q/+Mf/8Add9xRh5FRbfOpxc0xrs2RwDn89ttvAOxj2xo1alThmKP1jc23wctqEzBeenkKyi4lbkHY4nZ8lX02yeQuyQhPCg9wNERERESBlZGR4bzdokWLAEZCtcGnxM2RlG3durXC/uXLl0OSJFx33XUu5+Tl5QEAEhKCLxEgO8eMkgCQVxa8k5OwmyQRERHR38ovz6VUKgMYCdUGnxK3AQMGQAiBDz/8EIcOHQIA/PTTT9i4cSMAYPjw4S7n7N+/HwCQnByciznT3+PbJAAXy4Kzq6TVbMWJ1ScAcP02IiIiunq4m1XyrrvugiRJGDBggLPcgAEDnOUkScK8efNc6iouLsY777yDgQMHIikpCSqVCpGRkejUqROmT5+OP/74w+Ucm82G9evX46mnnkKfPn0QHx8PpVKJ6OhodOzYEU899RTOnDlTWw//qubTGLfp06fj008/RU5ODtq2bYuYmBjk5+dDCIH69etjzJgxLuesWbMGkiShffv2vlyaapFjfJtGLnChNDi7Sp798yyMRUZo47VI6Rqca8wRERERBau1a9fitttucxnyZDabsXv3buzevRsfffSRcz1mh1mzZuGll15yqa+wsBB79uzBnj17MGfOHCxcuBCjR4+u1cdwtfEpcWvevDm++uorTJ06FaWlpc5ukNHR0fjmm2+gUqkqlM/Ozsavv/4KABg4cKAvl6ZapDfbP6BaeTEKbPZ1AYKtxc3RTbLZsGaQyX1qOCYiIiIKaa+++iqeeuopbNu2DVOnTgVgX5qrW7duzjL169d33t6wYQOGDRsGi8UCuVyOO+64A6NGjULDhg1hMBhw8OBB/PLLL1i+fLnLtSwWC5KTkzF69Gj06tULTZo0QVhYGM6ePYs///wTH3/8MUpKSjBx4kTs3LkTrVq1qv0n4CrhU+IGAGPHjkW/fv2wYsUKZGdnIzk5GTfddBNiY2Ndyu7duxcTJ04E4L4bJQUHR4ubSrL/AqNT6qBRaio5o+45ukk2G9asipJEREQUaEKICmPor2RaBSBJUp1eMzU1FampqRVazxo3buyczb08g8GASZMmwWKxQKvVYsWKFejfv3+FMr1798a0adPczgI/bdo0zJgxw2UMXefOnTFq1ChMnz4dPXv2REZGBl577TV89dVX/nmQ5HviBgCJiYmYMmVKleWGDBmCIUOG+OOSVIscY9yUCM413ErOl+D83vMAgCaDmwQ4GiIiIqqK3gLEzisNdBh1Iu8uHXRBPC/IggULkJlpX07ptddec0naymvQoIHLvrS0tErrr1+/Pp5++mk89thj+OmnnyCEqPNE9krll8SNriyl9t6RUFxK3IJtRslT604BAJI6JUGXoAtwNERERESh4+effwYA6HQ6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",
      "text/plain": [
       "<Figure size 1000x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA24AAAJyCAYAAAC8MpMzAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjMsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvZiW1igAAAAlwSFlzAAAPYQAAD2EBqD+naQAAvhtJREFUeJzs3XlcVPX6B/DPmWETmAF3dnAX9w3LjMQdSxOJ3LdKy7KuldVtuXXt3vastF/qLdu0TENFc0XNpEgrcdfEJQUHB9BQYIadmXN+fyCjyDbD7PB59+LVMPM93/MMDjrPPN/zfAVJkiQQERERERGRw5LZOwAiIiIiIiKqGxM3IiIiIiIiB8fEjYiIiIiIyMExcSMiIiIiInJwTNyIiIiIiIgcHBM3IiIiIiIiB8fEjYiIiIiIyMExcSMiIiIiInJwLvYOoKkRRRGZmZlQKBQQBMHe4RARERERkZ1IkgStVouAgADIZHXX1Ji42VhmZiaCg4PtHQYRERERETmIjIwMBAUF1TmGiZuNKRQKABV/OEql0s7REBERERGRvWg0GgQHBxtyhLowcbOxyuWRSqWSiRsRERERERl1CRWbkxARERERETk4Jm5EREREREQOjokbERERERGRg2PiRkRERERE5OCYuBERERERETk4Jm5EREREREQOjokbERERERGRg2PiRkRERERE5OCYuBERERERETk4Jm5EREREREQOjokbERERERGRg2PiRkRERERE5OCYuBERERERETk4Jm5EREREREQOjokbERERERGRg2PiRkRERERE5OCYuBERERERETk4Jm5EREREREQOjokbERERERGRg2PiRkRERERE5OCYuBERERERETk4Jm5EREREREQOjokbERERERGRg2PiRkRERERE5OCYuBERERERETk4Jm5EREREREQOjokbERERERGRg2PiRkRERERE5OCYuBERERERETk4Jm5EREREREQOjokbERERERGRg2PiRkRERERE5OCYuBERERERETk4Jm5EREREREQOjokbERERERGRg2PiRkRERERE5OCYuBERERERETk4p03cioqKsHPnTrzxxhuIjY1FaGgoBEGAIAhYtGiRRc5x5coVLFy4EF26dEGzZs3QokULREZG4vPPP4ckSRY5BxERERERUX1c7B1AQx08eBD33nuv1eY/fPgwRo8e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mLgRERERERE5OCZuREREREREDo6JGxERERERkYNj4kZEREREROTgmLgRERERERE5OCZuREREREREDo6JGxERERERkYNj4kZEREREROTgmLgRERERERE5OCZuREREREREDo6JGxERERERkYNj4kZEREREROTgmLgRERERERE5OCZuREREREREDo6JGxERERERkYNj4kZEREREROTgmLgRERERERE5OCZuREREREREDo6JGxERERERkYNj4kZEREREROTgmLgRERERERE5OCZuREREREREDs7F3gFQw4miCJ1OB1EU7R0KkdXIZDK4uLhAJuPnTERERNR0MXFzQvn5+dBoNCgqKmLSRk2CTCaDp6cnlEolfHx87B0OERERkc0xcXMikiThypUryM3NhaenJ1q1agUPDw/IZDIIgmDv8IgsTpIkiKKIkpISFBQUIDMzE8XFxWjbti1f80RERNSkMHFzIrm5ucjNzYWfnx+aN29u73CIbMbLywstW7ZEbm4usrOz4ebmhhYtWtg7LCIiIiKb4UUjTkKSJOTl5UGhUDBpoyarefPmUCgUyMvLgyRJ9g6HiIiIyGaYuDkJnU6H0tJSXt9DTZ6Pjw9KS0uh0+nsHQoRERGRzTBxcxJ6vR4A4OLC1a3UtFX+DlT+ThARERE1BUzcnAwbMlBTx98BIiIiaoqYuBERERERETk4Jm5EREREREQOjokbERERERGRg2PiRkRERERE5OCYuBHV4uuvv4YgCBAEAenp6TWO2b9/PyZMmAA/Pz+4uLgYxufl5dk0ViIiIiJq3NhbnqiBtm7digkTJrAtPRERERFZHRM3ogZauHAh9Ho9AgIC8M4776B79+5wc3MDACiVSjtHR0RERESNCRM3olrMnj0bs2fPrvExlUqF8+fPAwBefvllzJgxw4aREREREVFTw2vciBpArVYbbnfu3NmOkRARERFRU8DEjagBSktLDbddXV3tGAkRERERNQVM3IhqUVNXydmzZ0MQBAwdOtQwbujQoYZxgiDg66+/rjaXVqvFBx98gGHDhsHPzw9ubm5QKpXo27cvnnrqKezfv7/aMaIo4qeffsJzzz2HwYMHo1WrVnB1dYWvry/69OmD5557DiqVylpPn4iIiIgcCK9xI7PoRQm/ZuuRXSTBz1PA3X5yyGWCvcNyKD/++COmTJmCnJycKveXl5fj2LFjOHbsGD755BNIklTl8f/85z94/fXXq82Xn5+P48eP4/jx41ixYgW+/fZbTJgwwarPgYiIiIjsi4kbNdjmNB2e/a0U6sKbCUegl4APB7kjpl3jfGm9+eabeO6555CSkoKHH34YAPDll18iIiLCMCYoKMhwe9++fRgzZgx0Oh3kcjlmzJiB8ePHIyQkBCUlJTh9+jR27tyJrVu3VjuXTqeDv78/JkyYgEGDBqF9+/bw8PBARkYGDhw4gOXLl6OgoABTp07FkSNHEB4ebv0fABERERHZReN8d01WtzlNh8k/lkC67f7MQgmTfyzBuhEejTJ5CwwMRGBgYJXqWbt27dCjR49qY0tKSjB9+nTodDp4enpi+/btiIqKqjLmrrvuwpw5c5CRkVHt+Dlz5uDf//53tWvo+vXrh/Hjx+Opp57CnXfeCbVajbfeegvffPONZZ4kERERETmcxvfOuomTJAlFOuueQy9KeOZAabWkDQAkAAKAZw+UYliAzKrLJj1dAEFw3GWZq1evRmZmJgDgrbfeqpa03So4OLjafWFhYXXOHxQUhOeffx5PP/00tmzZAkmSHPrnQUREREQNx8StkSnSAS2+LrRrDBIAdZGE1quLrHqe67O94OXADR23bdsGAPDy8sLcuXPNnk+j0eDatWsoKioyXA/3/+3deVyVdf7//8fhcFiOLIKGqLigaW5UiktpJo58REtnzCzTNNMybcqsKZvUvorjZJlUVmaOk5may6gz5ZZLMuq4lWvjkpUpmOKSCspyBFmu3x8M5wfBUVY5B573243b7eJ6L9frnHdXFy/f1/W+rFarvSwuLo4mTZqU+TgiIiIi4nyUuIlUkIMHDwIQHh5uT7BK6tSpU8TExLBmzRpOnTp1w7qXLl1S4iYiIiJSRSlxq2Ks7rkzURVpx7lsfr8x/ab1Vkd5cV9dc4XFYXXy/3rznoOrW7duqdqvX7+eAQMGYLMVb+by2rVrpTqOiIiIiDg/J//TV0rKZDJV+O2DkSFm6tcwcTbNKPI5NxO5q0tGhujVAKV16dIlBg8ejM1mw8fHh1deeYWoqCiaNm2Kv78/Hh4eAPz73/+mR48eAIVeJyAiIiIiVYcSNykxs1vukv+PbU7HBAWSt7w07Z17Pat90la7dm3OnDnDuXPnStx25cqVXLlyBYAvvviCyMjIIuslJiaWJUQRERERcRFulR2AuKZ+oe4si/SiXo2CyVn9GqYq+yqAkmrXrh0A+/btK/btjnmOHj0KQGBgoMOkLa9vEREREan6lLhJqfULdef4Y1Y2PejFwu6ebHrQi58esypp+5++ffsCYLPZmDt3bonaZmXlvtMhPT2dnJycIuvYbDa9u01ERESkmlDiJmVidjPRrZ47A2+30K2ee7W/PTK/IUOGUL9+fQAmTpzItm3bHNY9c+ZMgd+bNWsG5CZny5cvL1Q/Ozubp59+2v6eOBERERGp2pS4iVQQLy8vFi1ahLu7OzabjcjISEaMGMHq1as5cOAAu3fvZv78+TzyyCM0bdq0QNtHH30UT09PAIYPH85rr71GbGws+/btY8GCBXTq1ImlS5fSpUuXyvhoIiIiInKL6Z42kQrUvXt31q5dy6BBg0hKSmL+/PnMnz//pu1CQkL4+OOPefrpp0lPT2f69OlMnz69QJ2BAwcycuTIGz4DJyIiIiJVg2bcRCpYVFQUJ0+eZNq0aXTu3JlatWphNpvx8/OjXbt2vPjii+zZs6dQu+HDh7N9+3b69evHbbfdhsVioW7duvTq1Yt//OMfLFu2DLO54t6TJyIiIiLOw2To5U+3VHJyMv7+/ly9ehU/P79it0tPTycuLo7Q0FC8vLwqMEIR56ZzQURERKqKkuQGmnETERERERFxckrcREREREREnJwSNxERERERESenxE1ERERERMTJKXETERERERFxckrcREREREREnJwSNxERERERESenxE1ERERERMTJuXzilpKSQnR0NGFhYfj4+ODv70+HDh145513uH79eqn6TEhIYPbs2TzyyCPcfvvteHt74+3tTWhoKIMGDeLf//53OX8KERERERERx0yGYRiVHURpnTp1ioiICOLj4wGwWq1kZ2eTkZEBQNu2bYmNjSUgIKDYfZ4+fZpGjRqR/2uxWq0YhsG1a9fs+0aMGMHcuXMxm80lirkkb0fPLz09nbi4OEJDQ/Hy8irRMUWqEp0LIiIiUlWUJDdw2Rm3rKws+vbtS3x8PHXr1uXrr78mLS0Nm83GsmXL8PX15eDBgwwZMqRE/WZnZ2MYBj169GDBggUkJCSQlpZGamoqR48e5Q9/+AMAn376KdHR0RXwyURERERERApy2cRtwYIFHD58GIB//vOfREZGAuDm5sbAgQP529/+BsBXX31FbGxs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eustjh8/jpeXV5mPKSIiIiK5NOMm4kDr1q05evQor776Ks2aNcPT05PatWvTvXt3lixZwvz588vtWMOGDePEiRNMnDiR8PBwatasidlsJiAggHvuuYcJEyawYcOGQu0mTZrEunXr6NmzJwEBAXh4eBASEkL//v3ZtGkTMTEx5RYjwMSJE9m2bRv9+vUjKCgIT09PGjVqxIgRI9i3bx8PPPAAycnJQG7yKyIiIiLlw2RoJYFbKjk5GX9/f65evYqfn1+x26WnpxMXF0doaKhmMsRpZWZm4u/vz7Vr13j99deZOnVquR9D54KIiIhUFSXJDTTjJiLl5ssvv7QvhnLPPfdUcjQiIiIiVYcSNxEptp9//tlhWXx8PH/6058AqFOnDlFRUbcqLBEREZEqT4uTiEixtWjRggceeIA+ffrQunVratSowa+//sqWLVuYM2cOV65cASAmJgZ3d/3vRURERKS86C8rESm27Oxs1qxZw5o1a4osd3Nz469//StDhgy5xZGJiIiIVG1K3ESk2NasWcP69evZtWsXFy5c4PLly3h6elK/fn0iIiJ47rnnaNOmTWWHKSIiIlLlKHETkWLr06cPffr0qewwRERERKodLU4iIiIiIiLi5JS4iYiIiIiIODklbiIiIiIiIk5OiZuIiIiIiIiTU+LmYgzDqOwQRCqVzgERERGpjpS4uQg3t9yhysnJqeRIRCpXdnY28P+fEyIiIiLVgf7ycREWiwWz2UxaWlplhyJSqWw2G2azGYvFUtmhiIiIiNwyStxchMlkwtfXl+TkZN0qJtWWYRgkJyfj6+uLyWSq7HBEREREbhklbi7E39+fzMxMzp49q+RNqh3DMDh79iyZmZn4+/tXdjgiIiIit5R7ZQcgxWe1WgkJCeHMmTNcu3YNPz8/rFYrZrNZsw9SJRmGQXZ2NjabjeTkZDIzMwkJCcFqtVZ2aCIiIiK3lBI3F+Pr60ujRo24evUqV65c4fLly5UdkkiFM5vN+Pr64u/vr6RNREREqiUlbi7IarVitVoJDg4mMzNTK01Klebm5obFYtGssoiIiFRrStxcmMlkwsPDo7LDEBERERGRCqbFSURERERERJycEjcREREREREn5/KJW0pKCtHR0YSFheHj44O/vz8dOnTgnXfe4fr162Xq+8KFC7z88svccccdeHt7ExgYSNeuXfnkk0+0HL+IiIiIiNwyJsOFM5BTp04RERFBfHw8kLtoR3Z2NhkZGQC0bduW2NhYAgICStz3/v37iYqKsq/a6OPjQ3p6OllZWQBERUWxevXqEj9jlpycjL+/P1evXsXPz6/EcYmIiIiISNVQktzAZWfcsrKy6Nu3L/Hx8dStW5evv/6atLQ0bDYby5Ytw9fXl4MHDzJkyJAS93316lX69OnD5cuXadGiBXv37iUlJYW0tDRmzZqFxWJh48aNvPjii+X/wURERERERH7DZRO3BQsWcPjwYQD++c9/EhkZCeQuHT5w4ED+9re/AfDVV18RGxtbor5jYmI4f/483t7efPXVV7Rv3x4ADw8PnnvuOaZMmQLA3Llz+emnn8rrI4mIiIiIiBTJpRM3gO7du3PvvfcWKn/ssccIDQ0FYOHChSXqO69+/j7yGzNmDD4+PmRnZ7N48eKShi4iIiIiIlIiLpm42Ww2du7cCUDv3r2LrGMymejVqxcAmzZtKnbfP/74I7/88ssN+/bx8aFr164l7ltERERERKQ0XDJxO3bsGDk5OQC0adPGYb28svPnz5OYmFisvo8cOVKo/Y36/v7774vVr4iIiIiISGm5ZOJ29uxZ+3b9+vUd1stflr9NefadnJxMampqsfoWEREREREpDffKDqA0UlJS7NtWq9Vhvfxl+dtURN8+Pj5F1svIyLC/ngByV6yE3IRPRERERESqr7ycoDhvaHPJxM2VvPnmm/ZVKPNr0KBBJUQjIiIiIiLOJiUlBX9//xvWccnEzdfX175ts9kc1stflr9NSfp29CK84vY9fvx4/vSnP9l/z8nJITExkVq1amEymYoVU0VJTk6mQYMGnD59Wi8Dr0I0rlWPxrRq0rhWPRrTqknjWvU405gahkFKSgr16tW7aV2XTNzyf7CEhATuvPPOIuslJCQU2aYkfTsazLy+/fz8HN4mCeDp6Ymnp2eBfTVr1ixWLLeKn59fpf9HK+VP41r1aEyrJo1r1aMxrZo0rlWPs4zpzWba8rjk4iQtW7bEzS039PyrQP5WXllwcDCBgYHF6jv/SpLF6btVq1bF6ldERERERKS0XDJxs1qtdOnSBYANGzYUWccwDDZu3AhAz549i9138+bNadiw4Q37TktLY/v27SXuW0REREREpDRcMnEDGDZsGABbtmzh22+/LVS+YsUKTp48CcATTzxR7H5NJpO9/rJly4iPjy9U56OPPiI1NRWz2czjjz9eiuidg6enJ5MnTy50K6e4No1r1aMxrZo0rlWPxrRq0rhWPa46piajOGtPOqGsrCzatWvH4cOHqV+/PgsWLKBHjx7k5OTwz3/+k6effprk5GR69+7NV199VaBtdHS0faXHuLg4GjduXKD86tWrtGjRgvPnz9OqVSsWLlxIeHg4169fZ968ebz44otcv36dZ599ltmzZ9+qjywiIiIiItWUSy5OAuDu7s7q1avp3r078fHxREZGYrVaycnJIT09HYC2bduyePHiEvft7+/P2rVriYqK4vvvv6d9+/b4+vqSnp5OZmYmkHuL5HvvvVeun0lERERERKQoLnurJEDjxo05dOgQkyZNok2bNphMJiwWC+Hh4cTExPDNN98QEBBQqr7Dw8M5evQoL730Es2aNSMzM5MaNWpw33338fe//53169e73PSqiIiIiIi4Jpe9VVJERERERKS6cOkZNxERERERkepAiVs1lJKSQnR0NGFhYfj4+ODv70+HDh145513uH79emWHJyX02WefYTKZbvqzefPmyg5V/sdms7F+/Xr++te/0r9/fxo1amQfp+jo6GL1ceHCBV5++WXuuOMOvL29CQwMpGvXrnzyySfoRorKUZZxjY6OLtZ5/PPPP9+aDyMAXL58mfnz5zNkyBBatWpFjRo18PT0JCQkhH79+vHFF1/ctA9dc51PWcZV11zndODAAaZMmcLvf/97WrRoQa1atbBYLNSqVYsuXbrwxhtvkJiYeMM+XOG66rKLk0jpnDp1ioiICPtrDqxWKxkZGezbt499+/axePFiYmNjS/1soFQeNzc3brvtNofleibTeezZs4cHHnig1O33799PVFQUly9fBsDHx4eUlBR27NjBjh07WLlyJatXr8bDw6O8QpZiKOu4AlgsFgIDAx2Wu7vrsn0rBQcHk5WVZf/dy8sLi8VCQkICCQkJrFq1it69e7Ny5UqsVmuh9rrmOqeyjivomutsPv30Uz766CP7715eXnh7e5OYmMiuXbvYtWsXM2fOZPXq1dx7772F2rvKdVUzbtVIVlYWffv2JT4+nrp16/L111+TlpaGzWZj2bJl+Pr6cvDgQYYMGVLZoUopNGjQgPPnzzv86dq1a2WHKPkEBATQo0cPxo0bx9KlSwkODi5Wu6tXr9Kn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u3KliIg4FyVuIiJSJf3666+lamez2YrcHxQUdMN2derUAXJv0UxKSrLvT0xMLFZ7gODg4AJt8uStAFm3bt2b9nEjN0v68pK6nJycMh1HRETKX9FrFouIiLi47Oxs+/aaNWto3Lhxsdo5SrDy3uVWWmVtLyIi1ZsSNxERqZJq1apl365ZsyZt2rQpU38XLly44cIfFy5cAHITtICAAPv+vNsP88pvJO82zbw2eWrXrs2ZM2c4d+5cieMWEZGqQbdKiohIlZT3vBjkrhZZVnv37i1WebNmzfDw8LDvz0sY4+LiuHjxosP2mZmZ9mfZfptktmvXDsh9bs/RrZwiIlK1KXETEZEqqV27doSEhAAwd+5c0tPTy9TfggULHJbt3bvXvqBIZGRkgbK83w3DKLTMf34rV67k6tWrRfbRt29fIPf5u7xXD4iISPWixE1ERKokNzc3JkyYAOQub//EE0+QkZHhsH5ycjKzZs1yWL569WqWL19eaH9qaiqjRo2yHzNvO0+/fv2oV68eAG+88QaHDx8u1Mfp06d55ZVXgNwFRH776oEhQ4bY3702ceJEtm3b5jDOM2fOOCwTERHXpWfcRESkyho9ejRff/01X3zxBStWrODAgQOMGjWKjh074u/vT3JyMj/88ANbt25l9erVeHl58fzzzxfZV/v27Rk8eDDbtm1jwIAB+Pn5cejQIaZPn86PP/4IwHPPPcedd95ZoJ2Hhwdz586lb9++JCcn06VLF8aNG0ePHj0wm83s2rWLt956y74KZkxMDLVr1y7Qh5eXF4sWLaJnz57YbDYiIyMZOnQo/fr1IyQkhIyMDH744Qe++uorVq9efcMEVUREXJPJMAyjsoMQERGpKJmZmYwdO5Y5c+Zws0teaGhogZdPR0dHM2XKFCB31q5Hjx7ExcUV2fbhhx9m2bJluLsX/W+iCxYsYNSoUQ6TKrPZzNSpUxk/frzD+DZu3MigQYMKvG6gKL/9nBEREWzbto1u3bqxdetWh+3yf179eSAi4lx0q6SIiFRpFouF2bNn89///pcxY8YQFhaGv78/ZrMZf39/7r77bp566ilWrlzJsWPHHPYTGhrK/v37mTBhAi1btsRqteLv78/999/P559/zsqVKx0mbQDDhg3jhx9+YOzYsbRs2ZIaNWrg7e1N06ZNGTlyJAcPHrxh0gYQFRXFyZMnmTZtGp07d6ZWrVqYzWb8/Pxo164dL774Inv27Cn1dyUiIs5LM24iIiIOaAZKRESchWbcREREREREnJwSNxERERERESenxE1ERERERMTJKXETERERERFxckrcREREREREnJxWlRQREREREXFymnETERERERFxckrcREREREREnJwSNxERERERESenxE1ERERERMTJKXETERERERFxckrcREREREREnJwSNxERERERESenxE1ERERERMTJKXETERERERFxcv8fJZnG//2WGwgAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 1000x700 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "r_ifca = {}\n",
    "r_dfca_gi = {}\n",
    "r_dfca_li = {}\n",
    "\n",
    "r_ifca['test_loss'] = []\n",
    "r_ifca['test_acc'] = []\n",
    "r_ifca['cl_acc'] = []\n",
    "r_ifca['train_loss'] = []\n",
    "for i in range(len(learning_rates)):\n",
    "    r_ifca['test_loss'].append(ifca[i][0])\n",
    "    r_ifca['test_acc'].append(ifca[i][1])\n",
    "    r_ifca['cl_acc'].append(ifca[i][2])\n",
    "    r_ifca['train_loss'].append(ifca[i][3])\n",
    "\n",
    "r_dfca_gi['test_loss'] = []\n",
    "r_dfca_gi['test_acc'] = []\n",
    "r_dfca_gi['cl_acc'] = []\n",
    "r_dfca_gi['train_loss'] = []\n",
    "for i in range(len(learning_rates)):\n",
    "    r_dfca_gi['test_loss'].append(dfca_gi[i][0])\n",
    "    r_dfca_gi['test_acc'].append(dfca_gi[i][1])\n",
    "    r_dfca_gi['cl_acc'].append(dfca_gi[i][2])\n",
    "    r_dfca_gi['train_loss'].append(dfca_gi[i][3])\n",
    "\n",
    "r_dfca_li['test_loss'] = []\n",
    "r_dfca_li['test_acc'] = []\n",
    "r_dfca_li['cl_acc'] = []\n",
    "r_dfca_li['train_loss'] = []\n",
    "for i in range(len(learning_rates)):\n",
    "    r_dfca_li['test_loss'].append(dfca_li[i][0])\n",
    "    r_dfca_li['test_acc'].append(dfca_li[i][1])\n",
    "    r_dfca_li['cl_acc'].append(dfca_li[i][2])\n",
    "    r_dfca_li['train_loss'].append(dfca_li[i][3])\n",
    "\n",
    "dfca_gi_test_acc = [acc_list[-1] for acc_list in r_dfca_gi['test_acc']]\n",
    "dfca_li_test_acc = [acc_list[-1] for acc_list in r_dfca_li['test_acc']]\n",
    "ifca_test_acc = [acc_list[-1] for acc_list in r_ifca['test_acc']]\n",
    "\n",
    "print(\"DFCA-GI Acc: \", dfca_gi_last_acc)\n",
    "print(\"DFCA-LI Acc: \", dfca_li_last_acc)\n",
    "print(\"IFCA Acc: \", ifca_last_acc)\n",
    "\n",
    "print(\"DFCA-GI Avg Acc (%): \", dfca_gi_test_acc)\n",
    "print(\"DFCA-LI Avg Acc (%): \", dfca_li_test_acc)\n",
    "print(\"IFCA Avg Acc (%): \", ifca_test_acc)\n",
    "\n",
    "print(\"DFCA-GI Std: \", dfca_gi_std)\n",
    "print(\"DFCA-LI Std: \", dfca_li_std)\n",
    "print(\"IFCA Std: \", ifca_std)\n",
    "\n",
    "\n",
    "# dfca_gi_test_acc_std = dfca_gi_std[1][-1]\n",
    "# dfca_li_test_acc_std = dfca_li_std[1][-1]\n",
    "# ifca_test_acc_std = ifca_std[1][-1]\n",
    "# dec_ifca_test_acc_std = dec_ifca_std[1][-1]\n",
    "\n",
    "# print(\"DFCA-GI Std: \", dfca_gi_test_acc_std)\n",
    "# print(\"DFCA-LI Std: \", dfca_li_test_acc_std)\n",
    "# print(\"IFCA Std: \", ifca_test_acc_std)\n",
    "# print(\"DEC-IFCA Std: \", dec_ifca_test_acc_std)\n",
    "\n",
    "os.makedirs('graphs', exist_ok=True)\n",
    "\n",
    "for l in range(len(learning_rates)):\n",
    "\n",
    "    plt.figure(figsize=(10,8))\n",
    "    plt.plot(r_ifca['test_loss'][l], label='ifca', color='xkcd:azure')\n",
    "    plt.plot(r_dfca_li['test_loss'][l], label='dfca-li', color='purple')\n",
    "    plt.plot(r_dfca_gi['test_loss'][l], label='dfca-gi', color='green')\n",
    "    plt.xlabel('epoch', fontsize=20)\n",
    "    plt.ylabel('loss', fontsize=20)\n",
    "    plt.title(f'Test Loss per Epoch (lr={learning_rates[l]})', fontsize=22, fontweight='bold')\n",
    "    plt.tick_params(axis='both', which='major', labelsize=18)\n",
    "    plt.legend(fontsize=20)\n",
    "    plt.savefig(os.path.join('graphs', 'test_loss.png'))\n",
    "\n",
    "    plt.figure(figsize=(10,8))\n",
    "    plt.plot(r_ifca['train_loss'][l], label='ifca', color='xkcd:azure')\n",
    "    plt.plot(r_dfca_li['train_loss'][l], label='dfca-li', color='purple')\n",
    "    plt.plot(r_dfca_gi['train_loss'][l], label='dfca-gi', color='green')\n",
    "    plt.xlabel('epoch', fontsize=20)\n",
    "    plt.ylabel('loss', fontsize=20)\n",
    "    plt.title(f'Train Loss per Epoch (lr={learning_rates[l]})', fontsize=22, fontweight='bold')\n",
    "    plt.tick_params(axis='both', which='major', labelsize=18)\n",
    "    plt.legend(fontsize=20)\n",
    "    plt.savefig(os.path.join('graphs', 'train_loss.png'))\n",
    "\n",
    "    plt.figure(figsize=(10,8))\n",
    "    plt.plot(r_ifca['test_acc'][l], label='ifca', color='xkcd:azure')\n",
    "    plt.plot(r_dfca_li['test_acc'][l], label='dfca-li', color='purple')\n",
    "    plt.plot(r_dfca_gi['test_acc'][l], label='dfca-gi', color='green')\n",
    "    plt.xlabel('epoch', fontsize=20)\n",
    "    plt.ylabel('test accuracy', fontsize=20)\n",
    "    plt.title(f'Test Accuracy per Epoch (lr={learning_rates[l]})', fontsize=22, fontweight='bold')\n",
    "    plt.tick_params(axis='both', which='major', labelsize=18)\n",
    "    plt.legend(fontsize=20)\n",
    "    plt.savefig(os.path.join('graphs', 'test_acc.png'))\n",
    "\n",
    "    plt.figure(figsize=(10,8))\n",
    "    plt.ylim([0, 1.1])\n",
    "    plt.plot(r_ifca['cl_acc'][l][:31], label='ifca', color='xkcd:azure', marker='o')\n",
    "    plt.plot(r_dfca_li['cl_acc'][l][:31], label='dfca-li', color='purple', marker='o')\n",
    "    plt.plot(r_dfca_gi['cl_acc'][l][:31], label='dfca-gi', color='green', marker='o')\n",
    "    plt.xlabel('epoch', fontsize=20)\n",
    "    plt.ylabel('cluster acc', fontsize=20)\n",
    "    plt.legend(fontsize=20)\n",
    "    plt.tick_params(axis='both', which='major', labelsize=18)\n",
    "    plt.savefig(os.path.join('graphs', 'cluster_acc.png'))"
   ]
  }
 ],
 "metadata": {
  "accelerator": "GPU",
  "colab": {
   "gpuType": "T4",
   "provenance": []
  },
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.11.11"
  },
  "widgets": {
   "application/vnd.jupyter.widget-state+json": {
    "state": {
     "00c64801e11f49968f4c5a6efa89d8e9": {
      "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
      }
     },
     "035d9462d643423b912c1423e874a744": {
      "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
      }
     },
     "0638c549819d4e40937151c77fe6ed8e": {
      "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
      }
     },
     "0c04380779b84f9ea9f58639f8449b1a": {
      "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_db1638db724947b59a974991d135b6fc",
        "IPY_MODEL_f3b14c8c6a5f4be89f434129e874a9f7",
        "IPY_MODEL_8aaa7f8e3bce468d849fa4e56bc44f48"
       ],
       "layout": "IPY_MODEL_6f6fad5ec9df4003b92547bad3f156b9",
       "tabbable": null,
       "tooltip": null
      }
     },
     "17fb6b005f904589a2ee53a6e45085e8": {
      "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
      }
     },
     "291849e3ca07432e9f546ca527223a3a": {
      "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
      }
     },
     "2e46772bb52047429adf9c4a504deb9e": {
      "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_f27186cce921471599600b1d7ce2d356",
       "max": 3,
       "min": 0,
       "orientation": "horizontal",
       "style": "IPY_MODEL_f2d7c2b11aa14fb1933c9755a0c25187",
       "tabbable": null,
       "tooltip": null,
       "value": 3
      }
     },
     "5e86541334bc4186b8c51d7ed73e68fb": {
      "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
      }
     },
     "6f6fad5ec9df4003b92547bad3f156b9": {
      "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
      }
     },
     "6f76821bdd464d9c96016c48dc84e2d5": {
      "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_a3f2bcefd3b347a78cf6be49ad59f8d0",
        "IPY_MODEL_2e46772bb52047429adf9c4a504deb9e",
        "IPY_MODEL_c10f1d10690a490bb3bae121076505e8"
       ],
       "layout": "IPY_MODEL_00c64801e11f49968f4c5a6efa89d8e9",
       "tabbable": null,
       "tooltip": null
      }
     },
     "8aaa7f8e3bce468d849fa4e56bc44f48": {
      "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_9eee200bc5774275a105d59346a9532a",
       "placeholder": "​",
       "style": "IPY_MODEL_5e86541334bc4186b8c51d7ed73e68fb",
       "tabbable": null,
       "tooltip": null,
       "value": " 3/3 [00:05&lt;00:00,  5.47s/engine]"
      }
     },
     "92448cad6f434be8bb6161abde9aaf97": {
      "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": ""
      }
     },
     "94695ed3050f4eabbc330dbfb8e968d6": {
      "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
      }
     },
     "9839499763904ddfa9da4525b915ca47": {
      "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
      }
     },
     "9eee200bc5774275a105d59346a9532a": {
      "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
      }
     },
     "a3f2bcefd3b347a78cf6be49ad59f8d0": {
      "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_9839499763904ddfa9da4525b915ca47",
       "placeholder": "​",
       "style": "IPY_MODEL_035d9462d643423b912c1423e874a744",
       "tabbable": null,
       "tooltip": null,
       "value": "unknown: 100%"
      }
     },
     "b2236311c42740a5b5abebb0aaa9b5af": {
      "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
      }
     },
     "c10f1d10690a490bb3bae121076505e8": {
      "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_b2236311c42740a5b5abebb0aaa9b5af",
       "placeholder": "​",
       "style": "IPY_MODEL_0638c549819d4e40937151c77fe6ed8e",
       "tabbable": null,
       "tooltip": null,
       "value": " 3/3 [10:15:01&lt;00:00, 2616.07s/tasks]"
      }
     },
     "db1638db724947b59a974991d135b6fc": {
      "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_17fb6b005f904589a2ee53a6e45085e8",
       "placeholder": "​",
       "style": "IPY_MODEL_94695ed3050f4eabbc330dbfb8e968d6",
       "tabbable": null,
       "tooltip": null,
       "value": "100%"
      }
     },
     "f27186cce921471599600b1d7ce2d356": {
      "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
      }
     },
     "f2d7c2b11aa14fb1933c9755a0c25187": {
      "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": ""
      }
     },
     "f3b14c8c6a5f4be89f434129e874a9f7": {
      "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_291849e3ca07432e9f546ca527223a3a",
       "max": 3,
       "min": 0,
       "orientation": "horizontal",
       "style": "IPY_MODEL_92448cad6f434be8bb6161abde9aaf97",
       "tabbable": null,
       "tooltip": null,
       "value": 3
      }
     }
    },
    "version_major": 2,
    "version_minor": 0
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
