{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-20T05:56:31.067583Z",
     "iopub.status.busy": "2025-09-20T05:56:31.066936Z",
     "iopub.status.idle": "2025-09-20T05:56:39.384990Z",
     "shell.execute_reply": "2025-09-20T05:56:39.383866Z"
    },
    "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": "markdown",
   "metadata": {
    "id": "QAghP_o0-tqe"
   },
   "source": [
    "Reads Config file and prepares the arguments you can choose in the config_dfca.json/config_ifca.json"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-20T05:56:39.388793Z",
     "iopub.status.busy": "2025-09-20T05:56:39.388167Z",
     "iopub.status.idle": "2025-09-20T05:56:46.525013Z",
     "shell.execute_reply": "2025-09-20T05:56:46.523995Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Starting 4 engines with <class 'ipyparallel.cluster.launcher.LocalEngineSetLauncher'>\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "baa228d53bbe4be4ad9ad664ca0c87ac",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/4 [00:00<?, ?engine/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "rc = ipp.Cluster(n=4).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-20T05:56:46.528426Z",
     "iopub.status.busy": "2025-09-20T05:56:46.527749Z",
     "iopub.status.idle": "2025-09-20T05:56:46.532117Z",
     "shell.execute_reply": "2025-09-20T05:56:46.531424Z"
    }
   },
   "outputs": [],
   "source": [
    "learning_rates = [0.1]\n",
    "\n",
    "dfca_gi = []\n",
    "ifca = []\n",
    "dfca_li = []\n",
    "d_fedavg_m = []"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-20T05:56:46.534388Z",
     "iopub.status.busy": "2025-09-20T05:56:46.534101Z",
     "iopub.status.idle": "2025-09-20T05:56:46.554178Z",
     "shell.execute_reply": "2025-09-20T05:56:46.553481Z"
    }
   },
   "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(442)\n",
    "seeds = random.sample(range(10000), 5)\n",
    "learning_rates = [0.1]\n",
    "\n",
    "dfca_gi = []\n",
    "dfca_li = []\n",
    "ifca = []\n",
    "d_fedavg_m = []"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "7ADsUSUi-tqf"
   },
   "source": [
    "Running the dfca-gi experiment"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 1000
    },
    "execution": {
     "iopub.execute_input": "2025-09-20T05:56:46.556700Z",
     "iopub.status.busy": "2025-09-20T05:56:46.556414Z",
     "iopub.status.idle": "2025-09-20T05:56:46.565420Z",
     "shell.execute_reply": "2025-09-20T05:56:46.564458Z"
    },
    "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:1\" if torch.cuda.is_available() else \"cpu\")\n",
    "        print(f\"Using device: {device}\")\n",
    "\n",
    "        exp = DFCA.TrainMNISTCluster(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-20T05:56:46.568009Z",
     "iopub.status.busy": "2025-09-20T05:56:46.567755Z",
     "iopub.status.idle": "2025-09-20T05:56:46.577426Z",
     "shell.execute_reply": "2025-09-20T05:56:46.576340Z"
    }
   },
   "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:1\" if torch.cuda.is_available() else \"cpu\")\n",
    "        print(f\"Using device: {device}\")\n",
    "\n",
    "        exp = DFCA.TrainMNISTCluster(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": "markdown",
   "metadata": {},
   "source": [
    "Running the ifca experiment"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-20T05:56:46.579990Z",
     "iopub.status.busy": "2025-09-20T05:56:46.579737Z",
     "iopub.status.idle": "2025-09-20T05:56:46.588122Z",
     "shell.execute_reply": "2025-09-20T05:56:46.587145Z"
    }
   },
   "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:1\" if torch.cuda.is_available() else \"cpu\")\n",
    "        print(f\"Using device: {device}\")\n",
    "\n",
    "        exp = IFCA.TrainMNISTCluster(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": "code",
   "execution_count": 8,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-20T05:56:46.590521Z",
     "iopub.status.busy": "2025-09-20T05:56:46.590268Z",
     "iopub.status.idle": "2025-09-20T05:56:46.599362Z",
     "shell.execute_reply": "2025-09-20T05:56:46.598703Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<AsyncResult(%px): pending>"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "%%px --target 3 --noblock\n",
    "import DFedAvgM as DFedAvgM\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",
    "    config['tau'] = 10\n",
    "    res_final = []\n",
    "\n",
    "    for seed in seeds:\n",
    "        print(f\"---------------------------------DFedAvgM, lr: {lr}, seed: {seed}---------------------------------\")\n",
    "        start_time = time.time()\n",
    "        config['data_seed'] = seed\n",
    "        config['train_seed'] = config['data_seed']\n",
    "\n",
    "        print(\"config:\",config)\n",
    "        device = torch.device(\"cuda:1\" if torch.cuda.is_available() else \"cpu\")\n",
    "        print(f\"Using device: {device}\")\n",
    "\n",
    "        exp = DFedAvgM.TrainMNISTCluster(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",
    "    d_fedavg_m.append(res_mean)\n",
    "\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Results"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "DFCA-GI Experiment Outputs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-20T05:56:46.602542Z",
     "iopub.status.busy": "2025-09-20T05:56:46.602297Z",
     "iopub.status.idle": "2025-09-20T07:17:14.216951Z",
     "shell.execute_reply": "2025-09-20T07:17:14.215522Z"
    }
   },
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "81f9b7df3b344b4c992589a527667e42",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "unknown:   0%|          | 0/4 [00:00<?, ?tasks/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "---------------------------------DFedAvgM, lr: 0.1, seed: 6003---------------------------------\n",
      "config: {'m': 240, 'm_test': 40, 'p': 2, 'n': 500, 'uneven': True, 'local_model_init': False, 'Gp': 0.1, 'graph': 'er', 'agg': 'seq', 'h1': 200, 'num_epochs': 150, 'batch_size': 100, 'tau': 10, 'lr': 0.1, 'data_seed': 6003, 'train_seed': 6003, 'config_override': '', 'project_dir': 'output_dfca_gi'}\n",
      "Using device: cuda:1\n",
      "Epoch -1 tr: l 2.310 a 0.082 clct[np.int64(240), np.int64(0)] cl_acc 0.500  0.958sec\n",
      "Epoch -1 tst: l 2.311 a 0.077 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.122sec\n",
      "Epoch 0 tr: l 2.173 a 0.420 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.872sec(train) 1.025sec(infer)\n",
      "Epoch 0 tst: l 2.193 a 0.383 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.154sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 1 tr: l 2.004 a 0.519 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.045sec(train) 1.003sec(infer)\n",
      "Epoch 1 tst: l 2.031 a 0.480 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.166sec\n",
      "Epoch 2 tr: l 1.799 a 0.577 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.297sec(train) 0.909sec(infer)\n",
      "Epoch 2 tst: l 1.828 a 0.545 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.170sec\n",
      "Epoch 3 tr: l 1.601 a 0.615 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 6.098sec(train) 1.024sec(infer)\n",
      "Epoch 3 tst: l 1.630 a 0.587 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.160sec\n",
      "Epoch 4 tr: l 1.438 a 0.645 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.182sec(train) 0.969sec(infer)\n",
      "Epoch 4 tst: l 1.467 a 0.620 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.175sec\n",
      "Epoch 5 tr: l 1.312 a 0.667 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.017sec(train) 1.042sec(infer)\n",
      "Epoch 5 tst: l 1.341 a 0.644 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.189sec\n",
      "Epoch 6 tr: l 1.214 a 0.684 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.288sec(train) 1.029sec(infer)\n",
      "Epoch 6 tst: l 1.243 a 0.663 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.156sec\n",
      "Epoch 7 tr: l 1.137 a 0.698 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.589sec(train) 1.015sec(infer)\n",
      "Epoch 7 tst: l 1.166 a 0.678 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.155sec\n",
      "Epoch 8 tr: l 1.075 a 0.709 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.769sec(train) 1.051sec(infer)\n",
      "Epoch 8 tst: l 1.104 a 0.690 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.180sec\n",
      "Epoch 9 tr: l 1.025 a 0.719 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.699sec(train) 1.048sec(infer)\n",
      "Epoch 9 tst: l 1.053 a 0.700 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.181sec\n",
      "Epoch 10 tr: l 0.983 a 0.727 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.915sec(train) 1.064sec(infer)\n",
      "Epoch 10 tst: l 1.011 a 0.711 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.167sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 11 tr: l 0.948 a 0.733 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.608sec(train) 0.971sec(infer)\n",
      "Epoch 11 tst: l 0.975 a 0.719 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.166sec\n",
      "Epoch 12 tr: l 0.919 a 0.740 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.629sec(train) 0.994sec(infer)\n",
      "Epoch 12 tst: l 0.945 a 0.725 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.169sec\n",
      "Epoch 13 tr: l 0.894 a 0.745 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.939sec(train) 1.022sec(infer)\n",
      "Epoch 13 tst: l 0.919 a 0.732 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.154sec\n",
      "Epoch 14 tr: l 0.871 a 0.750 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.073sec(train) 0.960sec(infer)\n",
      "Epoch 14 tst: l 0.897 a 0.738 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.180sec\n",
      "Epoch 15 tr: l 0.852 a 0.755 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.777sec(train) 1.069sec(infer)\n",
      "Epoch 15 tst: l 0.877 a 0.742 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.183sec\n",
      "Epoch 16 tr: l 0.834 a 0.759 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.426sec(train) 1.067sec(infer)\n",
      "Epoch 16 tst: l 0.859 a 0.747 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.172sec\n",
      "Epoch 17 tr: l 0.819 a 0.762 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.761sec(train) 0.966sec(infer)\n",
      "Epoch 17 tst: l 0.843 a 0.751 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.177sec\n",
      "Epoch 18 tr: l 0.804 a 0.766 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.145sec(train) 1.125sec(infer)\n",
      "Epoch 18 tst: l 0.828 a 0.756 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.183sec\n",
      "Epoch 19 tr: l 0.791 a 0.769 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.579sec(train) 1.052sec(infer)\n",
      "Epoch 19 tst: l 0.815 a 0.759 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.176sec\n",
      "Epoch 20 tr: l 0.779 a 0.772 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.241sec(train) 1.059sec(infer)\n",
      "Epoch 20 tst: l 0.803 a 0.763 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.175sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 21 tr: l 0.768 a 0.776 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.604sec(train) 0.983sec(infer)\n",
      "Epoch 21 tst: l 0.791 a 0.767 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.164sec\n",
      "Epoch 22 tr: l 0.757 a 0.778 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.553sec(train) 0.943sec(infer)\n",
      "Epoch 22 tst: l 0.781 a 0.771 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.162sec\n",
      "Epoch 23 tr: l 0.747 a 0.781 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.292sec(train) 1.004sec(infer)\n",
      "Epoch 23 tst: l 0.771 a 0.774 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.179sec\n",
      "Epoch 24 tr: l 0.738 a 0.784 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.770sec(train) 1.038sec(infer)\n",
      "Epoch 24 tst: l 0.761 a 0.776 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.166sec\n",
      "Epoch 25 tr: l 0.728 a 0.787 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.067sec(train) 1.051sec(infer)\n",
      "Epoch 25 tst: l 0.752 a 0.779 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.157sec\n",
      "Epoch 26 tr: l 0.720 a 0.790 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.885sec(train) 0.891sec(infer)\n",
      "Epoch 26 tst: l 0.744 a 0.782 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.143sec\n",
      "Epoch 27 tr: l 0.712 a 0.792 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.986sec(train) 0.884sec(infer)\n",
      "Epoch 27 tst: l 0.736 a 0.784 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.145sec\n",
      "Epoch 28 tr: l 0.704 a 0.795 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.319sec(train) 0.917sec(infer)\n",
      "Epoch 28 tst: l 0.728 a 0.787 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.164sec\n",
      "Epoch 29 tr: l 0.696 a 0.797 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.238sec(train) 0.907sec(infer)\n",
      "Epoch 29 tst: l 0.720 a 0.789 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.151sec\n",
      "Epoch 30 tr: l 0.689 a 0.800 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.136sec(train) 0.906sec(infer)\n",
      "Epoch 30 tst: l 0.713 a 0.791 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.151sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 31 tr: l 0.681 a 0.802 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.281sec(train) 0.898sec(infer)\n",
      "Epoch 31 tst: l 0.706 a 0.793 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.139sec\n",
      "Epoch 32 tr: l 0.674 a 0.804 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.135sec(train) 0.963sec(infer)\n",
      "Epoch 32 tst: l 0.699 a 0.795 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.164sec\n",
      "Epoch 33 tr: l 0.667 a 0.806 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.859sec(train) 1.001sec(infer)\n",
      "Epoch 33 tst: l 0.692 a 0.797 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.154sec\n",
      "Epoch 34 tr: l 0.661 a 0.808 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.111sec(train) 0.880sec(infer)\n",
      "Epoch 34 tst: l 0.685 a 0.798 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.146sec\n",
      "Epoch 35 tr: l 0.654 a 0.810 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.203sec(train) 0.923sec(infer)\n",
      "Epoch 35 tst: l 0.679 a 0.801 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.164sec\n",
      "Epoch 36 tr: l 0.647 a 0.812 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.566sec(train) 0.894sec(infer)\n",
      "Epoch 36 tst: l 0.672 a 0.803 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.137sec\n",
      "Epoch 37 tr: l 0.641 a 0.814 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.678sec(train) 0.899sec(infer)\n",
      "Epoch 37 tst: l 0.666 a 0.805 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.133sec\n",
      "Epoch 38 tr: l 0.635 a 0.816 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.397sec(train) 0.901sec(infer)\n",
      "Epoch 38 tst: l 0.660 a 0.807 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.164sec\n",
      "Epoch 39 tr: l 0.628 a 0.818 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.848sec(train) 0.970sec(infer)\n",
      "Epoch 39 tst: l 0.654 a 0.809 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.157sec\n",
      "Epoch 40 tr: l 0.622 a 0.821 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.791sec(train) 0.969sec(infer)\n",
      "Epoch 40 tst: l 0.648 a 0.811 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.136sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 41 tr: l 0.616 a 0.823 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.758sec(train) 1.011sec(infer)\n",
      "Epoch 41 tst: l 0.642 a 0.814 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.151sec\n",
      "Epoch 42 tr: l 0.610 a 0.825 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.968sec(train) 1.157sec(infer)\n",
      "Epoch 42 tst: l 0.636 a 0.817 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.146sec\n",
      "Epoch 43 tr: l 0.604 a 0.827 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 6.483sec(train) 0.982sec(infer)\n",
      "Epoch 43 tst: l 0.630 a 0.819 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.172sec\n",
      "Epoch 44 tr: l 0.598 a 0.829 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.153sec(train) 0.995sec(infer)\n",
      "Epoch 44 tst: l 0.624 a 0.820 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.152sec\n",
      "Epoch 45 tr: l 0.592 a 0.831 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.822sec(train) 0.978sec(infer)\n",
      "Epoch 45 tst: l 0.618 a 0.823 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.162sec\n",
      "Epoch 46 tr: l 0.587 a 0.833 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.945sec(train) 0.920sec(infer)\n",
      "Epoch 46 tst: l 0.613 a 0.824 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.151sec\n",
      "Epoch 47 tr: l 0.581 a 0.835 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.966sec(train) 1.114sec(infer)\n",
      "Epoch 47 tst: l 0.607 a 0.826 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.158sec\n",
      "Epoch 48 tr: l 0.576 a 0.837 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.056sec(train) 1.057sec(infer)\n",
      "Epoch 48 tst: l 0.602 a 0.828 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.148sec\n",
      "Epoch 49 tr: l 0.570 a 0.839 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.609sec(train) 0.939sec(infer)\n",
      "Epoch 49 tst: l 0.596 a 0.829 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.157sec\n",
      "Epoch 50 tr: l 0.565 a 0.841 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.549sec(train) 0.929sec(infer)\n",
      "Epoch 50 tst: l 0.591 a 0.830 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.160sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 51 tr: l 0.559 a 0.842 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.780sec(train) 1.019sec(infer)\n",
      "Epoch 51 tst: l 0.585 a 0.833 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.176sec\n",
      "Epoch 52 tr: l 0.554 a 0.844 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.082sec(train) 1.002sec(infer)\n",
      "Epoch 52 tst: l 0.580 a 0.834 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.159sec\n",
      "Epoch 53 tr: l 0.549 a 0.846 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.800sec(train) 0.950sec(infer)\n",
      "Epoch 53 tst: l 0.575 a 0.836 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.152sec\n",
      "Epoch 54 tr: l 0.544 a 0.847 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.520sec(train) 1.039sec(infer)\n",
      "Epoch 54 tst: l 0.570 a 0.839 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.167sec\n",
      "Epoch 55 tr: l 0.539 a 0.849 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.314sec(train) 0.901sec(infer)\n",
      "Epoch 55 tst: l 0.565 a 0.841 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.157sec\n",
      "Epoch 56 tr: l 0.534 a 0.851 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.425sec(train) 1.040sec(infer)\n",
      "Epoch 56 tst: l 0.560 a 0.843 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.170sec\n",
      "Epoch 57 tr: l 0.529 a 0.852 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 6.063sec(train) 1.048sec(infer)\n",
      "Epoch 57 tst: l 0.555 a 0.844 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.170sec\n",
      "Epoch 58 tr: l 0.524 a 0.854 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.331sec(train) 0.931sec(infer)\n",
      "Epoch 58 tst: l 0.550 a 0.846 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.166sec\n",
      "Epoch 59 tr: l 0.520 a 0.855 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.452sec(train) 0.968sec(infer)\n",
      "Epoch 59 tst: l 0.545 a 0.848 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.134sec\n",
      "Epoch 60 tr: l 0.515 a 0.857 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 6.390sec(train) 0.955sec(infer)\n",
      "Epoch 60 tst: l 0.540 a 0.849 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.173sec\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.858 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.148sec(train) 0.842sec(infer)\n",
      "Epoch 61 tst: l 0.535 a 0.851 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.135sec\n",
      "Epoch 62 tr: l 0.506 a 0.859 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.920sec(train) 0.961sec(infer)\n",
      "Epoch 62 tst: l 0.531 a 0.853 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.161sec\n",
      "Epoch 63 tr: l 0.501 a 0.860 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.467sec(train) 1.059sec(infer)\n",
      "Epoch 63 tst: l 0.526 a 0.854 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.166sec\n",
      "Epoch 64 tr: l 0.497 a 0.862 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.156sec(train) 1.011sec(infer)\n",
      "Epoch 64 tst: l 0.521 a 0.856 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.152sec\n",
      "Epoch 65 tr: l 0.493 a 0.863 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.946sec(train) 0.884sec(infer)\n",
      "Epoch 65 tst: l 0.517 a 0.857 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.143sec\n",
      "Epoch 66 tr: l 0.488 a 0.864 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.724sec(train) 1.080sec(infer)\n",
      "Epoch 66 tst: l 0.513 a 0.859 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.195sec\n",
      "Epoch 67 tr: l 0.484 a 0.865 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.680sec(train) 1.034sec(infer)\n",
      "Epoch 67 tst: l 0.508 a 0.861 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.159sec\n",
      "Epoch 68 tr: l 0.480 a 0.866 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.491sec(train) 1.101sec(infer)\n",
      "Epoch 68 tst: l 0.504 a 0.862 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.196sec\n",
      "Epoch 69 tr: l 0.476 a 0.868 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.574sec(train) 1.046sec(infer)\n",
      "Epoch 69 tst: l 0.500 a 0.863 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.156sec\n",
      "Epoch 70 tr: l 0.472 a 0.869 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.624sec(train) 1.070sec(infer)\n",
      "Epoch 70 tst: l 0.496 a 0.865 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.172sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 71 tr: l 0.468 a 0.870 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.539sec(train) 1.057sec(infer)\n",
      "Epoch 71 tst: l 0.492 a 0.866 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.175sec\n",
      "Epoch 72 tr: l 0.465 a 0.871 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.777sec(train) 1.096sec(infer)\n",
      "Epoch 72 tst: l 0.488 a 0.867 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.176sec\n",
      "Epoch 73 tr: l 0.461 a 0.872 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.738sec(train) 1.092sec(infer)\n",
      "Epoch 73 tst: l 0.484 a 0.868 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.190sec\n",
      "Epoch 74 tr: l 0.457 a 0.873 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 6.091sec(train) 1.230sec(infer)\n",
      "Epoch 74 tst: l 0.480 a 0.869 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.192sec\n",
      "Epoch 75 tr: l 0.454 a 0.874 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 6.330sec(train) 0.899sec(infer)\n",
      "Epoch 75 tst: l 0.476 a 0.870 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.147sec\n",
      "Epoch 76 tr: l 0.450 a 0.875 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.288sec(train) 1.153sec(infer)\n",
      "Epoch 76 tst: l 0.472 a 0.871 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.201sec\n",
      "Epoch 77 tr: l 0.446 a 0.876 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.822sec(train) 0.929sec(infer)\n",
      "Epoch 77 tst: l 0.468 a 0.872 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.182sec\n",
      "Epoch 78 tr: l 0.443 a 0.877 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.907sec(train) 0.906sec(infer)\n",
      "Epoch 78 tst: l 0.465 a 0.873 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.167sec\n",
      "Epoch 79 tr: l 0.440 a 0.878 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.351sec(train) 0.927sec(infer)\n",
      "Epoch 79 tst: l 0.461 a 0.874 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.176sec\n",
      "Epoch 80 tr: l 0.436 a 0.879 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.362sec(train) 0.958sec(infer)\n",
      "Epoch 80 tst: l 0.458 a 0.874 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.155sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 81 tr: l 0.433 a 0.880 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.070sec(train) 1.093sec(infer)\n",
      "Epoch 81 tst: l 0.454 a 0.875 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.191sec\n",
      "Epoch 82 tr: l 0.430 a 0.881 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.509sec(train) 0.972sec(infer)\n",
      "Epoch 82 tst: l 0.451 a 0.876 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.183sec\n",
      "Epoch 83 tr: l 0.427 a 0.882 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.603sec(train) 0.887sec(infer)\n",
      "Epoch 83 tst: l 0.448 a 0.877 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.146sec\n",
      "Epoch 84 tr: l 0.424 a 0.883 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.117sec(train) 0.927sec(infer)\n",
      "Epoch 84 tst: l 0.444 a 0.878 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.183sec\n",
      "Epoch 85 tr: l 0.421 a 0.884 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 6.514sec(train) 1.075sec(infer)\n",
      "Epoch 85 tst: l 0.441 a 0.879 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.157sec\n",
      "Epoch 86 tr: l 0.418 a 0.885 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 6.130sec(train) 1.029sec(infer)\n",
      "Epoch 86 tst: l 0.438 a 0.880 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.180sec\n",
      "Epoch 87 tr: l 0.415 a 0.885 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.810sec(train) 0.922sec(infer)\n",
      "Epoch 87 tst: l 0.435 a 0.881 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.155sec\n",
      "Epoch 88 tr: l 0.412 a 0.886 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.418sec(train) 0.947sec(infer)\n",
      "Epoch 88 tst: l 0.432 a 0.882 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.168sec\n",
      "Epoch 89 tr: l 0.409 a 0.887 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 6.133sec(train) 0.970sec(infer)\n",
      "Epoch 89 tst: l 0.429 a 0.883 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.171sec\n",
      "Epoch 90 tr: l 0.406 a 0.888 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.258sec(train) 0.808sec(infer)\n",
      "Epoch 90 tst: l 0.426 a 0.884 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.114sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 91 tr: l 0.403 a 0.888 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.680sec(train) 0.952sec(infer)\n",
      "Epoch 91 tst: l 0.423 a 0.885 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.155sec\n",
      "Epoch 92 tr: l 0.400 a 0.889 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.485sec(train) 0.946sec(infer)\n",
      "Epoch 92 tst: l 0.420 a 0.885 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.155sec\n",
      "Epoch 93 tr: l 0.398 a 0.890 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.672sec(train) 0.945sec(infer)\n",
      "Epoch 93 tst: l 0.417 a 0.886 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.164sec\n",
      "Epoch 94 tr: l 0.395 a 0.891 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 6.107sec(train) 0.979sec(infer)\n",
      "Epoch 94 tst: l 0.414 a 0.887 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.168sec\n",
      "Epoch 95 tr: l 0.393 a 0.891 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.457sec(train) 0.963sec(infer)\n",
      "Epoch 95 tst: l 0.411 a 0.888 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.143sec\n",
      "Epoch 96 tr: l 0.390 a 0.892 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 6.004sec(train) 0.907sec(infer)\n",
      "Epoch 96 tst: l 0.409 a 0.889 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.165sec\n",
      "Epoch 97 tr: l 0.388 a 0.893 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.910sec(train) 0.954sec(infer)\n",
      "Epoch 97 tst: l 0.406 a 0.890 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.158sec\n",
      "Epoch 98 tr: l 0.385 a 0.894 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.909sec(train) 0.971sec(infer)\n",
      "Epoch 98 tst: l 0.403 a 0.890 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.158sec\n",
      "Epoch 99 tr: l 0.383 a 0.894 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.424sec(train) 0.920sec(infer)\n",
      "Epoch 99 tst: l 0.401 a 0.891 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.152sec\n",
      "Epoch 100 tr: l 0.380 a 0.895 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.966sec(train) 0.957sec(infer)\n",
      "Epoch 100 tst: l 0.398 a 0.892 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.151sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 101 tr: l 0.378 a 0.896 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.326sec(train) 1.025sec(infer)\n",
      "Epoch 101 tst: l 0.396 a 0.893 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.154sec\n",
      "Epoch 102 tr: l 0.376 a 0.896 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.696sec(train) 0.933sec(infer)\n",
      "Epoch 102 tst: l 0.393 a 0.893 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.154sec\n",
      "Epoch 103 tr: l 0.373 a 0.897 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.826sec(train) 0.978sec(infer)\n",
      "Epoch 103 tst: l 0.391 a 0.894 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.164sec\n",
      "Epoch 104 tr: l 0.371 a 0.897 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.472sec(train) 1.122sec(infer)\n",
      "Epoch 104 tst: l 0.388 a 0.895 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.173sec\n",
      "Epoch 105 tr: l 0.369 a 0.898 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.199sec(train) 1.091sec(infer)\n",
      "Epoch 105 tst: l 0.386 a 0.895 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.188sec\n",
      "Epoch 106 tr: l 0.367 a 0.898 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 6.123sec(train) 1.187sec(infer)\n",
      "Epoch 106 tst: l 0.384 a 0.895 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.194sec\n",
      "Epoch 107 tr: l 0.364 a 0.899 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.936sec(train) 1.015sec(infer)\n",
      "Epoch 107 tst: l 0.381 a 0.896 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.178sec\n",
      "Epoch 108 tr: l 0.362 a 0.900 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.763sec(train) 1.089sec(infer)\n",
      "Epoch 108 tst: l 0.379 a 0.897 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.179sec\n",
      "Epoch 109 tr: l 0.360 a 0.900 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.766sec(train) 1.054sec(infer)\n",
      "Epoch 109 tst: l 0.377 a 0.897 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.178sec\n",
      "Epoch 110 tr: l 0.358 a 0.900 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.513sec(train) 1.035sec(infer)\n",
      "Epoch 110 tst: l 0.375 a 0.897 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.174sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 111 tr: l 0.356 a 0.901 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.356sec(train) 0.899sec(infer)\n",
      "Epoch 111 tst: l 0.373 a 0.898 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.171sec\n",
      "Epoch 112 tr: l 0.354 a 0.901 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.545sec(train) 0.984sec(infer)\n",
      "Epoch 112 tst: l 0.371 a 0.898 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.168sec\n",
      "Epoch 113 tr: l 0.352 a 0.902 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.589sec(train) 1.049sec(infer)\n",
      "Epoch 113 tst: l 0.368 a 0.899 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.181sec\n",
      "Epoch 114 tr: l 0.350 a 0.902 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 6.249sec(train) 0.940sec(infer)\n",
      "Epoch 114 tst: l 0.366 a 0.899 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.162sec\n",
      "Epoch 115 tr: l 0.348 a 0.903 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.367sec(train) 0.968sec(infer)\n",
      "Epoch 115 tst: l 0.364 a 0.900 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.157sec\n",
      "Epoch 116 tr: l 0.346 a 0.903 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.848sec(train) 1.047sec(infer)\n",
      "Epoch 116 tst: l 0.362 a 0.900 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.175sec\n",
      "Epoch 117 tr: l 0.345 a 0.904 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.834sec(train) 0.977sec(infer)\n",
      "Epoch 117 tst: l 0.360 a 0.901 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.174sec\n",
      "Epoch 118 tr: l 0.343 a 0.904 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.629sec(train) 0.962sec(infer)\n",
      "Epoch 118 tst: l 0.358 a 0.901 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.151sec\n",
      "Epoch 119 tr: l 0.341 a 0.905 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.483sec(train) 1.090sec(infer)\n",
      "Epoch 119 tst: l 0.357 a 0.901 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.185sec\n",
      "Epoch 120 tr: l 0.339 a 0.905 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.666sec(train) 1.087sec(infer)\n",
      "Epoch 120 tst: l 0.355 a 0.902 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.161sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 121 tr: l 0.337 a 0.906 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 6.154sec(train) 1.056sec(infer)\n",
      "Epoch 121 tst: l 0.353 a 0.902 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.176sec\n",
      "Epoch 122 tr: l 0.336 a 0.906 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 6.296sec(train) 1.047sec(infer)\n",
      "Epoch 122 tst: l 0.351 a 0.903 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.159sec\n",
      "Epoch 123 tr: l 0.334 a 0.906 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.198sec(train) 0.889sec(infer)\n",
      "Epoch 123 tst: l 0.349 a 0.903 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.150sec\n",
      "Epoch 124 tr: l 0.332 a 0.907 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.541sec(train) 1.141sec(infer)\n",
      "Epoch 124 tst: l 0.347 a 0.904 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.165sec\n",
      "Epoch 125 tr: l 0.330 a 0.907 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.580sec(train) 0.955sec(infer)\n",
      "Epoch 125 tst: l 0.346 a 0.904 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.132sec\n",
      "Epoch 126 tr: l 0.329 a 0.908 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.698sec(train) 0.960sec(infer)\n",
      "Epoch 126 tst: l 0.344 a 0.905 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.175sec\n",
      "Epoch 127 tr: l 0.327 a 0.908 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.586sec(train) 1.037sec(infer)\n",
      "Epoch 127 tst: l 0.342 a 0.905 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.173sec\n",
      "Epoch 128 tr: l 0.325 a 0.909 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.612sec(train) 1.088sec(infer)\n",
      "Epoch 128 tst: l 0.341 a 0.906 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.174sec\n",
      "Epoch 129 tr: l 0.324 a 0.909 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.858sec(train) 1.000sec(infer)\n",
      "Epoch 129 tst: l 0.339 a 0.906 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.144sec\n",
      "Epoch 130 tr: l 0.322 a 0.909 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.912sec(train) 1.008sec(infer)\n",
      "Epoch 130 tst: l 0.337 a 0.906 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.169sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 131 tr: l 0.321 a 0.910 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.934sec(train) 0.960sec(infer)\n",
      "Epoch 131 tst: l 0.336 a 0.906 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.144sec\n",
      "Epoch 132 tr: l 0.319 a 0.910 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.475sec(train) 0.903sec(infer)\n",
      "Epoch 132 tst: l 0.334 a 0.907 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.153sec\n",
      "Epoch 133 tr: l 0.318 a 0.910 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.235sec(train) 0.916sec(infer)\n",
      "Epoch 133 tst: l 0.332 a 0.907 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.152sec\n",
      "Epoch 134 tr: l 0.316 a 0.911 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.625sec(train) 0.918sec(infer)\n",
      "Epoch 134 tst: l 0.331 a 0.907 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.155sec\n",
      "Epoch 135 tr: l 0.315 a 0.911 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.774sec(train) 1.107sec(infer)\n",
      "Epoch 135 tst: l 0.329 a 0.908 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.165sec\n",
      "Epoch 136 tr: l 0.313 a 0.912 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 6.160sec(train) 0.956sec(infer)\n",
      "Epoch 136 tst: l 0.328 a 0.908 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.167sec\n",
      "Epoch 137 tr: l 0.312 a 0.912 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.468sec(train) 1.080sec(infer)\n",
      "Epoch 137 tst: l 0.326 a 0.909 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.235sec\n",
      "Epoch 138 tr: l 0.310 a 0.912 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.565sec(train) 1.075sec(infer)\n",
      "Epoch 138 tst: l 0.325 a 0.909 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.158sec\n",
      "Epoch 139 tr: l 0.309 a 0.912 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.496sec(train) 0.859sec(infer)\n",
      "Epoch 139 tst: l 0.323 a 0.909 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.140sec\n",
      "Epoch 140 tr: l 0.307 a 0.913 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.358sec(train) 0.931sec(infer)\n",
      "Epoch 140 tst: l 0.322 a 0.910 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.179sec\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.913 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.685sec(train) 0.947sec(infer)\n",
      "Epoch 141 tst: l 0.320 a 0.910 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.170sec\n",
      "Epoch 142 tr: l 0.305 a 0.913 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.326sec(train) 1.039sec(infer)\n",
      "Epoch 142 tst: l 0.319 a 0.911 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.167sec\n",
      "Epoch 143 tr: l 0.303 a 0.914 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.391sec(train) 1.050sec(infer)\n",
      "Epoch 143 tst: l 0.318 a 0.911 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.172sec\n",
      "Epoch 144 tr: l 0.302 a 0.914 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.476sec(train) 0.982sec(infer)\n",
      "Epoch 144 tst: l 0.316 a 0.911 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.172sec\n",
      "Epoch 145 tr: l 0.300 a 0.914 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.003sec(train) 1.035sec(infer)\n",
      "Epoch 145 tst: l 0.315 a 0.911 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.169sec\n",
      "Epoch 146 tr: l 0.299 a 0.915 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.584sec(train) 1.123sec(infer)\n",
      "Epoch 146 tst: l 0.313 a 0.912 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.167sec\n",
      "Epoch 147 tr: l 0.298 a 0.915 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.937sec(train) 1.023sec(infer)\n",
      "Epoch 147 tst: l 0.312 a 0.912 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.166sec\n",
      "Epoch 148 tr: l 0.297 a 0.915 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.185sec(train) 0.994sec(infer)\n",
      "Epoch 148 tst: l 0.311 a 0.912 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.163sec\n",
      "Epoch 149 tr: l 0.295 a 0.916 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.591sec(train) 0.786sec(infer)\n",
      "Epoch 149 tst: l 0.310 a 0.913 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.143sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "---train cluster Ended in 0.28 hour (1006.358 sec) \n",
      "---------------------------------DFedAvgM, lr: 0.1, seed: 7293---------------------------------\n",
      "config: {'m': 240, 'm_test': 40, 'p': 2, 'n': 500, 'uneven': True, 'local_model_init': False, 'Gp': 0.1, 'graph': 'er', 'agg': 'seq', 'h1': 200, 'num_epochs': 150, 'batch_size': 100, 'tau': 10, 'lr': 0.1, 'data_seed': 7293, 'train_seed': 7293, 'config_override': '', 'project_dir': 'output_dfca_gi'}\n",
      "Using device: cuda:1\n",
      "Epoch -1 tr: l 2.307 a 0.122 clct[np.int64(240), np.int64(0)] cl_acc 0.500  0.822sec\n",
      "Epoch -1 tst: l 2.306 a 0.123 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.187sec\n",
      "Epoch 0 tr: l 2.171 a 0.411 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.697sec(train) 0.983sec(infer)\n",
      "Epoch 0 tst: l 2.191 a 0.374 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.175sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 1 tr: l 2.006 a 0.522 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.868sec(train) 1.074sec(infer)\n",
      "Epoch 1 tst: l 2.032 a 0.479 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.150sec\n",
      "Epoch 2 tr: l 1.797 a 0.578 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.259sec(train) 0.993sec(infer)\n",
      "Epoch 2 tst: l 1.824 a 0.540 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.173sec\n",
      "Epoch 3 tr: l 1.591 a 0.621 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.502sec(train) 1.019sec(infer)\n",
      "Epoch 3 tst: l 1.616 a 0.591 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.167sec\n",
      "Epoch 4 tr: l 1.424 a 0.652 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.061sec(train) 0.957sec(infer)\n",
      "Epoch 4 tst: l 1.446 a 0.629 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.161sec\n",
      "Epoch 5 tr: l 1.296 a 0.674 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.336sec(train) 1.049sec(infer)\n",
      "Epoch 5 tst: l 1.316 a 0.657 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.165sec\n",
      "Epoch 6 tr: l 1.198 a 0.690 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.075sec(train) 0.921sec(infer)\n",
      "Epoch 6 tst: l 1.215 a 0.675 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.151sec\n",
      "Epoch 7 tr: l 1.122 a 0.702 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.637sec(train) 0.991sec(infer)\n",
      "Epoch 7 tst: l 1.137 a 0.689 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.177sec\n",
      "Epoch 8 tr: l 1.061 a 0.712 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.603sec(train) 0.905sec(infer)\n",
      "Epoch 8 tst: l 1.074 a 0.701 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.156sec\n",
      "Epoch 9 tr: l 1.012 a 0.720 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.060sec(train) 0.971sec(infer)\n",
      "Epoch 9 tst: l 1.023 a 0.710 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.149sec\n",
      "Epoch 10 tr: l 0.972 a 0.728 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.670sec(train) 0.897sec(infer)\n",
      "Epoch 10 tst: l 0.981 a 0.718 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.168sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 11 tr: l 0.938 a 0.735 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.751sec(train) 1.013sec(infer)\n",
      "Epoch 11 tst: l 0.946 a 0.724 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.168sec\n",
      "Epoch 12 tr: l 0.909 a 0.741 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.063sec(train) 1.079sec(infer)\n",
      "Epoch 12 tst: l 0.916 a 0.731 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.170sec\n",
      "Epoch 13 tr: l 0.884 a 0.746 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.232sec(train) 1.063sec(infer)\n",
      "Epoch 13 tst: l 0.890 a 0.737 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.182sec\n",
      "Epoch 14 tr: l 0.862 a 0.751 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.969sec(train) 0.970sec(infer)\n",
      "Epoch 14 tst: l 0.867 a 0.742 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.150sec\n",
      "Epoch 15 tr: l 0.843 a 0.756 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.299sec(train) 1.010sec(infer)\n",
      "Epoch 15 tst: l 0.847 a 0.748 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.170sec\n",
      "Epoch 16 tr: l 0.826 a 0.760 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.759sec(train) 1.048sec(infer)\n",
      "Epoch 16 tst: l 0.829 a 0.752 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.166sec\n",
      "Epoch 17 tr: l 0.810 a 0.764 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.988sec(train) 0.957sec(infer)\n",
      "Epoch 17 tst: l 0.813 a 0.757 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.175sec\n",
      "Epoch 18 tr: l 0.796 a 0.768 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.205sec(train) 1.078sec(infer)\n",
      "Epoch 18 tst: l 0.798 a 0.761 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.181sec\n",
      "Epoch 19 tr: l 0.783 a 0.771 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.299sec(train) 0.952sec(infer)\n",
      "Epoch 19 tst: l 0.785 a 0.764 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.153sec\n",
      "Epoch 20 tr: l 0.771 a 0.775 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.470sec(train) 0.952sec(infer)\n",
      "Epoch 20 tst: l 0.772 a 0.769 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.175sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 21 tr: l 0.759 a 0.778 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.549sec(train) 0.841sec(infer)\n",
      "Epoch 21 tst: l 0.761 a 0.772 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.177sec\n",
      "Epoch 22 tr: l 0.748 a 0.781 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.603sec(train) 0.912sec(infer)\n",
      "Epoch 22 tst: l 0.750 a 0.775 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.203sec\n",
      "Epoch 23 tr: l 0.738 a 0.784 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.505sec(train) 1.002sec(infer)\n",
      "Epoch 23 tst: l 0.740 a 0.778 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.200sec\n",
      "Epoch 24 tr: l 0.729 a 0.787 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.965sec(train) 0.993sec(infer)\n",
      "Epoch 24 tst: l 0.730 a 0.782 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.163sec\n",
      "Epoch 25 tr: l 0.720 a 0.789 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.007sec(train) 0.993sec(infer)\n",
      "Epoch 25 tst: l 0.721 a 0.785 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.166sec\n",
      "Epoch 26 tr: l 0.711 a 0.792 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.361sec(train) 0.815sec(infer)\n",
      "Epoch 26 tst: l 0.712 a 0.788 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.133sec\n",
      "Epoch 27 tr: l 0.702 a 0.795 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.443sec(train) 0.892sec(infer)\n",
      "Epoch 27 tst: l 0.704 a 0.792 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.148sec\n",
      "Epoch 28 tr: l 0.694 a 0.797 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.219sec(train) 0.928sec(infer)\n",
      "Epoch 28 tst: l 0.696 a 0.794 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.158sec\n",
      "Epoch 29 tr: l 0.686 a 0.800 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.741sec(train) 0.980sec(infer)\n",
      "Epoch 29 tst: l 0.688 a 0.796 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.162sec\n",
      "Epoch 30 tr: l 0.678 a 0.803 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.075sec(train) 1.006sec(infer)\n",
      "Epoch 30 tst: l 0.680 a 0.799 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.163sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 31 tr: l 0.671 a 0.805 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.345sec(train) 0.980sec(infer)\n",
      "Epoch 31 tst: l 0.673 a 0.801 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.151sec\n",
      "Epoch 32 tr: l 0.664 a 0.807 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.639sec(train) 0.917sec(infer)\n",
      "Epoch 32 tst: l 0.666 a 0.804 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.152sec\n",
      "Epoch 33 tr: l 0.656 a 0.810 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.883sec(train) 1.035sec(infer)\n",
      "Epoch 33 tst: l 0.659 a 0.807 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.156sec\n",
      "Epoch 34 tr: l 0.649 a 0.812 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.715sec(train) 0.998sec(infer)\n",
      "Epoch 34 tst: l 0.652 a 0.809 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.167sec\n",
      "Epoch 35 tr: l 0.642 a 0.814 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.655sec(train) 1.167sec(infer)\n",
      "Epoch 35 tst: l 0.645 a 0.811 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.158sec\n",
      "Epoch 36 tr: l 0.636 a 0.816 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.217sec(train) 1.023sec(infer)\n",
      "Epoch 36 tst: l 0.639 a 0.813 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.173sec\n",
      "Epoch 37 tr: l 0.629 a 0.818 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.462sec(train) 1.028sec(infer)\n",
      "Epoch 37 tst: l 0.632 a 0.816 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.173sec\n",
      "Epoch 38 tr: l 0.623 a 0.821 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.898sec(train) 1.078sec(infer)\n",
      "Epoch 38 tst: l 0.626 a 0.818 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.184sec\n",
      "Epoch 39 tr: l 0.616 a 0.823 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.768sec(train) 0.980sec(infer)\n",
      "Epoch 39 tst: l 0.620 a 0.820 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.165sec\n",
      "Epoch 40 tr: l 0.610 a 0.825 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.342sec(train) 0.985sec(infer)\n",
      "Epoch 40 tst: l 0.613 a 0.822 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.175sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 41 tr: l 0.604 a 0.827 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.489sec(train) 1.034sec(infer)\n",
      "Epoch 41 tst: l 0.607 a 0.824 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.165sec\n",
      "Epoch 42 tr: l 0.597 a 0.829 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.891sec(train) 0.997sec(infer)\n",
      "Epoch 42 tst: l 0.601 a 0.826 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.166sec\n",
      "Epoch 43 tr: l 0.591 a 0.831 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.210sec(train) 1.045sec(infer)\n",
      "Epoch 43 tst: l 0.595 a 0.827 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.177sec\n",
      "Epoch 44 tr: l 0.586 a 0.834 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.933sec(train) 1.053sec(infer)\n",
      "Epoch 44 tst: l 0.590 a 0.829 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.177sec\n",
      "Epoch 45 tr: l 0.580 a 0.835 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.795sec(train) 0.948sec(infer)\n",
      "Epoch 45 tst: l 0.584 a 0.831 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.152sec\n",
      "Epoch 46 tr: l 0.574 a 0.838 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.659sec(train) 1.203sec(infer)\n",
      "Epoch 46 tst: l 0.578 a 0.833 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.168sec\n",
      "Epoch 47 tr: l 0.568 a 0.840 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.675sec(train) 1.008sec(infer)\n",
      "Epoch 47 tst: l 0.573 a 0.835 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.179sec\n",
      "Epoch 48 tr: l 0.563 a 0.841 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.480sec(train) 1.009sec(infer)\n",
      "Epoch 48 tst: l 0.567 a 0.837 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.175sec\n",
      "Epoch 49 tr: l 0.557 a 0.843 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.350sec(train) 1.112sec(infer)\n",
      "Epoch 49 tst: l 0.562 a 0.839 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.179sec\n",
      "Epoch 50 tr: l 0.552 a 0.845 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.668sec(train) 0.949sec(infer)\n",
      "Epoch 50 tst: l 0.556 a 0.842 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.174sec\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.847 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.091sec(train) 1.017sec(infer)\n",
      "Epoch 51 tst: l 0.551 a 0.843 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.174sec\n",
      "Epoch 52 tr: l 0.541 a 0.848 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.293sec(train) 1.084sec(infer)\n",
      "Epoch 52 tst: l 0.546 a 0.846 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.178sec\n",
      "Epoch 53 tr: l 0.536 a 0.850 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.501sec(train) 0.995sec(infer)\n",
      "Epoch 53 tst: l 0.541 a 0.847 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.161sec\n",
      "Epoch 54 tr: l 0.531 a 0.852 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.552sec(train) 0.929sec(infer)\n",
      "Epoch 54 tst: l 0.536 a 0.848 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.159sec\n",
      "Epoch 55 tr: l 0.526 a 0.853 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.780sec(train) 0.999sec(infer)\n",
      "Epoch 55 tst: l 0.531 a 0.850 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.171sec\n",
      "Epoch 56 tr: l 0.521 a 0.855 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.093sec(train) 0.982sec(infer)\n",
      "Epoch 56 tst: l 0.526 a 0.852 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.152sec\n",
      "Epoch 57 tr: l 0.516 a 0.856 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.124sec(train) 1.022sec(infer)\n",
      "Epoch 57 tst: l 0.521 a 0.853 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.180sec\n",
      "Epoch 58 tr: l 0.512 a 0.858 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.916sec(train) 1.001sec(infer)\n",
      "Epoch 58 tst: l 0.517 a 0.854 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.166sec\n",
      "Epoch 59 tr: l 0.507 a 0.859 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.465sec(train) 1.035sec(infer)\n",
      "Epoch 59 tst: l 0.512 a 0.856 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.175sec\n",
      "Epoch 60 tr: l 0.503 a 0.860 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.207sec(train) 0.859sec(infer)\n",
      "Epoch 60 tst: l 0.508 a 0.858 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.153sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 61 tr: l 0.498 a 0.862 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.291sec(train) 0.974sec(infer)\n",
      "Epoch 61 tst: l 0.503 a 0.860 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.182sec\n",
      "Epoch 62 tr: l 0.494 a 0.863 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.394sec(train) 0.907sec(infer)\n",
      "Epoch 62 tst: l 0.499 a 0.862 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.181sec\n",
      "Epoch 63 tr: l 0.489 a 0.864 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.776sec(train) 1.196sec(infer)\n",
      "Epoch 63 tst: l 0.495 a 0.863 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.201sec\n",
      "Epoch 64 tr: l 0.485 a 0.865 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 6.295sec(train) 1.077sec(infer)\n",
      "Epoch 64 tst: l 0.490 a 0.864 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.167sec\n",
      "Epoch 65 tr: l 0.481 a 0.867 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 6.255sec(train) 1.007sec(infer)\n",
      "Epoch 65 tst: l 0.486 a 0.865 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.157sec\n",
      "Epoch 66 tr: l 0.477 a 0.868 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.155sec(train) 0.955sec(infer)\n",
      "Epoch 66 tst: l 0.482 a 0.867 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.163sec\n",
      "Epoch 67 tr: l 0.473 a 0.869 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.175sec(train) 1.078sec(infer)\n",
      "Epoch 67 tst: l 0.478 a 0.868 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.178sec\n",
      "Epoch 68 tr: l 0.469 a 0.870 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.671sec(train) 1.121sec(infer)\n",
      "Epoch 68 tst: l 0.474 a 0.869 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.183sec\n",
      "Epoch 69 tr: l 0.465 a 0.871 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.604sec(train) 0.995sec(infer)\n",
      "Epoch 69 tst: l 0.471 a 0.871 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.171sec\n",
      "Epoch 70 tr: l 0.462 a 0.872 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.390sec(train) 0.946sec(infer)\n",
      "Epoch 70 tst: l 0.467 a 0.872 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.159sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 71 tr: l 0.458 a 0.873 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.613sec(train) 0.935sec(infer)\n",
      "Epoch 71 tst: l 0.463 a 0.873 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.150sec\n",
      "Epoch 72 tr: l 0.454 a 0.874 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.678sec(train) 0.872sec(infer)\n",
      "Epoch 72 tst: l 0.460 a 0.874 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.156sec\n",
      "Epoch 73 tr: l 0.451 a 0.875 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.739sec(train) 0.885sec(infer)\n",
      "Epoch 73 tst: l 0.456 a 0.875 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.147sec\n",
      "Epoch 74 tr: l 0.447 a 0.876 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.367sec(train) 0.967sec(infer)\n",
      "Epoch 74 tst: l 0.453 a 0.875 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.186sec\n",
      "Epoch 75 tr: l 0.444 a 0.877 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 6.117sec(train) 1.166sec(infer)\n",
      "Epoch 75 tst: l 0.449 a 0.877 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.179sec\n",
      "Epoch 76 tr: l 0.441 a 0.878 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.696sec(train) 1.102sec(infer)\n",
      "Epoch 76 tst: l 0.446 a 0.878 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.191sec\n",
      "Epoch 77 tr: l 0.437 a 0.879 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.629sec(train) 1.008sec(infer)\n",
      "Epoch 77 tst: l 0.443 a 0.879 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.165sec\n",
      "Epoch 78 tr: l 0.434 a 0.880 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.213sec(train) 0.972sec(infer)\n",
      "Epoch 78 tst: l 0.440 a 0.880 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.149sec\n",
      "Epoch 79 tr: l 0.431 a 0.881 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.799sec(train) 0.898sec(infer)\n",
      "Epoch 79 tst: l 0.437 a 0.881 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.164sec\n",
      "Epoch 80 tr: l 0.428 a 0.882 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 6.099sec(train) 0.983sec(infer)\n",
      "Epoch 80 tst: l 0.433 a 0.882 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.182sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 81 tr: l 0.425 a 0.882 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.530sec(train) 1.105sec(infer)\n",
      "Epoch 81 tst: l 0.430 a 0.882 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.170sec\n",
      "Epoch 82 tr: l 0.422 a 0.883 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.958sec(train) 1.011sec(infer)\n",
      "Epoch 82 tst: l 0.428 a 0.883 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.167sec\n",
      "Epoch 83 tr: l 0.419 a 0.884 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.489sec(train) 1.043sec(infer)\n",
      "Epoch 83 tst: l 0.425 a 0.884 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.162sec\n",
      "Epoch 84 tr: l 0.416 a 0.885 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.285sec(train) 1.004sec(infer)\n",
      "Epoch 84 tst: l 0.422 a 0.884 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.169sec\n",
      "Epoch 85 tr: l 0.413 a 0.886 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.353sec(train) 1.010sec(infer)\n",
      "Epoch 85 tst: l 0.419 a 0.885 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.177sec\n",
      "Epoch 86 tr: l 0.410 a 0.887 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.323sec(train) 1.072sec(infer)\n",
      "Epoch 86 tst: l 0.416 a 0.886 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.176sec\n",
      "Epoch 87 tr: l 0.408 a 0.887 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.245sec(train) 1.042sec(infer)\n",
      "Epoch 87 tst: l 0.414 a 0.887 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.160sec\n",
      "Epoch 88 tr: l 0.405 a 0.888 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.446sec(train) 0.965sec(infer)\n",
      "Epoch 88 tst: l 0.411 a 0.887 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.168sec\n",
      "Epoch 89 tr: l 0.402 a 0.889 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.770sec(train) 1.002sec(infer)\n",
      "Epoch 89 tst: l 0.408 a 0.888 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.148sec\n",
      "Epoch 90 tr: l 0.400 a 0.890 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.497sec(train) 0.938sec(infer)\n",
      "Epoch 90 tst: l 0.406 a 0.888 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.146sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 91 tr: l 0.397 a 0.890 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.997sec(train) 0.910sec(infer)\n",
      "Epoch 91 tst: l 0.403 a 0.889 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.139sec\n",
      "Epoch 92 tr: l 0.395 a 0.891 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.375sec(train) 0.986sec(infer)\n",
      "Epoch 92 tst: l 0.401 a 0.889 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.165sec\n",
      "Epoch 93 tr: l 0.392 a 0.891 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.873sec(train) 0.819sec(infer)\n",
      "Epoch 93 tst: l 0.398 a 0.890 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.144sec\n",
      "Epoch 94 tr: l 0.390 a 0.892 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.210sec(train) 0.996sec(infer)\n",
      "Epoch 94 tst: l 0.396 a 0.890 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.155sec\n",
      "Epoch 95 tr: l 0.387 a 0.893 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 6.061sec(train) 0.805sec(infer)\n",
      "Epoch 95 tst: l 0.394 a 0.891 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.153sec\n",
      "Epoch 96 tr: l 0.385 a 0.893 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.104sec(train) 0.795sec(infer)\n",
      "Epoch 96 tst: l 0.391 a 0.892 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.132sec\n",
      "Epoch 97 tr: l 0.383 a 0.894 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.873sec(train) 0.941sec(infer)\n",
      "Epoch 97 tst: l 0.389 a 0.892 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.140sec\n",
      "Epoch 98 tr: l 0.380 a 0.895 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.698sec(train) 1.072sec(infer)\n",
      "Epoch 98 tst: l 0.387 a 0.893 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.141sec\n",
      "Epoch 99 tr: l 0.378 a 0.895 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.213sec(train) 0.982sec(infer)\n",
      "Epoch 99 tst: l 0.385 a 0.894 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.241sec\n",
      "Epoch 100 tr: l 0.376 a 0.896 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.907sec(train) 0.999sec(infer)\n",
      "Epoch 100 tst: l 0.382 a 0.894 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.157sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 101 tr: l 0.374 a 0.896 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.723sec(train) 1.003sec(infer)\n",
      "Epoch 101 tst: l 0.380 a 0.895 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.178sec\n",
      "Epoch 102 tr: l 0.372 a 0.897 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.926sec(train) 0.993sec(infer)\n",
      "Epoch 102 tst: l 0.378 a 0.895 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.161sec\n",
      "Epoch 103 tr: l 0.370 a 0.897 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.756sec(train) 0.995sec(infer)\n",
      "Epoch 103 tst: l 0.376 a 0.896 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.168sec\n",
      "Epoch 104 tr: l 0.368 a 0.898 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.522sec(train) 0.990sec(infer)\n",
      "Epoch 104 tst: l 0.374 a 0.897 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.168sec\n",
      "Epoch 105 tr: l 0.365 a 0.898 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.885sec(train) 1.002sec(infer)\n",
      "Epoch 105 tst: l 0.372 a 0.897 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.171sec\n",
      "Epoch 106 tr: l 0.363 a 0.899 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.711sec(train) 0.949sec(infer)\n",
      "Epoch 106 tst: l 0.370 a 0.898 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.153sec\n",
      "Epoch 107 tr: l 0.361 a 0.900 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.250sec(train) 1.054sec(infer)\n",
      "Epoch 107 tst: l 0.368 a 0.898 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.143sec\n",
      "Epoch 108 tr: l 0.360 a 0.900 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.981sec(train) 1.001sec(infer)\n",
      "Epoch 108 tst: l 0.366 a 0.899 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.164sec\n",
      "Epoch 109 tr: l 0.358 a 0.900 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.726sec(train) 0.908sec(infer)\n",
      "Epoch 109 tst: l 0.365 a 0.899 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.144sec\n",
      "Epoch 110 tr: l 0.356 a 0.901 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 6.062sec(train) 1.067sec(infer)\n",
      "Epoch 110 tst: l 0.363 a 0.900 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.175sec\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.901 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.053sec(train) 0.987sec(infer)\n",
      "Epoch 111 tst: l 0.361 a 0.901 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.160sec\n",
      "Epoch 112 tr: l 0.352 a 0.902 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.848sec(train) 0.931sec(infer)\n",
      "Epoch 112 tst: l 0.359 a 0.901 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.170sec\n",
      "Epoch 113 tr: l 0.350 a 0.902 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.487sec(train) 0.997sec(infer)\n",
      "Epoch 113 tst: l 0.357 a 0.902 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.149sec\n",
      "Epoch 114 tr: l 0.348 a 0.903 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.383sec(train) 1.209sec(infer)\n",
      "Epoch 114 tst: l 0.356 a 0.902 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.195sec\n",
      "Epoch 115 tr: l 0.347 a 0.903 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.642sec(train) 1.073sec(infer)\n",
      "Epoch 115 tst: l 0.354 a 0.902 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.226sec\n",
      "Epoch 116 tr: l 0.345 a 0.904 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.895sec(train) 1.189sec(infer)\n",
      "Epoch 116 tst: l 0.352 a 0.902 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.215sec\n",
      "Epoch 117 tr: l 0.343 a 0.904 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.440sec(train) 1.002sec(infer)\n",
      "Epoch 117 tst: l 0.351 a 0.903 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.172sec\n",
      "Epoch 118 tr: l 0.341 a 0.905 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.861sec(train) 1.063sec(infer)\n",
      "Epoch 118 tst: l 0.349 a 0.903 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.176sec\n",
      "Epoch 119 tr: l 0.340 a 0.905 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.316sec(train) 0.981sec(infer)\n",
      "Epoch 119 tst: l 0.347 a 0.904 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.164sec\n",
      "Epoch 120 tr: l 0.338 a 0.906 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.343sec(train) 0.940sec(infer)\n",
      "Epoch 120 tst: l 0.346 a 0.904 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.172sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 121 tr: l 0.336 a 0.906 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.495sec(train) 1.128sec(infer)\n",
      "Epoch 121 tst: l 0.344 a 0.905 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.192sec\n",
      "Epoch 122 tr: l 0.335 a 0.907 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.953sec(train) 1.017sec(infer)\n",
      "Epoch 122 tst: l 0.343 a 0.905 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.170sec\n",
      "Epoch 123 tr: l 0.333 a 0.907 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.388sec(train) 0.879sec(infer)\n",
      "Epoch 123 tst: l 0.341 a 0.905 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.143sec\n",
      "Epoch 124 tr: l 0.332 a 0.907 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.355sec(train) 1.052sec(infer)\n",
      "Epoch 124 tst: l 0.339 a 0.906 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.177sec\n",
      "Epoch 125 tr: l 0.330 a 0.908 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 6.112sec(train) 1.011sec(infer)\n",
      "Epoch 125 tst: l 0.338 a 0.906 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.151sec\n",
      "Epoch 126 tr: l 0.328 a 0.908 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.253sec(train) 0.965sec(infer)\n",
      "Epoch 126 tst: l 0.336 a 0.906 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.184sec\n",
      "Epoch 127 tr: l 0.327 a 0.908 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.565sec(train) 1.108sec(infer)\n",
      "Epoch 127 tst: l 0.335 a 0.906 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.183sec\n",
      "Epoch 128 tr: l 0.325 a 0.909 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.470sec(train) 1.102sec(infer)\n",
      "Epoch 128 tst: l 0.334 a 0.907 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.210sec\n",
      "Epoch 129 tr: l 0.324 a 0.909 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.143sec(train) 0.876sec(infer)\n",
      "Epoch 129 tst: l 0.332 a 0.907 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.149sec\n",
      "Epoch 130 tr: l 0.322 a 0.909 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.012sec(train) 1.000sec(infer)\n",
      "Epoch 130 tst: l 0.331 a 0.907 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.165sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 131 tr: l 0.321 a 0.910 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.193sec(train) 0.982sec(infer)\n",
      "Epoch 131 tst: l 0.329 a 0.907 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.167sec\n",
      "Epoch 132 tr: l 0.320 a 0.910 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.301sec(train) 1.048sec(infer)\n",
      "Epoch 132 tst: l 0.328 a 0.907 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.167sec\n",
      "Epoch 133 tr: l 0.318 a 0.910 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.261sec(train) 1.067sec(infer)\n",
      "Epoch 133 tst: l 0.327 a 0.908 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.185sec\n",
      "Epoch 134 tr: l 0.317 a 0.911 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.659sec(train) 0.995sec(infer)\n",
      "Epoch 134 tst: l 0.325 a 0.908 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.166sec\n",
      "Epoch 135 tr: l 0.315 a 0.911 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.137sec(train) 0.972sec(infer)\n",
      "Epoch 135 tst: l 0.324 a 0.909 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.156sec\n",
      "Epoch 136 tr: l 0.314 a 0.912 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.614sec(train) 1.021sec(infer)\n",
      "Epoch 136 tst: l 0.322 a 0.909 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.173sec\n",
      "Epoch 137 tr: l 0.313 a 0.912 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.371sec(train) 1.026sec(infer)\n",
      "Epoch 137 tst: l 0.321 a 0.910 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.164sec\n",
      "Epoch 138 tr: l 0.311 a 0.912 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.645sec(train) 0.983sec(infer)\n",
      "Epoch 138 tst: l 0.320 a 0.910 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.152sec\n",
      "Epoch 139 tr: l 0.310 a 0.912 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.482sec(train) 1.041sec(infer)\n",
      "Epoch 139 tst: l 0.319 a 0.910 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.167sec\n",
      "Epoch 140 tr: l 0.308 a 0.913 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.408sec(train) 0.971sec(infer)\n",
      "Epoch 140 tst: l 0.317 a 0.911 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.181sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 141 tr: l 0.307 a 0.913 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.030sec(train) 1.046sec(infer)\n",
      "Epoch 141 tst: l 0.316 a 0.911 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.165sec\n",
      "Epoch 142 tr: l 0.306 a 0.913 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.450sec(train) 0.960sec(infer)\n",
      "Epoch 142 tst: l 0.315 a 0.912 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.172sec\n",
      "Epoch 143 tr: l 0.305 a 0.914 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.866sec(train) 1.057sec(infer)\n",
      "Epoch 143 tst: l 0.314 a 0.912 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.175sec\n",
      "Epoch 144 tr: l 0.303 a 0.914 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.562sec(train) 0.920sec(infer)\n",
      "Epoch 144 tst: l 0.312 a 0.912 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.153sec\n",
      "Epoch 145 tr: l 0.302 a 0.914 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.815sec(train) 1.017sec(infer)\n",
      "Epoch 145 tst: l 0.311 a 0.912 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.160sec\n",
      "Epoch 146 tr: l 0.301 a 0.915 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.387sec(train) 0.997sec(infer)\n",
      "Epoch 146 tst: l 0.310 a 0.913 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.164sec\n",
      "Epoch 147 tr: l 0.300 a 0.915 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.028sec(train) 0.931sec(infer)\n",
      "Epoch 147 tst: l 0.309 a 0.913 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.157sec\n",
      "Epoch 148 tr: l 0.298 a 0.915 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.380sec(train) 1.030sec(infer)\n",
      "Epoch 148 tst: l 0.308 a 0.913 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.173sec\n",
      "Epoch 149 tr: l 0.297 a 0.916 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.378sec(train) 1.085sec(infer)\n",
      "Epoch 149 tst: l 0.307 a 0.913 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.179sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "---train cluster Ended in 0.27 hour (956.837 sec) \n",
      "---------------------------------DFedAvgM, lr: 0.1, seed: 7383---------------------------------\n",
      "config: {'m': 240, 'm_test': 40, 'p': 2, 'n': 500, 'uneven': True, 'local_model_init': False, 'Gp': 0.1, 'graph': 'er', 'agg': 'seq', 'h1': 200, 'num_epochs': 150, 'batch_size': 100, 'tau': 10, 'lr': 0.1, 'data_seed': 7383, 'train_seed': 7383, 'config_override': '', 'project_dir': 'output_dfca_gi'}\n",
      "Using device: cuda:1\n",
      "Epoch -1 tr: l 2.301 a 0.096 clct[np.int64(240), np.int64(0)] cl_acc 0.500  0.868sec\n",
      "Epoch -1 tst: l 2.301 a 0.095 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.155sec\n",
      "Epoch 0 tr: l 2.150 a 0.442 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.660sec(train) 0.911sec(infer)\n",
      "Epoch 0 tst: l 2.172 a 0.410 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.124sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 1 tr: l 1.967 a 0.537 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.831sec(train) 1.060sec(infer)\n",
      "Epoch 1 tst: l 1.996 a 0.509 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.169sec\n",
      "Epoch 2 tr: l 1.757 a 0.595 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 6.046sec(train) 0.990sec(infer)\n",
      "Epoch 2 tst: l 1.789 a 0.575 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.133sec\n",
      "Epoch 3 tr: l 1.560 a 0.635 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.639sec(train) 0.984sec(infer)\n",
      "Epoch 3 tst: l 1.592 a 0.618 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.153sec\n",
      "Epoch 4 tr: l 1.400 a 0.664 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.931sec(train) 1.022sec(infer)\n",
      "Epoch 4 tst: l 1.432 a 0.650 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.155sec\n",
      "Epoch 5 tr: l 1.278 a 0.685 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.567sec(train) 0.954sec(infer)\n",
      "Epoch 5 tst: l 1.309 a 0.672 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.160sec\n",
      "Epoch 6 tr: l 1.183 a 0.699 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.939sec(train) 0.963sec(infer)\n",
      "Epoch 6 tst: l 1.214 a 0.687 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.154sec\n",
      "Epoch 7 tr: l 1.109 a 0.711 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.793sec(train) 0.941sec(infer)\n",
      "Epoch 7 tst: l 1.139 a 0.700 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.152sec\n",
      "Epoch 8 tr: l 1.050 a 0.721 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.894sec(train) 0.944sec(infer)\n",
      "Epoch 8 tst: l 1.079 a 0.709 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.142sec\n",
      "Epoch 9 tr: l 1.002 a 0.728 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.224sec(train) 1.011sec(infer)\n",
      "Epoch 9 tst: l 1.030 a 0.718 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.155sec\n",
      "Epoch 10 tr: l 0.962 a 0.735 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.358sec(train) 0.948sec(infer)\n",
      "Epoch 10 tst: l 0.990 a 0.725 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.135sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 11 tr: l 0.929 a 0.742 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.299sec(train) 0.971sec(infer)\n",
      "Epoch 11 tst: l 0.956 a 0.731 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.162sec\n",
      "Epoch 12 tr: l 0.901 a 0.747 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.355sec(train) 0.885sec(infer)\n",
      "Epoch 12 tst: l 0.927 a 0.738 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.159sec\n",
      "Epoch 13 tr: l 0.877 a 0.752 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.366sec(train) 1.254sec(infer)\n",
      "Epoch 13 tst: l 0.903 a 0.743 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.211sec\n",
      "Epoch 14 tr: l 0.856 a 0.757 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.970sec(train) 1.112sec(infer)\n",
      "Epoch 14 tst: l 0.881 a 0.748 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.189sec\n",
      "Epoch 15 tr: l 0.838 a 0.761 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.366sec(train) 0.960sec(infer)\n",
      "Epoch 15 tst: l 0.862 a 0.753 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.166sec\n",
      "Epoch 16 tr: l 0.821 a 0.765 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.434sec(train) 1.052sec(infer)\n",
      "Epoch 16 tst: l 0.845 a 0.758 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.164sec\n",
      "Epoch 17 tr: l 0.806 a 0.769 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.515sec(train) 0.998sec(infer)\n",
      "Epoch 17 tst: l 0.830 a 0.763 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.171sec\n",
      "Epoch 18 tr: l 0.793 a 0.771 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.248sec(train) 0.962sec(infer)\n",
      "Epoch 18 tst: l 0.816 a 0.766 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.173sec\n",
      "Epoch 19 tr: l 0.780 a 0.775 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.769sec(train) 1.034sec(infer)\n",
      "Epoch 19 tst: l 0.804 a 0.769 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.175sec\n",
      "Epoch 20 tr: l 0.768 a 0.778 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.904sec(train) 1.037sec(infer)\n",
      "Epoch 20 tst: l 0.792 a 0.773 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.152sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 21 tr: l 0.758 a 0.780 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.574sec(train) 0.912sec(infer)\n",
      "Epoch 21 tst: l 0.781 a 0.777 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.157sec\n",
      "Epoch 22 tr: l 0.747 a 0.783 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.769sec(train) 1.091sec(infer)\n",
      "Epoch 22 tst: l 0.771 a 0.781 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.187sec\n",
      "Epoch 23 tr: l 0.738 a 0.786 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.682sec(train) 0.988sec(infer)\n",
      "Epoch 23 tst: l 0.761 a 0.783 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.147sec\n",
      "Epoch 24 tr: l 0.729 a 0.788 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.308sec(train) 0.870sec(infer)\n",
      "Epoch 24 tst: l 0.752 a 0.786 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.165sec\n",
      "Epoch 25 tr: l 0.720 a 0.791 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.858sec(train) 0.919sec(infer)\n",
      "Epoch 25 tst: l 0.744 a 0.788 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.153sec\n",
      "Epoch 26 tr: l 0.712 a 0.793 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.379sec(train) 0.953sec(infer)\n",
      "Epoch 26 tst: l 0.736 a 0.792 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.179sec\n",
      "Epoch 27 tr: l 0.704 a 0.796 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.528sec(train) 0.976sec(infer)\n",
      "Epoch 27 tst: l 0.728 a 0.794 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.154sec\n",
      "Epoch 28 tr: l 0.696 a 0.798 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.659sec(train) 0.892sec(infer)\n",
      "Epoch 28 tst: l 0.720 a 0.797 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.149sec\n",
      "Epoch 29 tr: l 0.688 a 0.801 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.538sec(train) 1.009sec(infer)\n",
      "Epoch 29 tst: l 0.713 a 0.799 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.159sec\n",
      "Epoch 30 tr: l 0.681 a 0.803 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.220sec(train) 0.935sec(infer)\n",
      "Epoch 30 tst: l 0.706 a 0.801 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.163sec\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.805 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.147sec(train) 0.905sec(infer)\n",
      "Epoch 31 tst: l 0.699 a 0.803 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.176sec\n",
      "Epoch 32 tr: l 0.667 a 0.807 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.556sec(train) 0.871sec(infer)\n",
      "Epoch 32 tst: l 0.692 a 0.805 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.154sec\n",
      "Epoch 33 tr: l 0.660 a 0.810 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.050sec(train) 0.878sec(infer)\n",
      "Epoch 33 tst: l 0.685 a 0.807 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.160sec\n",
      "Epoch 34 tr: l 0.654 a 0.812 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.038sec(train) 0.996sec(infer)\n",
      "Epoch 34 tst: l 0.679 a 0.809 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.160sec\n",
      "Epoch 35 tr: l 0.647 a 0.814 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.003sec(train) 0.915sec(infer)\n",
      "Epoch 35 tst: l 0.672 a 0.810 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.161sec\n",
      "Epoch 36 tr: l 0.641 a 0.816 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.912sec(train) 0.899sec(infer)\n",
      "Epoch 36 tst: l 0.666 a 0.812 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.167sec\n",
      "Epoch 37 tr: l 0.634 a 0.818 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.123sec(train) 0.891sec(infer)\n",
      "Epoch 37 tst: l 0.660 a 0.814 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.173sec\n",
      "Epoch 38 tr: l 0.628 a 0.820 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.762sec(train) 0.888sec(infer)\n",
      "Epoch 38 tst: l 0.654 a 0.816 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.172sec\n",
      "Epoch 39 tr: l 0.622 a 0.822 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.409sec(train) 1.037sec(infer)\n",
      "Epoch 39 tst: l 0.648 a 0.817 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.154sec\n",
      "Epoch 40 tr: l 0.616 a 0.824 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.897sec(train) 1.009sec(infer)\n",
      "Epoch 40 tst: l 0.642 a 0.819 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.141sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 41 tr: l 0.610 a 0.827 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.636sec(train) 0.944sec(infer)\n",
      "Epoch 41 tst: l 0.636 a 0.821 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.163sec\n",
      "Epoch 42 tr: l 0.604 a 0.828 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.663sec(train) 0.907sec(infer)\n",
      "Epoch 42 tst: l 0.630 a 0.823 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.149sec\n",
      "Epoch 43 tr: l 0.599 a 0.830 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.661sec(train) 0.837sec(infer)\n",
      "Epoch 43 tst: l 0.625 a 0.825 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.149sec\n",
      "Epoch 44 tr: l 0.593 a 0.832 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.811sec(train) 0.950sec(infer)\n",
      "Epoch 44 tst: l 0.619 a 0.828 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.161sec\n",
      "Epoch 45 tr: l 0.587 a 0.835 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.794sec(train) 1.059sec(infer)\n",
      "Epoch 45 tst: l 0.614 a 0.830 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.161sec\n",
      "Epoch 46 tr: l 0.582 a 0.836 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.197sec(train) 0.937sec(infer)\n",
      "Epoch 46 tst: l 0.608 a 0.832 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.172sec\n",
      "Epoch 47 tr: l 0.576 a 0.838 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.278sec(train) 0.981sec(infer)\n",
      "Epoch 47 tst: l 0.603 a 0.833 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.166sec\n",
      "Epoch 48 tr: l 0.571 a 0.840 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.534sec(train) 0.905sec(infer)\n",
      "Epoch 48 tst: l 0.597 a 0.835 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.145sec\n",
      "Epoch 49 tr: l 0.566 a 0.842 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.830sec(train) 0.887sec(infer)\n",
      "Epoch 49 tst: l 0.592 a 0.836 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.163sec\n",
      "Epoch 50 tr: l 0.560 a 0.843 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.078sec(train) 0.922sec(infer)\n",
      "Epoch 50 tst: l 0.587 a 0.838 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.146sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 51 tr: l 0.555 a 0.845 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.003sec(train) 0.969sec(infer)\n",
      "Epoch 51 tst: l 0.582 a 0.840 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.164sec\n",
      "Epoch 52 tr: l 0.550 a 0.847 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.054sec(train) 0.897sec(infer)\n",
      "Epoch 52 tst: l 0.576 a 0.843 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.162sec\n",
      "Epoch 53 tr: l 0.545 a 0.848 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.388sec(train) 0.892sec(infer)\n",
      "Epoch 53 tst: l 0.571 a 0.844 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.154sec\n",
      "Epoch 54 tr: l 0.540 a 0.850 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.691sec(train) 1.072sec(infer)\n",
      "Epoch 54 tst: l 0.566 a 0.845 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.179sec\n",
      "Epoch 55 tr: l 0.535 a 0.852 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 6.046sec(train) 1.011sec(infer)\n",
      "Epoch 55 tst: l 0.562 a 0.846 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.175sec\n",
      "Epoch 56 tr: l 0.530 a 0.853 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.478sec(train) 0.919sec(infer)\n",
      "Epoch 56 tst: l 0.557 a 0.848 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.123sec\n",
      "Epoch 57 tr: l 0.526 a 0.855 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.401sec(train) 0.947sec(infer)\n",
      "Epoch 57 tst: l 0.552 a 0.850 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.156sec\n",
      "Epoch 58 tr: l 0.521 a 0.856 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.663sec(train) 0.968sec(infer)\n",
      "Epoch 58 tst: l 0.547 a 0.851 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.158sec\n",
      "Epoch 59 tr: l 0.516 a 0.858 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.206sec(train) 0.926sec(infer)\n",
      "Epoch 59 tst: l 0.543 a 0.852 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.148sec\n",
      "Epoch 60 tr: l 0.512 a 0.859 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 6.435sec(train) 0.974sec(infer)\n",
      "Epoch 60 tst: l 0.538 a 0.854 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.166sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 61 tr: l 0.507 a 0.860 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 6.854sec(train) 1.052sec(infer)\n",
      "Epoch 61 tst: l 0.534 a 0.855 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.178sec\n",
      "Epoch 62 tr: l 0.503 a 0.862 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 6.377sec(train) 1.040sec(infer)\n",
      "Epoch 62 tst: l 0.529 a 0.857 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.163sec\n",
      "Epoch 63 tr: l 0.499 a 0.863 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.653sec(train) 1.265sec(infer)\n",
      "Epoch 63 tst: l 0.525 a 0.859 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.197sec\n",
      "Epoch 64 tr: l 0.495 a 0.864 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 6.268sec(train) 0.966sec(infer)\n",
      "Epoch 64 tst: l 0.521 a 0.861 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.154sec\n",
      "Epoch 65 tr: l 0.490 a 0.865 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.636sec(train) 0.995sec(infer)\n",
      "Epoch 65 tst: l 0.516 a 0.863 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.178sec\n",
      "Epoch 66 tr: l 0.486 a 0.866 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.199sec(train) 0.852sec(infer)\n",
      "Epoch 66 tst: l 0.512 a 0.864 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.141sec\n",
      "Epoch 67 tr: l 0.482 a 0.867 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.516sec(train) 1.012sec(infer)\n",
      "Epoch 67 tst: l 0.508 a 0.866 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.160sec\n",
      "Epoch 68 tr: l 0.478 a 0.869 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.812sec(train) 0.987sec(infer)\n",
      "Epoch 68 tst: l 0.504 a 0.867 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.166sec\n",
      "Epoch 69 tr: l 0.475 a 0.870 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.954sec(train) 1.044sec(infer)\n",
      "Epoch 69 tst: l 0.500 a 0.868 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.164sec\n",
      "Epoch 70 tr: l 0.471 a 0.870 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.773sec(train) 0.908sec(infer)\n",
      "Epoch 70 tst: l 0.496 a 0.869 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.134sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 71 tr: l 0.467 a 0.872 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.704sec(train) 0.964sec(infer)\n",
      "Epoch 71 tst: l 0.493 a 0.871 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.150sec\n",
      "Epoch 72 tr: l 0.463 a 0.873 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.967sec(train) 1.101sec(infer)\n",
      "Epoch 72 tst: l 0.489 a 0.872 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.193sec\n",
      "Epoch 73 tr: l 0.460 a 0.874 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 6.631sec(train) 1.184sec(infer)\n",
      "Epoch 73 tst: l 0.485 a 0.872 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.199sec\n",
      "Epoch 74 tr: l 0.456 a 0.875 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.967sec(train) 1.023sec(infer)\n",
      "Epoch 74 tst: l 0.482 a 0.873 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.167sec\n",
      "Epoch 75 tr: l 0.453 a 0.875 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.578sec(train) 0.840sec(infer)\n",
      "Epoch 75 tst: l 0.478 a 0.874 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.140sec\n",
      "Epoch 76 tr: l 0.449 a 0.876 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.537sec(train) 1.075sec(infer)\n",
      "Epoch 76 tst: l 0.475 a 0.875 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.174sec\n",
      "Epoch 77 tr: l 0.446 a 0.877 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.551sec(train) 1.001sec(infer)\n",
      "Epoch 77 tst: l 0.471 a 0.877 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.170sec\n",
      "Epoch 78 tr: l 0.443 a 0.878 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.761sec(train) 0.941sec(infer)\n",
      "Epoch 78 tst: l 0.468 a 0.878 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.144sec\n",
      "Epoch 79 tr: l 0.439 a 0.879 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.990sec(train) 1.104sec(infer)\n",
      "Epoch 79 tst: l 0.465 a 0.878 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.184sec\n",
      "Epoch 80 tr: l 0.436 a 0.880 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.571sec(train) 0.933sec(infer)\n",
      "Epoch 80 tst: l 0.461 a 0.879 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.153sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 81 tr: l 0.433 a 0.881 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.230sec(train) 1.001sec(infer)\n",
      "Epoch 81 tst: l 0.458 a 0.880 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.146sec\n",
      "Epoch 82 tr: l 0.430 a 0.882 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.142sec(train) 0.861sec(infer)\n",
      "Epoch 82 tst: l 0.455 a 0.881 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.153sec\n",
      "Epoch 83 tr: l 0.427 a 0.882 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.727sec(train) 1.127sec(infer)\n",
      "Epoch 83 tst: l 0.452 a 0.881 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.170sec\n",
      "Epoch 84 tr: l 0.424 a 0.883 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.856sec(train) 0.879sec(infer)\n",
      "Epoch 84 tst: l 0.449 a 0.882 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.147sec\n",
      "Epoch 85 tr: l 0.421 a 0.884 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.214sec(train) 0.902sec(infer)\n",
      "Epoch 85 tst: l 0.446 a 0.883 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.168sec\n",
      "Epoch 86 tr: l 0.418 a 0.885 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.994sec(train) 0.909sec(infer)\n",
      "Epoch 86 tst: l 0.443 a 0.883 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.146sec\n",
      "Epoch 87 tr: l 0.415 a 0.886 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.220sec(train) 0.891sec(infer)\n",
      "Epoch 87 tst: l 0.440 a 0.884 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.168sec\n",
      "Epoch 88 tr: l 0.413 a 0.887 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.292sec(train) 0.916sec(infer)\n",
      "Epoch 88 tst: l 0.437 a 0.885 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.181sec\n",
      "Epoch 89 tr: l 0.410 a 0.887 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.287sec(train) 1.033sec(infer)\n",
      "Epoch 89 tst: l 0.434 a 0.885 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.157sec\n",
      "Epoch 90 tr: l 0.407 a 0.888 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.908sec(train) 0.980sec(infer)\n",
      "Epoch 90 tst: l 0.432 a 0.886 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.157sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 91 tr: l 0.405 a 0.889 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.034sec(train) 0.928sec(infer)\n",
      "Epoch 91 tst: l 0.429 a 0.886 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.170sec\n",
      "Epoch 92 tr: l 0.402 a 0.889 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.534sec(train) 0.938sec(infer)\n",
      "Epoch 92 tst: l 0.426 a 0.887 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.159sec\n",
      "Epoch 93 tr: l 0.399 a 0.890 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.433sec(train) 1.090sec(infer)\n",
      "Epoch 93 tst: l 0.424 a 0.887 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.190sec\n",
      "Epoch 94 tr: l 0.397 a 0.891 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.601sec(train) 1.039sec(infer)\n",
      "Epoch 94 tst: l 0.421 a 0.888 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.165sec\n",
      "Epoch 95 tr: l 0.394 a 0.891 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.486sec(train) 1.021sec(infer)\n",
      "Epoch 95 tst: l 0.418 a 0.889 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.152sec\n",
      "Epoch 96 tr: l 0.392 a 0.892 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.394sec(train) 0.842sec(infer)\n",
      "Epoch 96 tst: l 0.416 a 0.890 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.150sec\n",
      "Epoch 97 tr: l 0.390 a 0.892 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.103sec(train) 0.987sec(infer)\n",
      "Epoch 97 tst: l 0.413 a 0.890 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.159sec\n",
      "Epoch 98 tr: l 0.387 a 0.893 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.805sec(train) 0.967sec(infer)\n",
      "Epoch 98 tst: l 0.411 a 0.891 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.149sec\n",
      "Epoch 99 tr: l 0.385 a 0.893 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.208sec(train) 0.896sec(infer)\n",
      "Epoch 99 tst: l 0.409 a 0.891 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.170sec\n",
      "Epoch 100 tr: l 0.383 a 0.894 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.868sec(train) 0.885sec(infer)\n",
      "Epoch 100 tst: l 0.406 a 0.892 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.145sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 101 tr: l 0.380 a 0.895 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.547sec(train) 1.023sec(infer)\n",
      "Epoch 101 tst: l 0.404 a 0.893 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.181sec\n",
      "Epoch 102 tr: l 0.378 a 0.895 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.271sec(train) 0.968sec(infer)\n",
      "Epoch 102 tst: l 0.402 a 0.893 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.176sec\n",
      "Epoch 103 tr: l 0.376 a 0.896 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.048sec(train) 0.928sec(infer)\n",
      "Epoch 103 tst: l 0.399 a 0.894 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.157sec\n",
      "Epoch 104 tr: l 0.374 a 0.896 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.775sec(train) 0.892sec(infer)\n",
      "Epoch 104 tst: l 0.397 a 0.894 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.170sec\n",
      "Epoch 105 tr: l 0.371 a 0.897 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.820sec(train) 0.987sec(infer)\n",
      "Epoch 105 tst: l 0.395 a 0.895 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.169sec\n",
      "Epoch 106 tr: l 0.369 a 0.898 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.471sec(train) 1.033sec(infer)\n",
      "Epoch 106 tst: l 0.393 a 0.895 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.182sec\n",
      "Epoch 107 tr: l 0.367 a 0.898 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.063sec(train) 1.053sec(infer)\n",
      "Epoch 107 tst: l 0.391 a 0.896 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.182sec\n",
      "Epoch 108 tr: l 0.365 a 0.899 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.163sec(train) 0.912sec(infer)\n",
      "Epoch 108 tst: l 0.389 a 0.897 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.155sec\n",
      "Epoch 109 tr: l 0.363 a 0.899 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.092sec(train) 0.988sec(infer)\n",
      "Epoch 109 tst: l 0.387 a 0.897 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.175sec\n",
      "Epoch 110 tr: l 0.361 a 0.900 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.291sec(train) 1.042sec(infer)\n",
      "Epoch 110 tst: l 0.385 a 0.898 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.181sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 111 tr: l 0.359 a 0.900 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.664sec(train) 0.878sec(infer)\n",
      "Epoch 111 tst: l 0.383 a 0.898 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.148sec\n",
      "Epoch 112 tr: l 0.357 a 0.901 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.151sec(train) 0.915sec(infer)\n",
      "Epoch 112 tst: l 0.381 a 0.898 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.164sec\n",
      "Epoch 113 tr: l 0.355 a 0.901 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.071sec(train) 0.955sec(infer)\n",
      "Epoch 113 tst: l 0.379 a 0.899 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.186sec\n",
      "Epoch 114 tr: l 0.354 a 0.902 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.050sec(train) 0.984sec(infer)\n",
      "Epoch 114 tst: l 0.377 a 0.899 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.161sec\n",
      "Epoch 115 tr: l 0.352 a 0.902 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.197sec(train) 0.972sec(infer)\n",
      "Epoch 115 tst: l 0.375 a 0.900 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.166sec\n",
      "Epoch 116 tr: l 0.350 a 0.902 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.128sec(train) 1.000sec(infer)\n",
      "Epoch 116 tst: l 0.373 a 0.900 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.169sec\n",
      "Epoch 117 tr: l 0.348 a 0.903 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.926sec(train) 0.959sec(infer)\n",
      "Epoch 117 tst: l 0.371 a 0.900 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.161sec\n",
      "Epoch 118 tr: l 0.346 a 0.903 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.506sec(train) 0.946sec(infer)\n",
      "Epoch 118 tst: l 0.369 a 0.901 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.144sec\n",
      "Epoch 119 tr: l 0.345 a 0.904 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.479sec(train) 1.004sec(infer)\n",
      "Epoch 119 tst: l 0.368 a 0.901 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.170sec\n",
      "Epoch 120 tr: l 0.343 a 0.904 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.321sec(train) 1.016sec(infer)\n",
      "Epoch 120 tst: l 0.366 a 0.902 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.164sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 121 tr: l 0.341 a 0.905 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.571sec(train) 0.939sec(infer)\n",
      "Epoch 121 tst: l 0.364 a 0.902 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.157sec\n",
      "Epoch 122 tr: l 0.339 a 0.905 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.506sec(train) 1.143sec(infer)\n",
      "Epoch 122 tst: l 0.362 a 0.903 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.186sec\n",
      "Epoch 123 tr: l 0.338 a 0.905 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.615sec(train) 0.970sec(infer)\n",
      "Epoch 123 tst: l 0.361 a 0.903 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.170sec\n",
      "Epoch 124 tr: l 0.336 a 0.906 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.046sec(train) 1.026sec(infer)\n",
      "Epoch 124 tst: l 0.359 a 0.904 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.186sec\n",
      "Epoch 125 tr: l 0.334 a 0.906 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.413sec(train) 1.027sec(infer)\n",
      "Epoch 125 tst: l 0.357 a 0.904 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.170sec\n",
      "Epoch 126 tr: l 0.333 a 0.906 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.467sec(train) 1.013sec(infer)\n",
      "Epoch 126 tst: l 0.356 a 0.904 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.169sec\n",
      "Epoch 127 tr: l 0.331 a 0.907 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.748sec(train) 1.054sec(infer)\n",
      "Epoch 127 tst: l 0.354 a 0.905 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.163sec\n",
      "Epoch 128 tr: l 0.330 a 0.907 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.862sec(train) 0.905sec(infer)\n",
      "Epoch 128 tst: l 0.352 a 0.905 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.159sec\n",
      "Epoch 129 tr: l 0.328 a 0.908 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.284sec(train) 1.035sec(infer)\n",
      "Epoch 129 tst: l 0.351 a 0.906 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.171sec\n",
      "Epoch 130 tr: l 0.327 a 0.908 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 6.043sec(train) 0.978sec(infer)\n",
      "Epoch 130 tst: l 0.349 a 0.906 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.174sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 131 tr: l 0.325 a 0.908 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.468sec(train) 0.989sec(infer)\n",
      "Epoch 131 tst: l 0.348 a 0.907 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.167sec\n",
      "Epoch 132 tr: l 0.324 a 0.909 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.174sec(train) 1.024sec(infer)\n",
      "Epoch 132 tst: l 0.346 a 0.907 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.168sec\n",
      "Epoch 133 tr: l 0.322 a 0.909 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.553sec(train) 0.887sec(infer)\n",
      "Epoch 133 tst: l 0.345 a 0.907 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.216sec\n",
      "Epoch 134 tr: l 0.321 a 0.909 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 6.234sec(train) 0.956sec(infer)\n",
      "Epoch 134 tst: l 0.343 a 0.907 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.175sec\n",
      "Epoch 135 tr: l 0.319 a 0.910 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 6.215sec(train) 0.987sec(infer)\n",
      "Epoch 135 tst: l 0.342 a 0.908 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.163sec\n",
      "Epoch 136 tr: l 0.318 a 0.910 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.702sec(train) 1.078sec(infer)\n",
      "Epoch 136 tst: l 0.340 a 0.908 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.176sec\n",
      "Epoch 137 tr: l 0.316 a 0.910 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 6.011sec(train) 1.164sec(infer)\n",
      "Epoch 137 tst: l 0.339 a 0.909 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.189sec\n",
      "Epoch 138 tr: l 0.315 a 0.911 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.361sec(train) 0.893sec(infer)\n",
      "Epoch 138 tst: l 0.337 a 0.909 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.141sec\n",
      "Epoch 139 tr: l 0.314 a 0.911 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.140sec(train) 0.956sec(infer)\n",
      "Epoch 139 tst: l 0.336 a 0.909 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.196sec\n",
      "Epoch 140 tr: l 0.312 a 0.912 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.411sec(train) 1.018sec(infer)\n",
      "Epoch 140 tst: l 0.335 a 0.910 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.164sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 141 tr: l 0.311 a 0.912 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.912sec(train) 0.956sec(infer)\n",
      "Epoch 141 tst: l 0.333 a 0.910 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.149sec\n",
      "Epoch 142 tr: l 0.309 a 0.912 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.695sec(train) 1.035sec(infer)\n",
      "Epoch 142 tst: l 0.332 a 0.910 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.162sec\n",
      "Epoch 143 tr: l 0.308 a 0.913 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.200sec(train) 1.012sec(infer)\n",
      "Epoch 143 tst: l 0.331 a 0.910 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.176sec\n",
      "Epoch 144 tr: l 0.307 a 0.913 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.000sec(train) 0.962sec(infer)\n",
      "Epoch 144 tst: l 0.329 a 0.910 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.151sec\n",
      "Epoch 145 tr: l 0.306 a 0.913 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.460sec(train) 1.150sec(infer)\n",
      "Epoch 145 tst: l 0.328 a 0.911 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.186sec\n",
      "Epoch 146 tr: l 0.304 a 0.913 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.767sec(train) 1.141sec(infer)\n",
      "Epoch 146 tst: l 0.327 a 0.911 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.189sec\n",
      "Epoch 147 tr: l 0.303 a 0.914 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.522sec(train) 0.999sec(infer)\n",
      "Epoch 147 tst: l 0.325 a 0.911 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.179sec\n",
      "Epoch 148 tr: l 0.302 a 0.914 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.412sec(train) 0.900sec(infer)\n",
      "Epoch 148 tst: l 0.324 a 0.912 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.205sec\n",
      "Epoch 149 tr: l 0.301 a 0.914 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.351sec(train) 0.921sec(infer)\n",
      "Epoch 149 tst: l 0.323 a 0.912 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.162sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "---train cluster Ended in 0.27 hour (974.225 sec) \n",
      "---------------------------------DFedAvgM, lr: 0.1, seed: 6930---------------------------------\n",
      "config: {'m': 240, 'm_test': 40, 'p': 2, 'n': 500, 'uneven': True, 'local_model_init': False, 'Gp': 0.1, 'graph': 'er', 'agg': 'seq', 'h1': 200, 'num_epochs': 150, 'batch_size': 100, 'tau': 10, 'lr': 0.1, 'data_seed': 6930, 'train_seed': 6930, 'config_override': '', 'project_dir': 'output_dfca_gi'}\n",
      "Using device: cuda:1\n",
      "Epoch -1 tr: l 2.307 a 0.100 clct[np.int64(240), np.int64(0)] cl_acc 0.500  0.958sec\n",
      "Epoch -1 tst: l 2.306 a 0.103 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.154sec\n",
      "Epoch 0 tr: l 2.189 a 0.339 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.968sec(train) 0.979sec(infer)\n",
      "Epoch 0 tst: l 2.202 a 0.307 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.142sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 1 tr: l 2.035 a 0.491 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.363sec(train) 1.128sec(infer)\n",
      "Epoch 1 tst: l 2.052 a 0.470 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.162sec\n",
      "Epoch 2 tr: l 1.840 a 0.559 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.253sec(train) 0.915sec(infer)\n",
      "Epoch 2 tst: l 1.858 a 0.543 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.154sec\n",
      "Epoch 3 tr: l 1.641 a 0.604 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.205sec(train) 0.975sec(infer)\n",
      "Epoch 3 tst: l 1.657 a 0.594 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.157sec\n",
      "Epoch 4 tr: l 1.471 a 0.640 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 6.429sec(train) 1.291sec(infer)\n",
      "Epoch 4 tst: l 1.484 a 0.629 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.210sec\n",
      "Epoch 5 tr: l 1.338 a 0.666 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.616sec(train) 0.967sec(infer)\n",
      "Epoch 5 tst: l 1.349 a 0.657 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.155sec\n",
      "Epoch 6 tr: l 1.235 a 0.685 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.409sec(train) 0.974sec(infer)\n",
      "Epoch 6 tst: l 1.245 a 0.677 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.170sec\n",
      "Epoch 7 tr: l 1.154 a 0.699 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.558sec(train) 1.058sec(infer)\n",
      "Epoch 7 tst: l 1.163 a 0.692 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.170sec\n",
      "Epoch 8 tr: l 1.090 a 0.710 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.028sec(train) 1.079sec(infer)\n",
      "Epoch 8 tst: l 1.098 a 0.704 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.178sec\n",
      "Epoch 9 tr: l 1.038 a 0.719 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.498sec(train) 1.103sec(infer)\n",
      "Epoch 9 tst: l 1.045 a 0.714 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.174sec\n",
      "Epoch 10 tr: l 0.995 a 0.727 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 6.060sec(train) 1.051sec(infer)\n",
      "Epoch 10 tst: l 1.001 a 0.722 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.187sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 11 tr: l 0.959 a 0.734 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.168sec(train) 1.003sec(infer)\n",
      "Epoch 11 tst: l 0.965 a 0.730 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.168sec\n",
      "Epoch 12 tr: l 0.929 a 0.741 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.233sec(train) 1.048sec(infer)\n",
      "Epoch 12 tst: l 0.934 a 0.736 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.172sec\n",
      "Epoch 13 tr: l 0.903 a 0.746 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.593sec(train) 0.997sec(infer)\n",
      "Epoch 13 tst: l 0.907 a 0.742 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.153sec\n",
      "Epoch 14 tr: l 0.880 a 0.751 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.154sec(train) 0.962sec(infer)\n",
      "Epoch 14 tst: l 0.884 a 0.747 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.167sec\n",
      "Epoch 15 tr: l 0.860 a 0.756 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.177sec(train) 1.073sec(infer)\n",
      "Epoch 15 tst: l 0.864 a 0.753 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.164sec\n",
      "Epoch 16 tr: l 0.842 a 0.760 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.923sec(train) 1.006sec(infer)\n",
      "Epoch 16 tst: l 0.845 a 0.758 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.153sec\n",
      "Epoch 17 tr: l 0.826 a 0.764 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.914sec(train) 0.902sec(infer)\n",
      "Epoch 17 tst: l 0.829 a 0.762 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.151sec\n",
      "Epoch 18 tr: l 0.812 a 0.768 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.903sec(train) 1.104sec(infer)\n",
      "Epoch 18 tst: l 0.814 a 0.766 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.162sec\n",
      "Epoch 19 tr: l 0.798 a 0.771 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.649sec(train) 0.977sec(infer)\n",
      "Epoch 19 tst: l 0.801 a 0.770 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.148sec\n",
      "Epoch 20 tr: l 0.786 a 0.775 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.129sec(train) 0.930sec(infer)\n",
      "Epoch 20 tst: l 0.788 a 0.774 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.152sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 21 tr: l 0.774 a 0.778 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.004sec(train) 0.837sec(infer)\n",
      "Epoch 21 tst: l 0.777 a 0.778 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.143sec\n",
      "Epoch 22 tr: l 0.764 a 0.782 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.387sec(train) 1.017sec(infer)\n",
      "Epoch 22 tst: l 0.766 a 0.782 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.184sec\n",
      "Epoch 23 tr: l 0.753 a 0.784 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.073sec(train) 0.957sec(infer)\n",
      "Epoch 23 tst: l 0.756 a 0.786 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.168sec\n",
      "Epoch 24 tr: l 0.744 a 0.787 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.612sec(train) 1.048sec(infer)\n",
      "Epoch 24 tst: l 0.746 a 0.789 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.170sec\n",
      "Epoch 25 tr: l 0.735 a 0.789 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.942sec(train) 1.018sec(infer)\n",
      "Epoch 25 tst: l 0.737 a 0.792 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.177sec\n",
      "Epoch 26 tr: l 0.726 a 0.792 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.921sec(train) 1.036sec(infer)\n",
      "Epoch 26 tst: l 0.728 a 0.794 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.187sec\n",
      "Epoch 27 tr: l 0.717 a 0.794 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.389sec(train) 1.074sec(infer)\n",
      "Epoch 27 tst: l 0.720 a 0.796 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.182sec\n",
      "Epoch 28 tr: l 0.709 a 0.797 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.330sec(train) 0.947sec(infer)\n",
      "Epoch 28 tst: l 0.712 a 0.798 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.159sec\n",
      "Epoch 29 tr: l 0.701 a 0.799 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.285sec(train) 1.110sec(infer)\n",
      "Epoch 29 tst: l 0.704 a 0.801 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.225sec\n",
      "Epoch 30 tr: l 0.694 a 0.802 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.042sec(train) 1.130sec(infer)\n",
      "Epoch 30 tst: l 0.697 a 0.803 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.189sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 31 tr: l 0.686 a 0.804 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.548sec(train) 1.039sec(infer)\n",
      "Epoch 31 tst: l 0.689 a 0.805 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.183sec\n",
      "Epoch 32 tr: l 0.679 a 0.807 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.716sec(train) 1.049sec(infer)\n",
      "Epoch 32 tst: l 0.682 a 0.807 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.170sec\n",
      "Epoch 33 tr: l 0.672 a 0.809 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.976sec(train) 1.016sec(infer)\n",
      "Epoch 33 tst: l 0.675 a 0.810 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.147sec\n",
      "Epoch 34 tr: l 0.665 a 0.811 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.335sec(train) 1.019sec(infer)\n",
      "Epoch 34 tst: l 0.669 a 0.811 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.208sec\n",
      "Epoch 35 tr: l 0.658 a 0.813 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.846sec(train) 1.035sec(infer)\n",
      "Epoch 35 tst: l 0.662 a 0.814 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.170sec\n",
      "Epoch 36 tr: l 0.651 a 0.816 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.172sec(train) 0.975sec(infer)\n",
      "Epoch 36 tst: l 0.655 a 0.816 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.177sec\n",
      "Epoch 37 tr: l 0.644 a 0.818 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.823sec(train) 1.039sec(infer)\n",
      "Epoch 37 tst: l 0.649 a 0.818 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.170sec\n",
      "Epoch 38 tr: l 0.638 a 0.820 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.324sec(train) 1.135sec(infer)\n",
      "Epoch 38 tst: l 0.643 a 0.820 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.149sec\n",
      "Epoch 39 tr: l 0.631 a 0.822 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.909sec(train) 0.972sec(infer)\n",
      "Epoch 39 tst: l 0.636 a 0.822 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.159sec\n",
      "Epoch 40 tr: l 0.625 a 0.824 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.209sec(train) 0.962sec(infer)\n",
      "Epoch 40 tst: l 0.630 a 0.824 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.160sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 41 tr: l 0.619 a 0.826 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.282sec(train) 1.011sec(infer)\n",
      "Epoch 41 tst: l 0.624 a 0.825 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.173sec\n",
      "Epoch 42 tr: l 0.613 a 0.829 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.032sec(train) 1.065sec(infer)\n",
      "Epoch 42 tst: l 0.618 a 0.827 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.195sec\n",
      "Epoch 43 tr: l 0.607 a 0.831 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 6.215sec(train) 1.071sec(infer)\n",
      "Epoch 43 tst: l 0.612 a 0.829 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.183sec\n",
      "Epoch 44 tr: l 0.601 a 0.833 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.429sec(train) 0.961sec(infer)\n",
      "Epoch 44 tst: l 0.606 a 0.831 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.179sec\n",
      "Epoch 45 tr: l 0.595 a 0.834 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.626sec(train) 1.222sec(infer)\n",
      "Epoch 45 tst: l 0.601 a 0.833 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.181sec\n",
      "Epoch 46 tr: l 0.589 a 0.836 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.201sec(train) 0.991sec(infer)\n",
      "Epoch 46 tst: l 0.595 a 0.835 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.156sec\n",
      "Epoch 47 tr: l 0.583 a 0.838 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.953sec(train) 0.982sec(infer)\n",
      "Epoch 47 tst: l 0.589 a 0.836 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.167sec\n",
      "Epoch 48 tr: l 0.578 a 0.840 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.261sec(train) 1.006sec(infer)\n",
      "Epoch 48 tst: l 0.584 a 0.838 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.162sec\n",
      "Epoch 49 tr: l 0.572 a 0.842 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.349sec(train) 1.037sec(infer)\n",
      "Epoch 49 tst: l 0.578 a 0.840 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.170sec\n",
      "Epoch 50 tr: l 0.566 a 0.843 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.459sec(train) 0.969sec(infer)\n",
      "Epoch 50 tst: l 0.573 a 0.842 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.173sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 51 tr: l 0.561 a 0.845 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.720sec(train) 1.020sec(infer)\n",
      "Epoch 51 tst: l 0.568 a 0.843 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.181sec\n",
      "Epoch 52 tr: l 0.556 a 0.847 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.586sec(train) 1.106sec(infer)\n",
      "Epoch 52 tst: l 0.563 a 0.844 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.222sec\n",
      "Epoch 53 tr: l 0.550 a 0.849 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.681sec(train) 1.086sec(infer)\n",
      "Epoch 53 tst: l 0.557 a 0.847 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.177sec\n",
      "Epoch 54 tr: l 0.545 a 0.850 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.541sec(train) 0.994sec(infer)\n",
      "Epoch 54 tst: l 0.552 a 0.848 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.140sec\n",
      "Epoch 55 tr: l 0.540 a 0.852 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.632sec(train) 0.937sec(infer)\n",
      "Epoch 55 tst: l 0.547 a 0.850 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.164sec\n",
      "Epoch 56 tr: l 0.535 a 0.853 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.782sec(train) 1.028sec(infer)\n",
      "Epoch 56 tst: l 0.542 a 0.852 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.207sec\n",
      "Epoch 57 tr: l 0.530 a 0.855 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.489sec(train) 0.932sec(infer)\n",
      "Epoch 57 tst: l 0.537 a 0.853 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.154sec\n",
      "Epoch 58 tr: l 0.525 a 0.857 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.173sec(train) 1.027sec(infer)\n",
      "Epoch 58 tst: l 0.533 a 0.855 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.166sec\n",
      "Epoch 59 tr: l 0.520 a 0.858 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.545sec(train) 1.084sec(infer)\n",
      "Epoch 59 tst: l 0.528 a 0.856 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.166sec\n",
      "Epoch 60 tr: l 0.516 a 0.860 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.802sec(train) 1.014sec(infer)\n",
      "Epoch 60 tst: l 0.523 a 0.858 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.167sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 61 tr: l 0.511 a 0.861 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.108sec(train) 0.969sec(infer)\n",
      "Epoch 61 tst: l 0.519 a 0.860 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.151sec\n",
      "Epoch 62 tr: l 0.506 a 0.862 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.190sec(train) 1.124sec(infer)\n",
      "Epoch 62 tst: l 0.514 a 0.861 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.163sec\n",
      "Epoch 63 tr: l 0.502 a 0.864 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.324sec(train) 0.937sec(infer)\n",
      "Epoch 63 tst: l 0.510 a 0.863 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.167sec\n",
      "Epoch 64 tr: l 0.497 a 0.865 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.681sec(train) 1.014sec(infer)\n",
      "Epoch 64 tst: l 0.506 a 0.864 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.160sec\n",
      "Epoch 65 tr: l 0.493 a 0.866 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.002sec(train) 1.016sec(infer)\n",
      "Epoch 65 tst: l 0.501 a 0.866 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.183sec\n",
      "Epoch 66 tr: l 0.489 a 0.868 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.185sec(train) 0.901sec(infer)\n",
      "Epoch 66 tst: l 0.497 a 0.867 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.157sec\n",
      "Epoch 67 tr: l 0.485 a 0.869 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.988sec(train) 0.921sec(infer)\n",
      "Epoch 67 tst: l 0.493 a 0.868 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.160sec\n",
      "Epoch 68 tr: l 0.481 a 0.870 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.637sec(train) 1.167sec(infer)\n",
      "Epoch 68 tst: l 0.489 a 0.869 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.192sec\n",
      "Epoch 69 tr: l 0.476 a 0.871 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 6.633sec(train) 1.047sec(infer)\n",
      "Epoch 69 tst: l 0.485 a 0.870 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.177sec\n",
      "Epoch 70 tr: l 0.472 a 0.872 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.035sec(train) 1.010sec(infer)\n",
      "Epoch 70 tst: l 0.481 a 0.871 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.171sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 71 tr: l 0.469 a 0.873 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.941sec(train) 0.987sec(infer)\n",
      "Epoch 71 tst: l 0.477 a 0.872 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.145sec\n",
      "Epoch 72 tr: l 0.465 a 0.874 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.285sec(train) 0.958sec(infer)\n",
      "Epoch 72 tst: l 0.474 a 0.873 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.169sec\n",
      "Epoch 73 tr: l 0.461 a 0.875 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.815sec(train) 0.984sec(infer)\n",
      "Epoch 73 tst: l 0.470 a 0.874 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.185sec\n",
      "Epoch 74 tr: l 0.457 a 0.876 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.890sec(train) 0.992sec(infer)\n",
      "Epoch 74 tst: l 0.466 a 0.875 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.181sec\n",
      "Epoch 75 tr: l 0.454 a 0.877 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.321sec(train) 0.926sec(infer)\n",
      "Epoch 75 tst: l 0.463 a 0.876 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.161sec\n",
      "Epoch 76 tr: l 0.450 a 0.878 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.814sec(train) 1.011sec(infer)\n",
      "Epoch 76 tst: l 0.459 a 0.878 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.163sec\n",
      "Epoch 77 tr: l 0.447 a 0.879 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.257sec(train) 0.865sec(infer)\n",
      "Epoch 77 tst: l 0.456 a 0.879 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.154sec\n",
      "Epoch 78 tr: l 0.443 a 0.880 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.700sec(train) 1.012sec(infer)\n",
      "Epoch 78 tst: l 0.452 a 0.880 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.177sec\n",
      "Epoch 79 tr: l 0.440 a 0.881 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.571sec(train) 1.070sec(infer)\n",
      "Epoch 79 tst: l 0.449 a 0.881 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.181sec\n",
      "Epoch 80 tr: l 0.437 a 0.882 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.395sec(train) 1.013sec(infer)\n",
      "Epoch 80 tst: l 0.446 a 0.881 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.177sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 81 tr: l 0.433 a 0.883 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.723sec(train) 1.118sec(infer)\n",
      "Epoch 81 tst: l 0.442 a 0.882 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.170sec\n",
      "Epoch 82 tr: l 0.430 a 0.884 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.367sec(train) 0.971sec(infer)\n",
      "Epoch 82 tst: l 0.439 a 0.883 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.166sec\n",
      "Epoch 83 tr: l 0.427 a 0.884 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.758sec(train) 1.112sec(infer)\n",
      "Epoch 83 tst: l 0.436 a 0.884 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.171sec\n",
      "Epoch 84 tr: l 0.424 a 0.885 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 6.487sec(train) 1.227sec(infer)\n",
      "Epoch 84 tst: l 0.433 a 0.884 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.162sec\n",
      "Epoch 85 tr: l 0.421 a 0.886 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.521sec(train) 1.079sec(infer)\n",
      "Epoch 85 tst: l 0.430 a 0.886 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.142sec\n",
      "Epoch 86 tr: l 0.418 a 0.887 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.892sec(train) 1.009sec(infer)\n",
      "Epoch 86 tst: l 0.427 a 0.887 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.164sec\n",
      "Epoch 87 tr: l 0.415 a 0.888 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.830sec(train) 0.998sec(infer)\n",
      "Epoch 87 tst: l 0.424 a 0.887 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.152sec\n",
      "Epoch 88 tr: l 0.412 a 0.888 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.391sec(train) 1.008sec(infer)\n",
      "Epoch 88 tst: l 0.422 a 0.888 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.173sec\n",
      "Epoch 89 tr: l 0.409 a 0.889 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.467sec(train) 1.027sec(infer)\n",
      "Epoch 89 tst: l 0.419 a 0.889 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.170sec\n",
      "Epoch 90 tr: l 0.407 a 0.890 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.386sec(train) 0.987sec(infer)\n",
      "Epoch 90 tst: l 0.416 a 0.890 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.170sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 91 tr: l 0.404 a 0.890 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.056sec(train) 0.933sec(infer)\n",
      "Epoch 91 tst: l 0.413 a 0.890 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.151sec\n",
      "Epoch 92 tr: l 0.401 a 0.891 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.795sec(train) 0.939sec(infer)\n",
      "Epoch 92 tst: l 0.411 a 0.891 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.215sec\n",
      "Epoch 93 tr: l 0.399 a 0.892 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.514sec(train) 0.918sec(infer)\n",
      "Epoch 93 tst: l 0.408 a 0.892 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.175sec\n",
      "Epoch 94 tr: l 0.396 a 0.892 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.098sec(train) 0.938sec(infer)\n",
      "Epoch 94 tst: l 0.406 a 0.892 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.167sec\n",
      "Epoch 95 tr: l 0.393 a 0.893 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.108sec(train) 0.969sec(infer)\n",
      "Epoch 95 tst: l 0.403 a 0.893 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.163sec\n",
      "Epoch 96 tr: l 0.391 a 0.894 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.688sec(train) 0.917sec(infer)\n",
      "Epoch 96 tst: l 0.401 a 0.893 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.160sec\n",
      "Epoch 97 tr: l 0.388 a 0.894 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.294sec(train) 0.834sec(infer)\n",
      "Epoch 97 tst: l 0.398 a 0.894 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.158sec\n",
      "Epoch 98 tr: l 0.386 a 0.895 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.257sec(train) 0.988sec(infer)\n",
      "Epoch 98 tst: l 0.396 a 0.895 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.164sec\n",
      "Epoch 99 tr: l 0.384 a 0.896 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.301sec(train) 0.831sec(infer)\n",
      "Epoch 99 tst: l 0.393 a 0.896 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.139sec\n",
      "Epoch 100 tr: l 0.381 a 0.896 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.798sec(train) 0.913sec(infer)\n",
      "Epoch 100 tst: l 0.391 a 0.896 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.152sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 101 tr: l 0.379 a 0.897 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.472sec(train) 0.989sec(infer)\n",
      "Epoch 101 tst: l 0.389 a 0.897 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.183sec\n",
      "Epoch 102 tr: l 0.377 a 0.897 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.726sec(train) 0.914sec(infer)\n",
      "Epoch 102 tst: l 0.387 a 0.898 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.176sec\n",
      "Epoch 103 tr: l 0.374 a 0.898 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.787sec(train) 0.903sec(infer)\n",
      "Epoch 103 tst: l 0.384 a 0.898 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.173sec\n",
      "Epoch 104 tr: l 0.372 a 0.898 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.789sec(train) 0.884sec(infer)\n",
      "Epoch 104 tst: l 0.382 a 0.899 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.166sec\n",
      "Epoch 105 tr: l 0.370 a 0.899 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.624sec(train) 0.897sec(infer)\n",
      "Epoch 105 tst: l 0.380 a 0.899 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.135sec\n",
      "Epoch 106 tr: l 0.368 a 0.900 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.730sec(train) 1.043sec(infer)\n",
      "Epoch 106 tst: l 0.378 a 0.900 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.179sec\n",
      "Epoch 107 tr: l 0.366 a 0.900 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.392sec(train) 1.014sec(infer)\n",
      "Epoch 107 tst: l 0.376 a 0.901 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.176sec\n",
      "Epoch 108 tr: l 0.364 a 0.901 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.619sec(train) 1.014sec(infer)\n",
      "Epoch 108 tst: l 0.374 a 0.901 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.176sec\n",
      "Epoch 109 tr: l 0.362 a 0.901 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.945sec(train) 0.928sec(infer)\n",
      "Epoch 109 tst: l 0.372 a 0.902 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.173sec\n",
      "Epoch 110 tr: l 0.360 a 0.902 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 6.089sec(train) 0.828sec(infer)\n",
      "Epoch 110 tst: l 0.370 a 0.903 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.147sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 111 tr: l 0.358 a 0.902 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.222sec(train) 0.800sec(infer)\n",
      "Epoch 111 tst: l 0.368 a 0.903 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.160sec\n",
      "Epoch 112 tr: l 0.356 a 0.903 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.700sec(train) 0.822sec(infer)\n",
      "Epoch 112 tst: l 0.366 a 0.904 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.146sec\n",
      "Epoch 113 tr: l 0.354 a 0.903 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.827sec(train) 0.721sec(infer)\n",
      "Epoch 113 tst: l 0.364 a 0.904 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.132sec\n",
      "Epoch 114 tr: l 0.352 a 0.904 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.959sec(train) 0.724sec(infer)\n",
      "Epoch 114 tst: l 0.362 a 0.905 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.128sec\n",
      "Epoch 115 tr: l 0.350 a 0.904 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.538sec(train) 0.801sec(infer)\n",
      "Epoch 115 tst: l 0.360 a 0.905 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.141sec\n",
      "Epoch 116 tr: l 0.348 a 0.905 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.921sec(train) 0.806sec(infer)\n",
      "Epoch 116 tst: l 0.358 a 0.906 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.143sec\n",
      "Epoch 117 tr: l 0.346 a 0.905 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.655sec(train) 0.906sec(infer)\n",
      "Epoch 117 tst: l 0.357 a 0.906 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.147sec\n",
      "Epoch 118 tr: l 0.344 a 0.905 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.505sec(train) 0.789sec(infer)\n",
      "Epoch 118 tst: l 0.355 a 0.907 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.138sec\n",
      "Epoch 119 tr: l 0.343 a 0.906 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.143sec(train) 0.873sec(infer)\n",
      "Epoch 119 tst: l 0.353 a 0.907 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.142sec\n",
      "Epoch 120 tr: l 0.341 a 0.906 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.701sec(train) 0.811sec(infer)\n",
      "Epoch 120 tst: l 0.351 a 0.907 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.135sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 121 tr: l 0.339 a 0.907 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.547sec(train) 0.849sec(infer)\n",
      "Epoch 121 tst: l 0.350 a 0.908 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.145sec\n",
      "Epoch 122 tr: l 0.337 a 0.907 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.409sec(train) 0.831sec(infer)\n",
      "Epoch 122 tst: l 0.348 a 0.909 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.150sec\n",
      "Epoch 123 tr: l 0.336 a 0.908 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.695sec(train) 0.713sec(infer)\n",
      "Epoch 123 tst: l 0.346 a 0.909 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.152sec\n",
      "Epoch 124 tr: l 0.334 a 0.908 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.613sec(train) 0.878sec(infer)\n",
      "Epoch 124 tst: l 0.345 a 0.909 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.121sec\n",
      "Epoch 125 tr: l 0.332 a 0.909 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.720sec(train) 0.802sec(infer)\n",
      "Epoch 125 tst: l 0.343 a 0.910 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.142sec\n",
      "Epoch 126 tr: l 0.331 a 0.909 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.599sec(train) 0.816sec(infer)\n",
      "Epoch 126 tst: l 0.341 a 0.910 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.136sec\n",
      "Epoch 127 tr: l 0.329 a 0.909 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 6.214sec(train) 0.784sec(infer)\n",
      "Epoch 127 tst: l 0.340 a 0.910 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.134sec\n",
      "Epoch 128 tr: l 0.327 a 0.910 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.736sec(train) 0.848sec(infer)\n",
      "Epoch 128 tst: l 0.338 a 0.910 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.164sec\n",
      "Epoch 129 tr: l 0.326 a 0.910 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.265sec(train) 0.889sec(infer)\n",
      "Epoch 129 tst: l 0.337 a 0.910 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.135sec\n",
      "Epoch 130 tr: l 0.324 a 0.911 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.707sec(train) 0.902sec(infer)\n",
      "Epoch 130 tst: l 0.335 a 0.911 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.147sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 131 tr: l 0.323 a 0.911 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.180sec(train) 0.694sec(infer)\n",
      "Epoch 131 tst: l 0.334 a 0.911 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.122sec\n",
      "Epoch 132 tr: l 0.321 a 0.911 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.311sec(train) 0.921sec(infer)\n",
      "Epoch 132 tst: l 0.332 a 0.911 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.149sec\n",
      "Epoch 133 tr: l 0.320 a 0.911 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.263sec(train) 0.805sec(infer)\n",
      "Epoch 133 tst: l 0.331 a 0.911 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.135sec\n",
      "Epoch 134 tr: l 0.318 a 0.912 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.592sec(train) 0.837sec(infer)\n",
      "Epoch 134 tst: l 0.329 a 0.912 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.144sec\n",
      "Epoch 135 tr: l 0.317 a 0.912 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.604sec(train) 0.781sec(infer)\n",
      "Epoch 135 tst: l 0.328 a 0.912 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.130sec\n",
      "Epoch 136 tr: l 0.315 a 0.913 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.755sec(train) 0.810sec(infer)\n",
      "Epoch 136 tst: l 0.327 a 0.912 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.140sec\n",
      "Epoch 137 tr: l 0.314 a 0.913 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.910sec(train) 0.853sec(infer)\n",
      "Epoch 137 tst: l 0.325 a 0.913 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.147sec\n",
      "Epoch 138 tr: l 0.312 a 0.913 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.535sec(train) 0.802sec(infer)\n",
      "Epoch 138 tst: l 0.324 a 0.913 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.136sec\n",
      "Epoch 139 tr: l 0.311 a 0.914 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.095sec(train) 0.848sec(infer)\n",
      "Epoch 139 tst: l 0.322 a 0.913 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.142sec\n",
      "Epoch 140 tr: l 0.310 a 0.914 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.653sec(train) 0.810sec(infer)\n",
      "Epoch 140 tst: l 0.321 a 0.914 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.139sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 141 tr: l 0.308 a 0.914 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.196sec(train) 0.788sec(infer)\n",
      "Epoch 141 tst: l 0.320 a 0.914 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.130sec\n",
      "Epoch 142 tr: l 0.307 a 0.915 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.951sec(train) 0.797sec(infer)\n",
      "Epoch 142 tst: l 0.318 a 0.914 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.138sec\n",
      "Epoch 143 tr: l 0.306 a 0.915 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.393sec(train) 0.802sec(infer)\n",
      "Epoch 143 tst: l 0.317 a 0.915 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.128sec\n",
      "Epoch 144 tr: l 0.304 a 0.915 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.544sec(train) 0.804sec(infer)\n",
      "Epoch 144 tst: l 0.316 a 0.915 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.134sec\n",
      "Epoch 145 tr: l 0.303 a 0.916 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.516sec(train) 0.855sec(infer)\n",
      "Epoch 145 tst: l 0.315 a 0.916 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.151sec\n",
      "Epoch 146 tr: l 0.302 a 0.916 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.723sec(train) 0.771sec(infer)\n",
      "Epoch 146 tst: l 0.313 a 0.916 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.130sec\n",
      "Epoch 147 tr: l 0.300 a 0.916 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.424sec(train) 0.815sec(infer)\n",
      "Epoch 147 tst: l 0.312 a 0.916 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.129sec\n",
      "Epoch 148 tr: l 0.299 a 0.917 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.093sec(train) 0.899sec(infer)\n",
      "Epoch 148 tst: l 0.311 a 0.917 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.170sec\n",
      "Epoch 149 tr: l 0.298 a 0.917 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.736sec(train) 0.766sec(infer)\n",
      "Epoch 149 tst: l 0.310 a 0.917 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.120sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "---train cluster Ended in 0.27 hour (965.614 sec) \n",
      "---------------------------------DFedAvgM, lr: 0.1, seed: 6753---------------------------------\n",
      "config: {'m': 240, 'm_test': 40, 'p': 2, 'n': 500, 'uneven': True, 'local_model_init': False, 'Gp': 0.1, 'graph': 'er', 'agg': 'seq', 'h1': 200, 'num_epochs': 150, 'batch_size': 100, 'tau': 10, 'lr': 0.1, 'data_seed': 6753, 'train_seed': 6753, 'config_override': '', 'project_dir': 'output_dfca_gi'}\n",
      "Using device: cuda:1\n",
      "Epoch -1 tr: l 2.300 a 0.116 clct[np.int64(240), np.int64(0)] cl_acc 0.500  0.708sec\n",
      "Epoch -1 tst: l 2.302 a 0.118 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.120sec\n",
      "Epoch 0 tr: l 2.160 a 0.372 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.738sec(train) 0.670sec(infer)\n",
      "Epoch 0 tst: l 2.169 a 0.372 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.108sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 1 tr: l 1.989 a 0.495 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.449sec(train) 0.677sec(infer)\n",
      "Epoch 1 tst: l 1.995 a 0.489 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.104sec\n",
      "Epoch 2 tr: l 1.788 a 0.571 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.941sec(train) 0.724sec(infer)\n",
      "Epoch 2 tst: l 1.789 a 0.567 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.112sec\n",
      "Epoch 3 tr: l 1.593 a 0.618 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.674sec(train) 0.692sec(infer)\n",
      "Epoch 3 tst: l 1.590 a 0.616 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.115sec\n",
      "Epoch 4 tr: l 1.431 a 0.652 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 6.071sec(train) 0.708sec(infer)\n",
      "Epoch 4 tst: l 1.426 a 0.651 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.115sec\n",
      "Epoch 5 tr: l 1.305 a 0.674 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.735sec(train) 0.733sec(infer)\n",
      "Epoch 5 tst: l 1.300 a 0.675 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.120sec\n",
      "Epoch 6 tr: l 1.208 a 0.690 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.687sec(train) 0.674sec(infer)\n",
      "Epoch 6 tst: l 1.202 a 0.694 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.121sec\n",
      "Epoch 7 tr: l 1.131 a 0.703 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.829sec(train) 0.672sec(infer)\n",
      "Epoch 7 tst: l 1.125 a 0.706 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.111sec\n",
      "Epoch 8 tr: l 1.070 a 0.714 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.766sec(train) 0.775sec(infer)\n",
      "Epoch 8 tst: l 1.064 a 0.717 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.146sec\n",
      "Epoch 9 tr: l 1.021 a 0.722 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.143sec(train) 0.796sec(infer)\n",
      "Epoch 9 tst: l 1.015 a 0.725 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.134sec\n",
      "Epoch 10 tr: l 0.980 a 0.730 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.445sec(train) 0.810sec(infer)\n",
      "Epoch 10 tst: l 0.974 a 0.731 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.143sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 11 tr: l 0.946 a 0.737 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.243sec(train) 0.844sec(infer)\n",
      "Epoch 11 tst: l 0.940 a 0.737 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.150sec\n",
      "Epoch 12 tr: l 0.917 a 0.743 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.525sec(train) 0.769sec(infer)\n",
      "Epoch 12 tst: l 0.911 a 0.743 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.131sec\n",
      "Epoch 13 tr: l 0.892 a 0.749 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.265sec(train) 0.762sec(infer)\n",
      "Epoch 13 tst: l 0.886 a 0.749 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.129sec\n",
      "Epoch 14 tr: l 0.870 a 0.754 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.788sec(train) 0.839sec(infer)\n",
      "Epoch 14 tst: l 0.864 a 0.754 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.133sec\n",
      "Epoch 15 tr: l 0.851 a 0.759 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.101sec(train) 0.764sec(infer)\n",
      "Epoch 15 tst: l 0.845 a 0.760 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.131sec\n",
      "Epoch 16 tr: l 0.833 a 0.764 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.213sec(train) 0.808sec(infer)\n",
      "Epoch 16 tst: l 0.827 a 0.765 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.139sec\n",
      "Epoch 17 tr: l 0.817 a 0.768 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.354sec(train) 0.706sec(infer)\n",
      "Epoch 17 tst: l 0.811 a 0.770 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.125sec\n",
      "Epoch 18 tr: l 0.803 a 0.771 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.315sec(train) 0.793sec(infer)\n",
      "Epoch 18 tst: l 0.797 a 0.774 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.123sec\n",
      "Epoch 19 tr: l 0.789 a 0.775 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.113sec(train) 0.856sec(infer)\n",
      "Epoch 19 tst: l 0.784 a 0.778 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.164sec\n",
      "Epoch 20 tr: l 0.777 a 0.778 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.768sec(train) 0.838sec(infer)\n",
      "Epoch 20 tst: l 0.771 a 0.782 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.138sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 21 tr: l 0.765 a 0.782 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.577sec(train) 1.020sec(infer)\n",
      "Epoch 21 tst: l 0.760 a 0.786 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.163sec\n",
      "Epoch 22 tr: l 0.754 a 0.784 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.439sec(train) 0.802sec(infer)\n",
      "Epoch 22 tst: l 0.749 a 0.790 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.138sec\n",
      "Epoch 23 tr: l 0.744 a 0.787 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.570sec(train) 0.810sec(infer)\n",
      "Epoch 23 tst: l 0.739 a 0.793 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.132sec\n",
      "Epoch 24 tr: l 0.734 a 0.791 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.200sec(train) 0.653sec(infer)\n",
      "Epoch 24 tst: l 0.730 a 0.796 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.114sec\n",
      "Epoch 25 tr: l 0.724 a 0.793 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.358sec(train) 0.766sec(infer)\n",
      "Epoch 25 tst: l 0.720 a 0.799 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.145sec\n",
      "Epoch 26 tr: l 0.715 a 0.796 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.686sec(train) 0.767sec(infer)\n",
      "Epoch 26 tst: l 0.712 a 0.802 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.130sec\n",
      "Epoch 27 tr: l 0.707 a 0.799 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.245sec(train) 0.867sec(infer)\n",
      "Epoch 27 tst: l 0.703 a 0.805 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.153sec\n",
      "Epoch 28 tr: l 0.698 a 0.801 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.928sec(train) 1.077sec(infer)\n",
      "Epoch 28 tst: l 0.695 a 0.807 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.143sec\n",
      "Epoch 29 tr: l 0.690 a 0.804 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.778sec(train) 0.923sec(infer)\n",
      "Epoch 29 tst: l 0.687 a 0.809 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.162sec\n",
      "Epoch 30 tr: l 0.682 a 0.806 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.479sec(train) 0.841sec(infer)\n",
      "Epoch 30 tst: l 0.680 a 0.811 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.144sec\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.809 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.949sec(train) 0.651sec(infer)\n",
      "Epoch 31 tst: l 0.672 a 0.814 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.108sec\n",
      "Epoch 32 tr: l 0.667 a 0.811 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.701sec(train) 0.719sec(infer)\n",
      "Epoch 32 tst: l 0.665 a 0.816 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.125sec\n",
      "Epoch 33 tr: l 0.659 a 0.814 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 6.237sec(train) 0.848sec(infer)\n",
      "Epoch 33 tst: l 0.658 a 0.818 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.168sec\n",
      "Epoch 34 tr: l 0.652 a 0.816 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.223sec(train) 0.775sec(infer)\n",
      "Epoch 34 tst: l 0.651 a 0.820 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.130sec\n",
      "Epoch 35 tr: l 0.645 a 0.818 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.427sec(train) 0.698sec(infer)\n",
      "Epoch 35 tst: l 0.644 a 0.821 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.119sec\n",
      "Epoch 36 tr: l 0.638 a 0.820 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.576sec(train) 0.685sec(infer)\n",
      "Epoch 36 tst: l 0.638 a 0.823 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.156sec\n",
      "Epoch 37 tr: l 0.631 a 0.823 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.143sec(train) 0.758sec(infer)\n",
      "Epoch 37 tst: l 0.631 a 0.826 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.128sec\n",
      "Epoch 38 tr: l 0.625 a 0.825 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.987sec(train) 0.790sec(infer)\n",
      "Epoch 38 tst: l 0.625 a 0.828 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.130sec\n",
      "Epoch 39 tr: l 0.618 a 0.827 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.682sec(train) 0.707sec(infer)\n",
      "Epoch 39 tst: l 0.618 a 0.831 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.119sec\n",
      "Epoch 40 tr: l 0.612 a 0.829 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.783sec(train) 0.747sec(infer)\n",
      "Epoch 40 tst: l 0.612 a 0.833 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.134sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 41 tr: l 0.605 a 0.832 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.863sec(train) 0.788sec(infer)\n",
      "Epoch 41 tst: l 0.606 a 0.835 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.134sec\n",
      "Epoch 42 tr: l 0.599 a 0.834 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.415sec(train) 0.798sec(infer)\n",
      "Epoch 42 tst: l 0.600 a 0.837 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.151sec\n",
      "Epoch 43 tr: l 0.593 a 0.836 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.593sec(train) 0.712sec(infer)\n",
      "Epoch 43 tst: l 0.594 a 0.839 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.123sec\n",
      "Epoch 44 tr: l 0.587 a 0.838 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.137sec(train) 0.704sec(infer)\n",
      "Epoch 44 tst: l 0.588 a 0.841 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.120sec\n",
      "Epoch 45 tr: l 0.581 a 0.840 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.222sec(train) 0.803sec(infer)\n",
      "Epoch 45 tst: l 0.583 a 0.843 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.134sec\n",
      "Epoch 46 tr: l 0.575 a 0.842 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.124sec(train) 0.708sec(infer)\n",
      "Epoch 46 tst: l 0.577 a 0.845 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.124sec\n",
      "Epoch 47 tr: l 0.569 a 0.844 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.025sec(train) 0.736sec(infer)\n",
      "Epoch 47 tst: l 0.571 a 0.846 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.123sec\n",
      "Epoch 48 tr: l 0.563 a 0.845 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.178sec(train) 0.791sec(infer)\n",
      "Epoch 48 tst: l 0.566 a 0.848 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.134sec\n",
      "Epoch 49 tr: l 0.558 a 0.847 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.994sec(train) 0.897sec(infer)\n",
      "Epoch 49 tst: l 0.560 a 0.850 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.148sec\n",
      "Epoch 50 tr: l 0.552 a 0.849 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.440sec(train) 0.709sec(infer)\n",
      "Epoch 50 tst: l 0.555 a 0.852 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.118sec\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.851 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.118sec(train) 0.688sec(infer)\n",
      "Epoch 51 tst: l 0.550 a 0.853 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.120sec\n",
      "Epoch 52 tr: l 0.541 a 0.852 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.184sec(train) 0.787sec(infer)\n",
      "Epoch 52 tst: l 0.544 a 0.855 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.132sec\n",
      "Epoch 53 tr: l 0.536 a 0.854 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.611sec(train) 0.783sec(infer)\n",
      "Epoch 53 tst: l 0.539 a 0.857 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.124sec\n",
      "Epoch 54 tr: l 0.530 a 0.856 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.402sec(train) 0.677sec(infer)\n",
      "Epoch 54 tst: l 0.534 a 0.858 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.118sec\n",
      "Epoch 55 tr: l 0.525 a 0.858 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.173sec(train) 0.682sec(infer)\n",
      "Epoch 55 tst: l 0.529 a 0.859 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.119sec\n",
      "Epoch 56 tr: l 0.520 a 0.859 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.358sec(train) 0.678sec(infer)\n",
      "Epoch 56 tst: l 0.524 a 0.861 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.119sec\n",
      "Epoch 57 tr: l 0.515 a 0.861 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.467sec(train) 0.793sec(infer)\n",
      "Epoch 57 tst: l 0.519 a 0.863 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.121sec\n",
      "Epoch 58 tr: l 0.510 a 0.862 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.593sec(train) 0.805sec(infer)\n",
      "Epoch 58 tst: l 0.515 a 0.864 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.118sec\n",
      "Epoch 59 tr: l 0.506 a 0.864 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.424sec(train) 0.892sec(infer)\n",
      "Epoch 59 tst: l 0.510 a 0.866 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.127sec\n",
      "Epoch 60 tr: l 0.501 a 0.865 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.639sec(train) 0.643sec(infer)\n",
      "Epoch 60 tst: l 0.505 a 0.867 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.118sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 61 tr: l 0.496 a 0.866 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.184sec(train) 0.755sec(infer)\n",
      "Epoch 61 tst: l 0.501 a 0.868 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.122sec\n",
      "Epoch 62 tr: l 0.492 a 0.868 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.460sec(train) 0.808sec(infer)\n",
      "Epoch 62 tst: l 0.497 a 0.870 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.151sec\n",
      "Epoch 63 tr: l 0.487 a 0.869 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.427sec(train) 0.717sec(infer)\n",
      "Epoch 63 tst: l 0.492 a 0.872 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.127sec\n",
      "Epoch 64 tr: l 0.483 a 0.870 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.190sec(train) 0.809sec(infer)\n",
      "Epoch 64 tst: l 0.488 a 0.873 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.126sec\n",
      "Epoch 65 tr: l 0.479 a 0.871 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.552sec(train) 0.879sec(infer)\n",
      "Epoch 65 tst: l 0.484 a 0.874 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.141sec\n",
      "Epoch 66 tr: l 0.475 a 0.872 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.188sec(train) 0.794sec(infer)\n",
      "Epoch 66 tst: l 0.480 a 0.875 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.144sec\n",
      "Epoch 67 tr: l 0.470 a 0.873 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.278sec(train) 0.856sec(infer)\n",
      "Epoch 67 tst: l 0.476 a 0.876 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.145sec\n",
      "Epoch 68 tr: l 0.466 a 0.874 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.690sec(train) 0.915sec(infer)\n",
      "Epoch 68 tst: l 0.472 a 0.877 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.163sec\n",
      "Epoch 69 tr: l 0.462 a 0.875 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.954sec(train) 0.820sec(infer)\n",
      "Epoch 69 tst: l 0.468 a 0.878 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.154sec\n",
      "Epoch 70 tr: l 0.459 a 0.877 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.270sec(train) 0.845sec(infer)\n",
      "Epoch 70 tst: l 0.464 a 0.880 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.143sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 71 tr: l 0.455 a 0.877 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.430sec(train) 0.768sec(infer)\n",
      "Epoch 71 tst: l 0.460 a 0.881 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.128sec\n",
      "Epoch 72 tr: l 0.451 a 0.879 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.483sec(train) 0.872sec(infer)\n",
      "Epoch 72 tst: l 0.457 a 0.882 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.138sec\n",
      "Epoch 73 tr: l 0.447 a 0.879 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.531sec(train) 0.683sec(infer)\n",
      "Epoch 73 tst: l 0.453 a 0.884 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.122sec\n",
      "Epoch 74 tr: l 0.444 a 0.880 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.315sec(train) 0.852sec(infer)\n",
      "Epoch 74 tst: l 0.449 a 0.885 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.152sec\n",
      "Epoch 75 tr: l 0.440 a 0.882 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.297sec(train) 0.788sec(infer)\n",
      "Epoch 75 tst: l 0.446 a 0.886 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.126sec\n",
      "Epoch 76 tr: l 0.437 a 0.882 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.454sec(train) 0.713sec(infer)\n",
      "Epoch 76 tst: l 0.443 a 0.886 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.119sec\n",
      "Epoch 77 tr: l 0.434 a 0.883 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.324sec(train) 0.719sec(infer)\n",
      "Epoch 77 tst: l 0.439 a 0.887 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.123sec\n",
      "Epoch 78 tr: l 0.430 a 0.884 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.333sec(train) 0.702sec(infer)\n",
      "Epoch 78 tst: l 0.436 a 0.888 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.123sec\n",
      "Epoch 79 tr: l 0.427 a 0.885 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.301sec(train) 0.689sec(infer)\n",
      "Epoch 79 tst: l 0.433 a 0.889 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.115sec\n",
      "Epoch 80 tr: l 0.424 a 0.886 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.136sec(train) 0.680sec(infer)\n",
      "Epoch 80 tst: l 0.430 a 0.890 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.118sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 81 tr: l 0.421 a 0.887 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.624sec(train) 0.919sec(infer)\n",
      "Epoch 81 tst: l 0.427 a 0.891 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.157sec\n",
      "Epoch 82 tr: l 0.418 a 0.888 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.261sec(train) 0.751sec(infer)\n",
      "Epoch 82 tst: l 0.424 a 0.892 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.124sec\n",
      "Epoch 83 tr: l 0.415 a 0.888 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.230sec(train) 0.904sec(infer)\n",
      "Epoch 83 tst: l 0.421 a 0.892 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.150sec\n",
      "Epoch 84 tr: l 0.412 a 0.889 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.172sec(train) 0.755sec(infer)\n",
      "Epoch 84 tst: l 0.418 a 0.893 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.124sec\n",
      "Epoch 85 tr: l 0.409 a 0.890 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.144sec(train) 0.798sec(infer)\n",
      "Epoch 85 tst: l 0.415 a 0.893 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.134sec\n",
      "Epoch 86 tr: l 0.406 a 0.891 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.042sec(train) 0.814sec(infer)\n",
      "Epoch 86 tst: l 0.412 a 0.894 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.132sec\n",
      "Epoch 87 tr: l 0.403 a 0.891 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.327sec(train) 0.739sec(infer)\n",
      "Epoch 87 tst: l 0.410 a 0.895 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.125sec\n",
      "Epoch 88 tr: l 0.401 a 0.892 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.942sec(train) 0.755sec(infer)\n",
      "Epoch 88 tst: l 0.407 a 0.896 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.126sec\n",
      "Epoch 89 tr: l 0.398 a 0.893 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.382sec(train) 0.707sec(infer)\n",
      "Epoch 89 tst: l 0.404 a 0.896 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.123sec\n",
      "Epoch 90 tr: l 0.395 a 0.894 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.804sec(train) 0.708sec(infer)\n",
      "Epoch 90 tst: l 0.402 a 0.897 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.118sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 91 tr: l 0.393 a 0.894 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.697sec(train) 0.698sec(infer)\n",
      "Epoch 91 tst: l 0.399 a 0.897 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.116sec\n",
      "Epoch 92 tr: l 0.390 a 0.895 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.188sec(train) 0.760sec(infer)\n",
      "Epoch 92 tst: l 0.397 a 0.898 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.130sec\n",
      "Epoch 93 tr: l 0.388 a 0.895 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.442sec(train) 0.806sec(infer)\n",
      "Epoch 93 tst: l 0.394 a 0.898 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.130sec\n",
      "Epoch 94 tr: l 0.385 a 0.896 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.387sec(train) 0.748sec(infer)\n",
      "Epoch 94 tst: l 0.392 a 0.899 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.124sec\n",
      "Epoch 95 tr: l 0.383 a 0.897 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.278sec(train) 0.821sec(infer)\n",
      "Epoch 95 tst: l 0.390 a 0.899 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.139sec\n",
      "Epoch 96 tr: l 0.381 a 0.897 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.056sec(train) 0.761sec(infer)\n",
      "Epoch 96 tst: l 0.387 a 0.900 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.126sec\n",
      "Epoch 97 tr: l 0.378 a 0.898 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.857sec(train) 0.780sec(infer)\n",
      "Epoch 97 tst: l 0.385 a 0.900 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.133sec\n",
      "Epoch 98 tr: l 0.376 a 0.898 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.623sec(train) 0.783sec(infer)\n",
      "Epoch 98 tst: l 0.383 a 0.900 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.158sec\n",
      "Epoch 99 tr: l 0.374 a 0.899 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.659sec(train) 0.839sec(infer)\n",
      "Epoch 99 tst: l 0.381 a 0.901 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.151sec\n",
      "Epoch 100 tr: l 0.371 a 0.899 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.334sec(train) 0.798sec(infer)\n",
      "Epoch 100 tst: l 0.379 a 0.902 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.136sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 101 tr: l 0.369 a 0.900 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.142sec(train) 0.837sec(infer)\n",
      "Epoch 101 tst: l 0.376 a 0.902 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.158sec\n",
      "Epoch 102 tr: l 0.367 a 0.901 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.783sec(train) 0.719sec(infer)\n",
      "Epoch 102 tst: l 0.374 a 0.903 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.125sec\n",
      "Epoch 103 tr: l 0.365 a 0.901 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.022sec(train) 0.850sec(infer)\n",
      "Epoch 103 tst: l 0.372 a 0.903 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.150sec\n",
      "Epoch 104 tr: l 0.363 a 0.902 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.241sec(train) 0.671sec(infer)\n",
      "Epoch 104 tst: l 0.370 a 0.903 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.122sec\n",
      "Epoch 105 tr: l 0.361 a 0.902 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.775sec(train) 0.807sec(infer)\n",
      "Epoch 105 tst: l 0.368 a 0.904 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.143sec\n",
      "Epoch 106 tr: l 0.359 a 0.902 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.193sec(train) 0.652sec(infer)\n",
      "Epoch 106 tst: l 0.366 a 0.904 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.113sec\n",
      "Epoch 107 tr: l 0.357 a 0.903 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.121sec(train) 0.669sec(infer)\n",
      "Epoch 107 tst: l 0.364 a 0.905 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.109sec\n",
      "Epoch 108 tr: l 0.355 a 0.903 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.604sec(train) 0.797sec(infer)\n",
      "Epoch 108 tst: l 0.362 a 0.905 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.211sec\n",
      "Epoch 109 tr: l 0.353 a 0.904 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.143sec(train) 0.752sec(infer)\n",
      "Epoch 109 tst: l 0.361 a 0.905 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.135sec\n",
      "Epoch 110 tr: l 0.351 a 0.904 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.424sec(train) 0.743sec(infer)\n",
      "Epoch 110 tst: l 0.359 a 0.905 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.202sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 111 tr: l 0.349 a 0.905 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.453sec(train) 0.761sec(infer)\n",
      "Epoch 111 tst: l 0.357 a 0.906 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.131sec\n",
      "Epoch 112 tr: l 0.347 a 0.905 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.671sec(train) 0.688sec(infer)\n",
      "Epoch 112 tst: l 0.355 a 0.906 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.124sec\n",
      "Epoch 113 tr: l 0.345 a 0.906 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.951sec(train) 0.895sec(infer)\n",
      "Epoch 113 tst: l 0.353 a 0.906 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.177sec\n",
      "Epoch 114 tr: l 0.344 a 0.906 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.599sec(train) 0.818sec(infer)\n",
      "Epoch 114 tst: l 0.351 a 0.906 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.153sec\n",
      "Epoch 115 tr: l 0.342 a 0.906 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.855sec(train) 0.733sec(infer)\n",
      "Epoch 115 tst: l 0.350 a 0.907 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.155sec\n",
      "Epoch 116 tr: l 0.340 a 0.907 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.778sec(train) 1.075sec(infer)\n",
      "Epoch 116 tst: l 0.348 a 0.907 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.169sec\n",
      "Epoch 117 tr: l 0.338 a 0.907 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.647sec(train) 1.002sec(infer)\n",
      "Epoch 117 tst: l 0.346 a 0.907 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.177sec\n",
      "Epoch 118 tr: l 0.337 a 0.908 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.842sec(train) 0.802sec(infer)\n",
      "Epoch 118 tst: l 0.345 a 0.907 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.140sec\n",
      "Epoch 119 tr: l 0.335 a 0.908 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.439sec(train) 0.743sec(infer)\n",
      "Epoch 119 tst: l 0.343 a 0.908 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.135sec\n",
      "Epoch 120 tr: l 0.333 a 0.909 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 6.034sec(train) 0.806sec(infer)\n",
      "Epoch 120 tst: l 0.341 a 0.908 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.148sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 121 tr: l 0.332 a 0.909 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.135sec(train) 0.794sec(infer)\n",
      "Epoch 121 tst: l 0.340 a 0.908 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.136sec\n",
      "Epoch 122 tr: l 0.330 a 0.909 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 6.537sec(train) 0.866sec(infer)\n",
      "Epoch 122 tst: l 0.338 a 0.909 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.137sec\n",
      "Epoch 123 tr: l 0.328 a 0.910 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.869sec(train) 0.783sec(infer)\n",
      "Epoch 123 tst: l 0.337 a 0.909 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.137sec\n",
      "Epoch 124 tr: l 0.327 a 0.910 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.815sec(train) 0.781sec(infer)\n",
      "Epoch 124 tst: l 0.335 a 0.910 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.133sec\n",
      "Epoch 125 tr: l 0.325 a 0.910 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.066sec(train) 0.866sec(infer)\n",
      "Epoch 125 tst: l 0.334 a 0.910 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.128sec\n",
      "Epoch 126 tr: l 0.324 a 0.911 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.532sec(train) 0.791sec(infer)\n",
      "Epoch 126 tst: l 0.332 a 0.911 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.137sec\n",
      "Epoch 127 tr: l 0.322 a 0.911 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.433sec(train) 0.891sec(infer)\n",
      "Epoch 127 tst: l 0.331 a 0.911 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.159sec\n",
      "Epoch 128 tr: l 0.321 a 0.911 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.232sec(train) 0.796sec(infer)\n",
      "Epoch 128 tst: l 0.329 a 0.911 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.129sec\n",
      "Epoch 129 tr: l 0.319 a 0.912 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.604sec(train) 0.752sec(infer)\n",
      "Epoch 129 tst: l 0.328 a 0.911 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.131sec\n",
      "Epoch 130 tr: l 0.318 a 0.912 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.912sec(train) 0.739sec(infer)\n",
      "Epoch 130 tst: l 0.326 a 0.912 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.124sec\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.913 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.003sec(train) 0.788sec(infer)\n",
      "Epoch 131 tst: l 0.325 a 0.912 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.134sec\n",
      "Epoch 132 tr: l 0.315 a 0.913 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.921sec(train) 0.712sec(infer)\n",
      "Epoch 132 tst: l 0.323 a 0.912 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.143sec\n",
      "Epoch 133 tr: l 0.313 a 0.913 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 6.257sec(train) 0.948sec(infer)\n",
      "Epoch 133 tst: l 0.322 a 0.912 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.159sec\n",
      "Epoch 134 tr: l 0.312 a 0.914 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.296sec(train) 0.817sec(infer)\n",
      "Epoch 134 tst: l 0.321 a 0.913 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.138sec\n",
      "Epoch 135 tr: l 0.310 a 0.914 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.269sec(train) 0.869sec(infer)\n",
      "Epoch 135 tst: l 0.319 a 0.913 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.156sec\n",
      "Epoch 136 tr: l 0.309 a 0.914 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 4.701sec(train) 0.695sec(infer)\n",
      "Epoch 136 tst: l 0.318 a 0.913 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.122sec\n",
      "Epoch 137 tr: l 0.308 a 0.915 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.200sec(train) 0.500sec(infer)\n",
      "Epoch 137 tst: l 0.317 a 0.913 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.087sec\n",
      "Epoch 138 tr: l 0.306 a 0.915 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.392sec(train) 0.654sec(infer)\n",
      "Epoch 138 tst: l 0.315 a 0.914 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.104sec\n",
      "Epoch 139 tr: l 0.305 a 0.915 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.639sec(train) 0.749sec(infer)\n",
      "Epoch 139 tst: l 0.314 a 0.914 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.142sec\n",
      "Epoch 140 tr: l 0.303 a 0.916 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.561sec(train) 0.755sec(infer)\n",
      "Epoch 140 tst: l 0.313 a 0.914 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.127sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 141 tr: l 0.302 a 0.916 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.395sec(train) 0.762sec(infer)\n",
      "Epoch 141 tst: l 0.311 a 0.915 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.124sec\n",
      "Epoch 142 tr: l 0.301 a 0.916 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.415sec(train) 0.861sec(infer)\n",
      "Epoch 142 tst: l 0.310 a 0.915 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.106sec\n",
      "Epoch 143 tr: l 0.300 a 0.917 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.007sec(train) 0.750sec(infer)\n",
      "Epoch 143 tst: l 0.309 a 0.915 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.114sec\n",
      "Epoch 144 tr: l 0.298 a 0.917 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.520sec(train) 0.706sec(infer)\n",
      "Epoch 144 tst: l 0.308 a 0.916 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.121sec\n",
      "Epoch 145 tr: l 0.297 a 0.917 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.077sec(train) 0.655sec(infer)\n",
      "Epoch 145 tst: l 0.307 a 0.916 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.111sec\n",
      "Epoch 146 tr: l 0.296 a 0.917 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.509sec(train) 0.645sec(infer)\n",
      "Epoch 146 tst: l 0.305 a 0.916 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.111sec\n",
      "Epoch 147 tr: l 0.294 a 0.918 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.390sec(train) 0.720sec(infer)\n",
      "Epoch 147 tst: l 0.304 a 0.916 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.120sec\n",
      "Epoch 148 tr: l 0.293 a 0.918 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.534sec(train) 0.753sec(infer)\n",
      "Epoch 148 tst: l 0.303 a 0.917 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.134sec\n",
      "Epoch 149 tr: l 0.292 a 0.918 clct[np.int64(240), np.int64(0)] cl_acc 0.500  lr 0.100000 5.335sec(train) 0.701sec(infer)\n",
      "Epoch 149 tst: l 0.302 a 0.917 clct[np.int64(40), np.int64(0)] cl_acc 0.500  0.134sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "---train cluster Ended in 0.25 hour (913.221 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",
    "d_fedavg_m = rc[3].pull('d_fedavg_m', 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",
    "d_fedavg_m_last_acc = rc[3].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",
    "d_fedavg_m_std = rc[3].pull('res_std', block=True)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "DFCA-LI Experiment Outputs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-20T07:17:14.223934Z",
     "iopub.status.busy": "2025-09-20T07:17:14.223131Z",
     "iopub.status.idle": "2025-09-20T07:17:14.233532Z",
     "shell.execute_reply": "2025-09-20T07:17:14.231953Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "---------------------------------IFCA, lr: 0.1, seed: 6003---------------------------------\n",
      "config: {'m': 240, 'm_test': 40, 'p': 2, 'n': 500, 'uneven': True, 'local_model_init': False, 'Gp': 0.1, 'graph': 'er', 'agg': 'seq', 'h1': 200, 'num_epochs': 150, 'batch_size': 100, 'tau': 10, 'lr': 0.1, 'data_seed': 6003, 'train_seed': 6003, 'config_override': '', 'project_dir': 'output_dfca_gi'}\n",
      "Using device: cuda:1\n",
      "Epoch -1 tr: l 2.307 a 0.104 clct[np.int64(124), np.int64(116)] cl_acc 0.792  2.380sec\n",
      "Epoch -1 tst: l 2.307 a 0.102 clct[np.int64(18), np.int64(22)] cl_acc 0.850  0.139sec\n",
      "Epoch 0 tr: l 2.141 a 0.507 clct[np.int64(119), np.int64(121)] cl_acc 0.996  lr 0.100000 3.760sec(train) 0.930sec(infer)\n",
      "Epoch 0 tst: l 2.137 a 0.515 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.152sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 1 tr: l 1.867 a 0.680 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.691sec(train) 1.050sec(infer)\n",
      "Epoch 1 tst: l 1.857 a 0.688 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.195sec\n",
      "Epoch 2 tr: l 1.534 a 0.729 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.446sec(train) 0.992sec(infer)\n",
      "Epoch 2 tst: l 1.518 a 0.741 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.167sec\n",
      "Epoch 3 tr: l 1.235 a 0.773 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.516sec(train) 0.910sec(infer)\n",
      "Epoch 3 tst: l 1.214 a 0.782 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.145sec\n",
      "Epoch 4 tr: l 1.016 a 0.803 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.803sec(train) 0.880sec(infer)\n",
      "Epoch 4 tst: l 0.992 a 0.810 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.174sec\n",
      "Epoch 5 tr: l 0.866 a 0.822 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.952sec(train) 1.084sec(infer)\n",
      "Epoch 5 tst: l 0.841 a 0.830 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.189sec\n",
      "Epoch 6 tr: l 0.762 a 0.836 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.299sec(train) 0.974sec(infer)\n",
      "Epoch 6 tst: l 0.737 a 0.843 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.156sec\n",
      "Epoch 7 tr: l 0.687 a 0.845 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 2.921sec(train) 0.853sec(infer)\n",
      "Epoch 7 tst: l 0.662 a 0.853 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.142sec\n",
      "Epoch 8 tr: l 0.631 a 0.852 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.253sec(train) 1.080sec(infer)\n",
      "Epoch 8 tst: l 0.607 a 0.860 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.163sec\n",
      "Epoch 9 tr: l 0.587 a 0.859 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.267sec(train) 1.037sec(infer)\n",
      "Epoch 9 tst: l 0.564 a 0.866 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.181sec\n",
      "Epoch 10 tr: l 0.553 a 0.864 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.321sec(train) 0.983sec(infer)\n",
      "Epoch 10 tst: l 0.530 a 0.872 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.168sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 11 tr: l 0.525 a 0.869 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.322sec(train) 0.983sec(infer)\n",
      "Epoch 11 tst: l 0.503 a 0.875 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.165sec\n",
      "Epoch 12 tr: l 0.502 a 0.872 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.191sec(train) 1.010sec(infer)\n",
      "Epoch 12 tst: l 0.480 a 0.879 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.153sec\n",
      "Epoch 13 tr: l 0.483 a 0.875 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.410sec(train) 0.916sec(infer)\n",
      "Epoch 13 tst: l 0.461 a 0.881 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.151sec\n",
      "Epoch 14 tr: l 0.466 a 0.878 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.412sec(train) 0.933sec(infer)\n",
      "Epoch 14 tst: l 0.445 a 0.885 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.166sec\n",
      "Epoch 15 tr: l 0.452 a 0.880 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.415sec(train) 1.031sec(infer)\n",
      "Epoch 15 tst: l 0.431 a 0.888 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.167sec\n",
      "Epoch 16 tr: l 0.440 a 0.882 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.600sec(train) 0.953sec(infer)\n",
      "Epoch 16 tst: l 0.419 a 0.889 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.156sec\n",
      "Epoch 17 tr: l 0.429 a 0.885 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.541sec(train) 0.976sec(infer)\n",
      "Epoch 17 tst: l 0.409 a 0.891 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.158sec\n",
      "Epoch 18 tr: l 0.419 a 0.886 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.374sec(train) 1.034sec(infer)\n",
      "Epoch 18 tst: l 0.399 a 0.893 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.180sec\n",
      "Epoch 19 tr: l 0.411 a 0.888 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.597sec(train) 0.948sec(infer)\n",
      "Epoch 19 tst: l 0.391 a 0.894 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.167sec\n",
      "Epoch 20 tr: l 0.403 a 0.889 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.792sec(train) 0.933sec(infer)\n",
      "Epoch 20 tst: l 0.384 a 0.895 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.152sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 21 tr: l 0.396 a 0.890 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.255sec(train) 1.012sec(infer)\n",
      "Epoch 21 tst: l 0.377 a 0.897 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.182sec\n",
      "Epoch 22 tr: l 0.390 a 0.892 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.460sec(train) 1.069sec(infer)\n",
      "Epoch 22 tst: l 0.371 a 0.898 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.191sec\n",
      "Epoch 23 tr: l 0.384 a 0.893 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.555sec(train) 1.022sec(infer)\n",
      "Epoch 23 tst: l 0.365 a 0.898 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.151sec\n",
      "Epoch 24 tr: l 0.379 a 0.893 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.225sec(train) 0.938sec(infer)\n",
      "Epoch 24 tst: l 0.360 a 0.899 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.169sec\n",
      "Epoch 25 tr: l 0.374 a 0.895 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.161sec(train) 0.983sec(infer)\n",
      "Epoch 25 tst: l 0.355 a 0.900 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.179sec\n",
      "Epoch 26 tr: l 0.369 a 0.896 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.050sec(train) 0.918sec(infer)\n",
      "Epoch 26 tst: l 0.351 a 0.901 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.148sec\n",
      "Epoch 27 tr: l 0.365 a 0.897 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.236sec(train) 0.956sec(infer)\n",
      "Epoch 27 tst: l 0.347 a 0.902 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.176sec\n",
      "Epoch 28 tr: l 0.361 a 0.898 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.361sec(train) 0.982sec(infer)\n",
      "Epoch 28 tst: l 0.343 a 0.902 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.169sec\n",
      "Epoch 29 tr: l 0.357 a 0.898 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.450sec(train) 1.015sec(infer)\n",
      "Epoch 29 tst: l 0.340 a 0.903 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.165sec\n",
      "Epoch 30 tr: l 0.353 a 0.899 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.721sec(train) 1.025sec(infer)\n",
      "Epoch 30 tst: l 0.336 a 0.903 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.184sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 31 tr: l 0.350 a 0.899 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.610sec(train) 1.037sec(infer)\n",
      "Epoch 31 tst: l 0.333 a 0.904 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.174sec\n",
      "Epoch 32 tr: l 0.347 a 0.900 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.541sec(train) 1.025sec(infer)\n",
      "Epoch 32 tst: l 0.330 a 0.905 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.165sec\n",
      "Epoch 33 tr: l 0.344 a 0.901 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.612sec(train) 1.016sec(infer)\n",
      "Epoch 33 tst: l 0.327 a 0.906 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.173sec\n",
      "Epoch 34 tr: l 0.341 a 0.902 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.611sec(train) 1.001sec(infer)\n",
      "Epoch 34 tst: l 0.325 a 0.906 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.182sec\n",
      "Epoch 35 tr: l 0.338 a 0.902 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.657sec(train) 0.855sec(infer)\n",
      "Epoch 35 tst: l 0.322 a 0.906 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.143sec\n",
      "Epoch 36 tr: l 0.335 a 0.903 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.522sec(train) 0.951sec(infer)\n",
      "Epoch 36 tst: l 0.320 a 0.907 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.165sec\n",
      "Epoch 37 tr: l 0.333 a 0.903 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.833sec(train) 1.107sec(infer)\n",
      "Epoch 37 tst: l 0.317 a 0.907 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.202sec\n",
      "Epoch 38 tr: l 0.330 a 0.904 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.570sec(train) 1.069sec(infer)\n",
      "Epoch 38 tst: l 0.315 a 0.908 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.177sec\n",
      "Epoch 39 tr: l 0.328 a 0.905 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.053sec(train) 0.842sec(infer)\n",
      "Epoch 39 tst: l 0.313 a 0.909 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.163sec\n",
      "Epoch 40 tr: l 0.326 a 0.905 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.256sec(train) 0.911sec(infer)\n",
      "Epoch 40 tst: l 0.311 a 0.910 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.156sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 41 tr: l 0.323 a 0.906 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.177sec(train) 1.092sec(infer)\n",
      "Epoch 41 tst: l 0.309 a 0.910 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.181sec\n",
      "Epoch 42 tr: l 0.321 a 0.906 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.105sec(train) 0.867sec(infer)\n",
      "Epoch 42 tst: l 0.307 a 0.911 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.167sec\n",
      "Epoch 43 tr: l 0.319 a 0.907 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.332sec(train) 0.884sec(infer)\n",
      "Epoch 43 tst: l 0.305 a 0.911 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.147sec\n",
      "Epoch 44 tr: l 0.317 a 0.907 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 2.942sec(train) 1.027sec(infer)\n",
      "Epoch 44 tst: l 0.303 a 0.912 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.190sec\n",
      "Epoch 45 tr: l 0.315 a 0.908 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.267sec(train) 0.925sec(infer)\n",
      "Epoch 45 tst: l 0.301 a 0.912 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.191sec\n",
      "Epoch 46 tr: l 0.313 a 0.908 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.376sec(train) 0.914sec(infer)\n",
      "Epoch 46 tst: l 0.300 a 0.913 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.154sec\n",
      "Epoch 47 tr: l 0.311 a 0.909 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.562sec(train) 1.018sec(infer)\n",
      "Epoch 47 tst: l 0.298 a 0.913 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.170sec\n",
      "Epoch 48 tr: l 0.310 a 0.909 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.157sec(train) 1.086sec(infer)\n",
      "Epoch 48 tst: l 0.296 a 0.914 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.178sec\n",
      "Epoch 49 tr: l 0.308 a 0.910 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.213sec(train) 0.972sec(infer)\n",
      "Epoch 49 tst: l 0.295 a 0.914 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.177sec\n",
      "Epoch 50 tr: l 0.306 a 0.910 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.950sec(train) 0.832sec(infer)\n",
      "Epoch 50 tst: l 0.293 a 0.915 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.159sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 51 tr: l 0.304 a 0.911 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.149sec(train) 1.044sec(infer)\n",
      "Epoch 51 tst: l 0.292 a 0.915 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.139sec\n",
      "Epoch 52 tr: l 0.303 a 0.911 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.209sec(train) 1.051sec(infer)\n",
      "Epoch 52 tst: l 0.290 a 0.915 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.171sec\n",
      "Epoch 53 tr: l 0.301 a 0.912 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.288sec(train) 1.005sec(infer)\n",
      "Epoch 53 tst: l 0.289 a 0.916 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.162sec\n",
      "Epoch 54 tr: l 0.300 a 0.912 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.303sec(train) 0.878sec(infer)\n",
      "Epoch 54 tst: l 0.288 a 0.916 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.154sec\n",
      "Epoch 55 tr: l 0.298 a 0.912 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.125sec(train) 1.117sec(infer)\n",
      "Epoch 55 tst: l 0.286 a 0.916 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.157sec\n",
      "Epoch 56 tr: l 0.296 a 0.913 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.767sec(train) 1.260sec(infer)\n",
      "Epoch 56 tst: l 0.285 a 0.917 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.164sec\n",
      "Epoch 57 tr: l 0.295 a 0.913 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.299sec(train) 1.069sec(infer)\n",
      "Epoch 57 tst: l 0.284 a 0.917 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.155sec\n",
      "Epoch 58 tr: l 0.293 a 0.914 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.176sec(train) 0.905sec(infer)\n",
      "Epoch 58 tst: l 0.282 a 0.918 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.148sec\n",
      "Epoch 59 tr: l 0.292 a 0.914 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.463sec(train) 0.984sec(infer)\n",
      "Epoch 59 tst: l 0.281 a 0.918 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.152sec\n",
      "Epoch 60 tr: l 0.291 a 0.914 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.399sec(train) 1.008sec(infer)\n",
      "Epoch 60 tst: l 0.280 a 0.919 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.173sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 61 tr: l 0.289 a 0.915 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.532sec(train) 0.913sec(infer)\n",
      "Epoch 61 tst: l 0.279 a 0.919 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.154sec\n",
      "Epoch 62 tr: l 0.288 a 0.915 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.668sec(train) 1.014sec(infer)\n",
      "Epoch 62 tst: l 0.277 a 0.919 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.167sec\n",
      "Epoch 63 tr: l 0.286 a 0.915 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.669sec(train) 0.987sec(infer)\n",
      "Epoch 63 tst: l 0.276 a 0.920 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.172sec\n",
      "Epoch 64 tr: l 0.285 a 0.916 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.575sec(train) 1.086sec(infer)\n",
      "Epoch 64 tst: l 0.275 a 0.920 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.168sec\n",
      "Epoch 65 tr: l 0.284 a 0.916 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.094sec(train) 0.966sec(infer)\n",
      "Epoch 65 tst: l 0.274 a 0.920 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.177sec\n",
      "Epoch 66 tr: l 0.282 a 0.916 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.553sec(train) 0.925sec(infer)\n",
      "Epoch 66 tst: l 0.273 a 0.921 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.138sec\n",
      "Epoch 67 tr: l 0.281 a 0.917 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.595sec(train) 1.025sec(infer)\n",
      "Epoch 67 tst: l 0.272 a 0.921 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.167sec\n",
      "Epoch 68 tr: l 0.280 a 0.917 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.322sec(train) 0.984sec(infer)\n",
      "Epoch 68 tst: l 0.271 a 0.921 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.161sec\n",
      "Epoch 69 tr: l 0.279 a 0.917 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.352sec(train) 0.894sec(infer)\n",
      "Epoch 69 tst: l 0.270 a 0.921 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.152sec\n",
      "Epoch 70 tr: l 0.277 a 0.918 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.560sec(train) 1.000sec(infer)\n",
      "Epoch 70 tst: l 0.269 a 0.922 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.175sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 71 tr: l 0.276 a 0.918 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.385sec(train) 1.025sec(infer)\n",
      "Epoch 71 tst: l 0.268 a 0.922 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.157sec\n",
      "Epoch 72 tr: l 0.275 a 0.918 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.723sec(train) 1.092sec(infer)\n",
      "Epoch 72 tst: l 0.267 a 0.922 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.173sec\n",
      "Epoch 73 tr: l 0.274 a 0.919 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.714sec(train) 1.115sec(infer)\n",
      "Epoch 73 tst: l 0.266 a 0.922 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.206sec\n",
      "Epoch 74 tr: l 0.273 a 0.919 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.056sec(train) 0.972sec(infer)\n",
      "Epoch 74 tst: l 0.265 a 0.923 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.168sec\n",
      "Epoch 75 tr: l 0.271 a 0.919 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.311sec(train) 0.905sec(infer)\n",
      "Epoch 75 tst: l 0.264 a 0.923 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.153sec\n",
      "Epoch 76 tr: l 0.270 a 0.920 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.364sec(train) 0.863sec(infer)\n",
      "Epoch 76 tst: l 0.263 a 0.924 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.153sec\n",
      "Epoch 77 tr: l 0.269 a 0.920 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.414sec(train) 1.032sec(infer)\n",
      "Epoch 77 tst: l 0.262 a 0.924 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.175sec\n",
      "Epoch 78 tr: l 0.268 a 0.920 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.603sec(train) 0.935sec(infer)\n",
      "Epoch 78 tst: l 0.261 a 0.924 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.167sec\n",
      "Epoch 79 tr: l 0.267 a 0.921 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.072sec(train) 0.945sec(infer)\n",
      "Epoch 79 tst: l 0.260 a 0.924 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.161sec\n",
      "Epoch 80 tr: l 0.266 a 0.921 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.634sec(train) 0.916sec(infer)\n",
      "Epoch 80 tst: l 0.259 a 0.925 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.135sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 81 tr: l 0.264 a 0.922 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.633sec(train) 1.004sec(infer)\n",
      "Epoch 81 tst: l 0.258 a 0.925 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.171sec\n",
      "Epoch 82 tr: l 0.263 a 0.922 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.807sec(train) 0.995sec(infer)\n",
      "Epoch 82 tst: l 0.257 a 0.925 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.183sec\n",
      "Epoch 83 tr: l 0.262 a 0.922 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.077sec(train) 0.933sec(infer)\n",
      "Epoch 83 tst: l 0.256 a 0.925 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.147sec\n",
      "Epoch 84 tr: l 0.261 a 0.923 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.753sec(train) 0.999sec(infer)\n",
      "Epoch 84 tst: l 0.255 a 0.925 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.186sec\n",
      "Epoch 85 tr: l 0.260 a 0.923 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.678sec(train) 0.989sec(infer)\n",
      "Epoch 85 tst: l 0.254 a 0.926 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.161sec\n",
      "Epoch 86 tr: l 0.259 a 0.923 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.590sec(train) 0.898sec(infer)\n",
      "Epoch 86 tst: l 0.253 a 0.926 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.163sec\n",
      "Epoch 87 tr: l 0.258 a 0.923 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.689sec(train) 0.984sec(infer)\n",
      "Epoch 87 tst: l 0.253 a 0.926 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.163sec\n",
      "Epoch 88 tr: l 0.257 a 0.924 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.383sec(train) 1.005sec(infer)\n",
      "Epoch 88 tst: l 0.252 a 0.926 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.162sec\n",
      "Epoch 89 tr: l 0.256 a 0.924 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.310sec(train) 1.032sec(infer)\n",
      "Epoch 89 tst: l 0.251 a 0.927 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.158sec\n",
      "Epoch 90 tr: l 0.255 a 0.924 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.532sec(train) 0.941sec(infer)\n",
      "Epoch 90 tst: l 0.250 a 0.927 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.160sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 91 tr: l 0.254 a 0.924 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.303sec(train) 0.990sec(infer)\n",
      "Epoch 91 tst: l 0.249 a 0.927 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.164sec\n",
      "Epoch 92 tr: l 0.253 a 0.925 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.464sec(train) 0.966sec(infer)\n",
      "Epoch 92 tst: l 0.248 a 0.928 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.156sec\n",
      "Epoch 93 tr: l 0.252 a 0.925 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.760sec(train) 0.942sec(infer)\n",
      "Epoch 93 tst: l 0.247 a 0.928 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.157sec\n",
      "Epoch 94 tr: l 0.251 a 0.925 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.506sec(train) 1.045sec(infer)\n",
      "Epoch 94 tst: l 0.247 a 0.928 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.159sec\n",
      "Epoch 95 tr: l 0.250 a 0.926 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.718sec(train) 0.910sec(infer)\n",
      "Epoch 95 tst: l 0.246 a 0.928 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.153sec\n",
      "Epoch 96 tr: l 0.249 a 0.926 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.616sec(train) 0.976sec(infer)\n",
      "Epoch 96 tst: l 0.245 a 0.929 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.166sec\n",
      "Epoch 97 tr: l 0.248 a 0.926 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.896sec(train) 1.017sec(infer)\n",
      "Epoch 97 tst: l 0.244 a 0.929 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.163sec\n",
      "Epoch 98 tr: l 0.247 a 0.927 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.982sec(train) 0.931sec(infer)\n",
      "Epoch 98 tst: l 0.243 a 0.929 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.150sec\n",
      "Epoch 99 tr: l 0.246 a 0.927 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.860sec(train) 0.948sec(infer)\n",
      "Epoch 99 tst: l 0.243 a 0.929 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.162sec\n",
      "Epoch 100 tr: l 0.245 a 0.927 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.926sec(train) 0.921sec(infer)\n",
      "Epoch 100 tst: l 0.242 a 0.929 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.153sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 101 tr: l 0.244 a 0.927 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.773sec(train) 0.941sec(infer)\n",
      "Epoch 101 tst: l 0.241 a 0.930 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.141sec\n",
      "Epoch 102 tr: l 0.243 a 0.928 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.577sec(train) 1.525sec(infer)\n",
      "Epoch 102 tst: l 0.240 a 0.930 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.209sec\n",
      "Epoch 103 tr: l 0.242 a 0.928 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.356sec(train) 1.131sec(infer)\n",
      "Epoch 103 tst: l 0.239 a 0.930 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.200sec\n",
      "Epoch 104 tr: l 0.241 a 0.928 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.951sec(train) 0.981sec(infer)\n",
      "Epoch 104 tst: l 0.239 a 0.930 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.156sec\n",
      "Epoch 105 tr: l 0.240 a 0.928 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.523sec(train) 0.991sec(infer)\n",
      "Epoch 105 tst: l 0.238 a 0.930 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.164sec\n",
      "Epoch 106 tr: l 0.239 a 0.929 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.545sec(train) 0.896sec(infer)\n",
      "Epoch 106 tst: l 0.237 a 0.931 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.150sec\n",
      "Epoch 107 tr: l 0.238 a 0.929 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.492sec(train) 0.907sec(infer)\n",
      "Epoch 107 tst: l 0.236 a 0.931 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.171sec\n",
      "Epoch 108 tr: l 0.238 a 0.929 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.479sec(train) 1.039sec(infer)\n",
      "Epoch 108 tst: l 0.236 a 0.931 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.174sec\n",
      "Epoch 109 tr: l 0.237 a 0.929 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.868sec(train) 1.030sec(infer)\n",
      "Epoch 109 tst: l 0.235 a 0.931 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.170sec\n",
      "Epoch 110 tr: l 0.236 a 0.930 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.959sec(train) 0.975sec(infer)\n",
      "Epoch 110 tst: l 0.234 a 0.931 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.165sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 111 tr: l 0.235 a 0.930 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.764sec(train) 0.976sec(infer)\n",
      "Epoch 111 tst: l 0.233 a 0.931 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.160sec\n",
      "Epoch 112 tr: l 0.234 a 0.930 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.486sec(train) 0.897sec(infer)\n",
      "Epoch 112 tst: l 0.233 a 0.932 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.147sec\n",
      "Epoch 113 tr: l 0.233 a 0.930 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.110sec(train) 1.157sec(infer)\n",
      "Epoch 113 tst: l 0.232 a 0.932 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.214sec\n",
      "Epoch 114 tr: l 0.232 a 0.931 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.067sec(train) 0.905sec(infer)\n",
      "Epoch 114 tst: l 0.231 a 0.932 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.144sec\n",
      "Epoch 115 tr: l 0.231 a 0.931 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.059sec(train) 0.944sec(infer)\n",
      "Epoch 115 tst: l 0.230 a 0.932 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.204sec\n",
      "Epoch 116 tr: l 0.231 a 0.931 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.546sec(train) 1.023sec(infer)\n",
      "Epoch 116 tst: l 0.230 a 0.933 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.154sec\n",
      "Epoch 117 tr: l 0.230 a 0.931 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.661sec(train) 0.974sec(infer)\n",
      "Epoch 117 tst: l 0.229 a 0.933 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.173sec\n",
      "Epoch 118 tr: l 0.229 a 0.932 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.880sec(train) 0.995sec(infer)\n",
      "Epoch 118 tst: l 0.228 a 0.933 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.176sec\n",
      "Epoch 119 tr: l 0.228 a 0.932 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.927sec(train) 1.023sec(infer)\n",
      "Epoch 119 tst: l 0.228 a 0.933 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.125sec\n",
      "Epoch 120 tr: l 0.227 a 0.932 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.692sec(train) 0.888sec(infer)\n",
      "Epoch 120 tst: l 0.227 a 0.933 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.143sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 121 tr: l 0.226 a 0.932 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.331sec(train) 0.944sec(infer)\n",
      "Epoch 121 tst: l 0.226 a 0.934 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.159sec\n",
      "Epoch 122 tr: l 0.226 a 0.933 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.922sec(train) 0.974sec(infer)\n",
      "Epoch 122 tst: l 0.226 a 0.934 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.149sec\n",
      "Epoch 123 tr: l 0.225 a 0.933 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.514sec(train) 0.998sec(infer)\n",
      "Epoch 123 tst: l 0.225 a 0.934 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.162sec\n",
      "Epoch 124 tr: l 0.224 a 0.933 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.665sec(train) 1.012sec(infer)\n",
      "Epoch 124 tst: l 0.224 a 0.934 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.174sec\n",
      "Epoch 125 tr: l 0.223 a 0.933 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.732sec(train) 0.942sec(infer)\n",
      "Epoch 125 tst: l 0.223 a 0.934 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.165sec\n",
      "Epoch 126 tr: l 0.222 a 0.934 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.001sec(train) 0.949sec(infer)\n",
      "Epoch 126 tst: l 0.223 a 0.934 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.154sec\n",
      "Epoch 127 tr: l 0.222 a 0.934 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.390sec(train) 0.915sec(infer)\n",
      "Epoch 127 tst: l 0.222 a 0.934 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.183sec\n",
      "Epoch 128 tr: l 0.221 a 0.934 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.131sec(train) 1.049sec(infer)\n",
      "Epoch 128 tst: l 0.222 a 0.935 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.183sec\n",
      "Epoch 129 tr: l 0.220 a 0.934 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.959sec(train) 1.110sec(infer)\n",
      "Epoch 129 tst: l 0.221 a 0.935 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.193sec\n",
      "Epoch 130 tr: l 0.219 a 0.934 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.007sec(train) 1.026sec(infer)\n",
      "Epoch 130 tst: l 0.220 a 0.935 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.178sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 131 tr: l 0.219 a 0.935 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.890sec(train) 1.031sec(infer)\n",
      "Epoch 131 tst: l 0.220 a 0.935 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.174sec\n",
      "Epoch 132 tr: l 0.218 a 0.935 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.535sec(train) 1.102sec(infer)\n",
      "Epoch 132 tst: l 0.219 a 0.935 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.160sec\n",
      "Epoch 133 tr: l 0.217 a 0.935 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.633sec(train) 0.875sec(infer)\n",
      "Epoch 133 tst: l 0.218 a 0.936 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.153sec\n",
      "Epoch 134 tr: l 0.216 a 0.935 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.473sec(train) 0.970sec(infer)\n",
      "Epoch 134 tst: l 0.218 a 0.936 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.172sec\n",
      "Epoch 135 tr: l 0.215 a 0.936 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.554sec(train) 1.045sec(infer)\n",
      "Epoch 135 tst: l 0.217 a 0.936 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.158sec\n",
      "Epoch 136 tr: l 0.215 a 0.936 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.669sec(train) 1.069sec(infer)\n",
      "Epoch 136 tst: l 0.216 a 0.936 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.196sec\n",
      "Epoch 137 tr: l 0.214 a 0.936 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.875sec(train) 0.882sec(infer)\n",
      "Epoch 137 tst: l 0.216 a 0.936 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.151sec\n",
      "Epoch 138 tr: l 0.213 a 0.936 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.790sec(train) 1.122sec(infer)\n",
      "Epoch 138 tst: l 0.215 a 0.937 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.180sec\n",
      "Epoch 139 tr: l 0.213 a 0.937 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.556sec(train) 0.949sec(infer)\n",
      "Epoch 139 tst: l 0.215 a 0.937 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.153sec\n",
      "Epoch 140 tr: l 0.212 a 0.937 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.794sec(train) 0.987sec(infer)\n",
      "Epoch 140 tst: l 0.214 a 0.937 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.167sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 141 tr: l 0.211 a 0.937 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.845sec(train) 1.091sec(infer)\n",
      "Epoch 141 tst: l 0.213 a 0.937 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.178sec\n",
      "Epoch 142 tr: l 0.210 a 0.937 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.048sec(train) 0.963sec(infer)\n",
      "Epoch 142 tst: l 0.213 a 0.937 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.151sec\n",
      "Epoch 143 tr: l 0.210 a 0.937 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.975sec(train) 0.880sec(infer)\n",
      "Epoch 143 tst: l 0.212 a 0.937 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.164sec\n",
      "Epoch 144 tr: l 0.209 a 0.938 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.708sec(train) 0.983sec(infer)\n",
      "Epoch 144 tst: l 0.212 a 0.937 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.165sec\n",
      "Epoch 145 tr: l 0.208 a 0.938 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.828sec(train) 0.977sec(infer)\n",
      "Epoch 145 tst: l 0.211 a 0.937 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.162sec\n",
      "Epoch 146 tr: l 0.207 a 0.938 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.838sec(train) 1.021sec(infer)\n",
      "Epoch 146 tst: l 0.210 a 0.937 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.154sec\n",
      "Epoch 147 tr: l 0.207 a 0.938 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.810sec(train) 0.994sec(infer)\n",
      "Epoch 147 tst: l 0.210 a 0.938 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.179sec\n",
      "Epoch 148 tr: l 0.206 a 0.939 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.913sec(train) 0.983sec(infer)\n",
      "Epoch 148 tst: l 0.209 a 0.938 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.170sec\n",
      "Epoch 149 tr: l 0.205 a 0.939 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.885sec(train) 1.110sec(infer)\n",
      "Epoch 149 tst: l 0.209 a 0.938 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.186sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "---train cluster Ended in 0.21 hour (751.978 sec) \n",
      "---------------------------------IFCA, lr: 0.1, seed: 7293---------------------------------\n",
      "config: {'m': 240, 'm_test': 40, 'p': 2, 'n': 500, 'uneven': True, 'local_model_init': False, 'Gp': 0.1, 'graph': 'er', 'agg': 'seq', 'h1': 200, 'num_epochs': 150, 'batch_size': 100, 'tau': 10, 'lr': 0.1, 'data_seed': 7293, 'train_seed': 7293, 'config_override': '', 'project_dir': 'output_dfca_gi'}\n",
      "Using device: cuda:1\n",
      "Epoch -1 tr: l 2.306 a 0.117 clct[np.int64(202), np.int64(38)] cl_acc 0.592  0.989sec\n",
      "Epoch -1 tst: l 2.306 a 0.120 clct[np.int64(37), np.int64(3)] cl_acc 0.525  0.171sec\n",
      "Epoch 0 tr: l 2.162 a 0.451 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.840sec(train) 1.024sec(infer)\n",
      "Epoch 0 tst: l 2.161 a 0.452 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.170sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 1 tr: l 1.885 a 0.678 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.956sec(train) 1.081sec(infer)\n",
      "Epoch 1 tst: l 1.878 a 0.681 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.159sec\n",
      "Epoch 2 tr: l 1.548 a 0.745 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.753sec(train) 0.920sec(infer)\n",
      "Epoch 2 tst: l 1.535 a 0.753 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.145sec\n",
      "Epoch 3 tr: l 1.240 a 0.784 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.552sec(train) 0.934sec(infer)\n",
      "Epoch 3 tst: l 1.222 a 0.793 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.151sec\n",
      "Epoch 4 tr: l 1.015 a 0.808 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.289sec(train) 1.001sec(infer)\n",
      "Epoch 4 tst: l 0.994 a 0.817 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.171sec\n",
      "Epoch 5 tr: l 0.862 a 0.826 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.867sec(train) 0.987sec(infer)\n",
      "Epoch 5 tst: l 0.839 a 0.832 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.156sec\n",
      "Epoch 6 tr: l 0.758 a 0.838 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.840sec(train) 0.949sec(infer)\n",
      "Epoch 6 tst: l 0.734 a 0.845 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.151sec\n",
      "Epoch 7 tr: l 0.683 a 0.847 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.852sec(train) 0.896sec(infer)\n",
      "Epoch 7 tst: l 0.659 a 0.855 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.149sec\n",
      "Epoch 8 tr: l 0.627 a 0.855 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.589sec(train) 1.085sec(infer)\n",
      "Epoch 8 tst: l 0.603 a 0.861 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.171sec\n",
      "Epoch 9 tr: l 0.584 a 0.860 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.184sec(train) 1.111sec(infer)\n",
      "Epoch 9 tst: l 0.561 a 0.868 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.211sec\n",
      "Epoch 10 tr: l 0.550 a 0.865 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.063sec(train) 0.923sec(infer)\n",
      "Epoch 10 tst: l 0.527 a 0.873 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.156sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 11 tr: l 0.523 a 0.869 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.916sec(train) 0.975sec(infer)\n",
      "Epoch 11 tst: l 0.500 a 0.877 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.162sec\n",
      "Epoch 12 tr: l 0.500 a 0.873 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.049sec(train) 1.020sec(infer)\n",
      "Epoch 12 tst: l 0.477 a 0.881 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.170sec\n",
      "Epoch 13 tr: l 0.481 a 0.876 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.775sec(train) 0.971sec(infer)\n",
      "Epoch 13 tst: l 0.459 a 0.884 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.167sec\n",
      "Epoch 14 tr: l 0.465 a 0.879 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.840sec(train) 0.967sec(infer)\n",
      "Epoch 14 tst: l 0.443 a 0.886 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.147sec\n",
      "Epoch 15 tr: l 0.451 a 0.881 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.089sec(train) 0.998sec(infer)\n",
      "Epoch 15 tst: l 0.429 a 0.888 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.162sec\n",
      "Epoch 16 tr: l 0.438 a 0.884 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.794sec(train) 1.000sec(infer)\n",
      "Epoch 16 tst: l 0.417 a 0.890 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.172sec\n",
      "Epoch 17 tr: l 0.428 a 0.885 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.340sec(train) 1.032sec(infer)\n",
      "Epoch 17 tst: l 0.407 a 0.892 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.168sec\n",
      "Epoch 18 tr: l 0.418 a 0.887 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.558sec(train) 1.055sec(infer)\n",
      "Epoch 18 tst: l 0.398 a 0.894 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.175sec\n",
      "Epoch 19 tr: l 0.410 a 0.888 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.658sec(train) 1.122sec(infer)\n",
      "Epoch 19 tst: l 0.390 a 0.895 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.190sec\n",
      "Epoch 20 tr: l 0.402 a 0.890 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.712sec(train) 0.979sec(infer)\n",
      "Epoch 20 tst: l 0.383 a 0.896 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.161sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 21 tr: l 0.395 a 0.891 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.759sec(train) 0.999sec(infer)\n",
      "Epoch 21 tst: l 0.376 a 0.897 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.169sec\n",
      "Epoch 22 tr: l 0.389 a 0.892 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.699sec(train) 0.966sec(infer)\n",
      "Epoch 22 tst: l 0.370 a 0.898 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.161sec\n",
      "Epoch 23 tr: l 0.383 a 0.893 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.934sec(train) 1.013sec(infer)\n",
      "Epoch 23 tst: l 0.365 a 0.898 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.153sec\n",
      "Epoch 24 tr: l 0.378 a 0.894 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.610sec(train) 1.010sec(infer)\n",
      "Epoch 24 tst: l 0.360 a 0.899 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.158sec\n",
      "Epoch 25 tr: l 0.373 a 0.895 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.741sec(train) 1.051sec(infer)\n",
      "Epoch 25 tst: l 0.355 a 0.900 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.131sec\n",
      "Epoch 26 tr: l 0.368 a 0.896 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.001sec(train) 0.924sec(infer)\n",
      "Epoch 26 tst: l 0.351 a 0.901 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.178sec\n",
      "Epoch 27 tr: l 0.364 a 0.897 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.689sec(train) 0.826sec(infer)\n",
      "Epoch 27 tst: l 0.347 a 0.902 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.133sec\n",
      "Epoch 28 tr: l 0.360 a 0.898 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.362sec(train) 0.975sec(infer)\n",
      "Epoch 28 tst: l 0.344 a 0.902 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.153sec\n",
      "Epoch 29 tr: l 0.356 a 0.898 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.437sec(train) 0.968sec(infer)\n",
      "Epoch 29 tst: l 0.340 a 0.903 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.161sec\n",
      "Epoch 30 tr: l 0.353 a 0.899 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.229sec(train) 1.000sec(infer)\n",
      "Epoch 30 tst: l 0.337 a 0.904 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.167sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 31 tr: l 0.350 a 0.900 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.558sec(train) 1.073sec(infer)\n",
      "Epoch 31 tst: l 0.334 a 0.904 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.256sec\n",
      "Epoch 32 tr: l 0.346 a 0.901 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.256sec(train) 0.934sec(infer)\n",
      "Epoch 32 tst: l 0.331 a 0.904 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.150sec\n",
      "Epoch 33 tr: l 0.343 a 0.901 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.758sec(train) 1.060sec(infer)\n",
      "Epoch 33 tst: l 0.328 a 0.905 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.174sec\n",
      "Epoch 34 tr: l 0.340 a 0.902 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.912sec(train) 0.979sec(infer)\n",
      "Epoch 34 tst: l 0.326 a 0.906 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.185sec\n",
      "Epoch 35 tr: l 0.338 a 0.903 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.463sec(train) 0.810sec(infer)\n",
      "Epoch 35 tst: l 0.323 a 0.906 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.135sec\n",
      "Epoch 36 tr: l 0.335 a 0.903 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.617sec(train) 1.047sec(infer)\n",
      "Epoch 36 tst: l 0.321 a 0.907 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.179sec\n",
      "Epoch 37 tr: l 0.332 a 0.904 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.681sec(train) 1.038sec(infer)\n",
      "Epoch 37 tst: l 0.319 a 0.907 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.178sec\n",
      "Epoch 38 tr: l 0.330 a 0.905 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.614sec(train) 1.135sec(infer)\n",
      "Epoch 38 tst: l 0.317 a 0.908 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.177sec\n",
      "Epoch 39 tr: l 0.328 a 0.905 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.640sec(train) 0.916sec(infer)\n",
      "Epoch 39 tst: l 0.315 a 0.909 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.149sec\n",
      "Epoch 40 tr: l 0.325 a 0.906 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.496sec(train) 0.979sec(infer)\n",
      "Epoch 40 tst: l 0.313 a 0.909 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.161sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 41 tr: l 0.323 a 0.906 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.951sec(train) 1.100sec(infer)\n",
      "Epoch 41 tst: l 0.311 a 0.910 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.179sec\n",
      "Epoch 42 tr: l 0.321 a 0.907 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.198sec(train) 0.990sec(infer)\n",
      "Epoch 42 tst: l 0.309 a 0.911 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.175sec\n",
      "Epoch 43 tr: l 0.319 a 0.907 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.966sec(train) 1.068sec(infer)\n",
      "Epoch 43 tst: l 0.307 a 0.911 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.182sec\n",
      "Epoch 44 tr: l 0.317 a 0.908 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.692sec(train) 0.827sec(infer)\n",
      "Epoch 44 tst: l 0.305 a 0.911 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.148sec\n",
      "Epoch 45 tr: l 0.315 a 0.909 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.262sec(train) 0.862sec(infer)\n",
      "Epoch 45 tst: l 0.304 a 0.912 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.134sec\n",
      "Epoch 46 tr: l 0.313 a 0.909 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.483sec(train) 1.079sec(infer)\n",
      "Epoch 46 tst: l 0.302 a 0.912 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.177sec\n",
      "Epoch 47 tr: l 0.311 a 0.910 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.237sec(train) 0.909sec(infer)\n",
      "Epoch 47 tst: l 0.301 a 0.913 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.176sec\n",
      "Epoch 48 tr: l 0.309 a 0.910 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.248sec(train) 0.766sec(infer)\n",
      "Epoch 48 tst: l 0.299 a 0.914 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.131sec\n",
      "Epoch 49 tr: l 0.308 a 0.911 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.256sec(train) 0.901sec(infer)\n",
      "Epoch 49 tst: l 0.298 a 0.914 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.156sec\n",
      "Epoch 50 tr: l 0.306 a 0.911 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 2.997sec(train) 0.697sec(infer)\n",
      "Epoch 50 tst: l 0.296 a 0.915 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.125sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 51 tr: l 0.304 a 0.911 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.854sec(train) 1.027sec(infer)\n",
      "Epoch 51 tst: l 0.295 a 0.915 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.203sec\n",
      "Epoch 52 tr: l 0.303 a 0.912 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.610sec(train) 0.995sec(infer)\n",
      "Epoch 52 tst: l 0.293 a 0.916 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.168sec\n",
      "Epoch 53 tr: l 0.301 a 0.912 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.544sec(train) 0.931sec(infer)\n",
      "Epoch 53 tst: l 0.292 a 0.916 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.153sec\n",
      "Epoch 54 tr: l 0.299 a 0.913 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.691sec(train) 0.941sec(infer)\n",
      "Epoch 54 tst: l 0.291 a 0.916 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.147sec\n",
      "Epoch 55 tr: l 0.298 a 0.913 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.419sec(train) 1.141sec(infer)\n",
      "Epoch 55 tst: l 0.289 a 0.917 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.162sec\n",
      "Epoch 56 tr: l 0.296 a 0.914 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.553sec(train) 0.914sec(infer)\n",
      "Epoch 56 tst: l 0.288 a 0.917 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.149sec\n",
      "Epoch 57 tr: l 0.295 a 0.914 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.425sec(train) 0.953sec(infer)\n",
      "Epoch 57 tst: l 0.287 a 0.917 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.165sec\n",
      "Epoch 58 tr: l 0.293 a 0.914 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.682sec(train) 1.073sec(infer)\n",
      "Epoch 58 tst: l 0.286 a 0.918 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.181sec\n",
      "Epoch 59 tr: l 0.292 a 0.915 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.884sec(train) 1.005sec(infer)\n",
      "Epoch 59 tst: l 0.284 a 0.918 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.193sec\n",
      "Epoch 60 tr: l 0.291 a 0.915 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.030sec(train) 1.043sec(infer)\n",
      "Epoch 60 tst: l 0.283 a 0.919 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.173sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 61 tr: l 0.289 a 0.916 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.206sec(train) 0.972sec(infer)\n",
      "Epoch 61 tst: l 0.282 a 0.919 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.159sec\n",
      "Epoch 62 tr: l 0.288 a 0.916 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.088sec(train) 0.956sec(infer)\n",
      "Epoch 62 tst: l 0.281 a 0.920 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.164sec\n",
      "Epoch 63 tr: l 0.286 a 0.916 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.276sec(train) 0.990sec(infer)\n",
      "Epoch 63 tst: l 0.280 a 0.920 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.178sec\n",
      "Epoch 64 tr: l 0.285 a 0.917 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.100sec(train) 0.920sec(infer)\n",
      "Epoch 64 tst: l 0.279 a 0.921 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.169sec\n",
      "Epoch 65 tr: l 0.284 a 0.917 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.381sec(train) 0.934sec(infer)\n",
      "Epoch 65 tst: l 0.278 a 0.921 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.169sec\n",
      "Epoch 66 tr: l 0.282 a 0.917 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.342sec(train) 0.917sec(infer)\n",
      "Epoch 66 tst: l 0.277 a 0.921 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.159sec\n",
      "Epoch 67 tr: l 0.281 a 0.918 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.280sec(train) 1.028sec(infer)\n",
      "Epoch 67 tst: l 0.276 a 0.922 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.165sec\n",
      "Epoch 68 tr: l 0.280 a 0.918 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.072sec(train) 0.949sec(infer)\n",
      "Epoch 68 tst: l 0.275 a 0.923 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.168sec\n",
      "Epoch 69 tr: l 0.279 a 0.918 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.179sec(train) 0.902sec(infer)\n",
      "Epoch 69 tst: l 0.273 a 0.923 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.168sec\n",
      "Epoch 70 tr: l 0.277 a 0.919 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.234sec(train) 0.935sec(infer)\n",
      "Epoch 70 tst: l 0.272 a 0.923 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.147sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 71 tr: l 0.276 a 0.919 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.015sec(train) 0.955sec(infer)\n",
      "Epoch 71 tst: l 0.271 a 0.923 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.171sec\n",
      "Epoch 72 tr: l 0.275 a 0.920 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.162sec(train) 0.850sec(infer)\n",
      "Epoch 72 tst: l 0.270 a 0.924 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.156sec\n",
      "Epoch 73 tr: l 0.274 a 0.920 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.059sec(train) 1.072sec(infer)\n",
      "Epoch 73 tst: l 0.269 a 0.924 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.161sec\n",
      "Epoch 74 tr: l 0.273 a 0.920 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.624sec(train) 1.044sec(infer)\n",
      "Epoch 74 tst: l 0.268 a 0.924 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.172sec\n",
      "Epoch 75 tr: l 0.271 a 0.921 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.227sec(train) 0.994sec(infer)\n",
      "Epoch 75 tst: l 0.268 a 0.924 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.156sec\n",
      "Epoch 76 tr: l 0.270 a 0.921 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.501sec(train) 0.895sec(infer)\n",
      "Epoch 76 tst: l 0.267 a 0.924 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.169sec\n",
      "Epoch 77 tr: l 0.269 a 0.921 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.637sec(train) 0.948sec(infer)\n",
      "Epoch 77 tst: l 0.266 a 0.925 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.151sec\n",
      "Epoch 78 tr: l 0.268 a 0.922 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.140sec(train) 1.003sec(infer)\n",
      "Epoch 78 tst: l 0.265 a 0.925 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.188sec\n",
      "Epoch 79 tr: l 0.267 a 0.922 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.744sec(train) 0.981sec(infer)\n",
      "Epoch 79 tst: l 0.264 a 0.925 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.165sec\n",
      "Epoch 80 tr: l 0.266 a 0.922 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.145sec(train) 0.910sec(infer)\n",
      "Epoch 80 tst: l 0.263 a 0.925 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.152sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 81 tr: l 0.265 a 0.923 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.283sec(train) 1.049sec(infer)\n",
      "Epoch 81 tst: l 0.262 a 0.926 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.131sec\n",
      "Epoch 82 tr: l 0.263 a 0.923 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.315sec(train) 1.077sec(infer)\n",
      "Epoch 82 tst: l 0.261 a 0.926 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.186sec\n",
      "Epoch 83 tr: l 0.262 a 0.923 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.490sec(train) 0.917sec(infer)\n",
      "Epoch 83 tst: l 0.260 a 0.926 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.159sec\n",
      "Epoch 84 tr: l 0.261 a 0.924 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.730sec(train) 0.957sec(infer)\n",
      "Epoch 84 tst: l 0.259 a 0.926 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.156sec\n",
      "Epoch 85 tr: l 0.260 a 0.924 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.653sec(train) 1.005sec(infer)\n",
      "Epoch 85 tst: l 0.258 a 0.926 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.174sec\n",
      "Epoch 86 tr: l 0.259 a 0.924 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.391sec(train) 1.065sec(infer)\n",
      "Epoch 86 tst: l 0.258 a 0.926 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.173sec\n",
      "Epoch 87 tr: l 0.258 a 0.924 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.588sec(train) 0.905sec(infer)\n",
      "Epoch 87 tst: l 0.257 a 0.927 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.176sec\n",
      "Epoch 88 tr: l 0.257 a 0.925 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.693sec(train) 0.994sec(infer)\n",
      "Epoch 88 tst: l 0.256 a 0.927 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.153sec\n",
      "Epoch 89 tr: l 0.256 a 0.925 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.267sec(train) 1.006sec(infer)\n",
      "Epoch 89 tst: l 0.255 a 0.927 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.170sec\n",
      "Epoch 90 tr: l 0.255 a 0.925 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.595sec(train) 1.129sec(infer)\n",
      "Epoch 90 tst: l 0.254 a 0.927 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.179sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 91 tr: l 0.254 a 0.926 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.568sec(train) 0.996sec(infer)\n",
      "Epoch 91 tst: l 0.253 a 0.928 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.180sec\n",
      "Epoch 92 tr: l 0.253 a 0.926 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.279sec(train) 1.019sec(infer)\n",
      "Epoch 92 tst: l 0.252 a 0.928 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.180sec\n",
      "Epoch 93 tr: l 0.252 a 0.926 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.737sec(train) 0.999sec(infer)\n",
      "Epoch 93 tst: l 0.252 a 0.928 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.163sec\n",
      "Epoch 94 tr: l 0.251 a 0.927 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.790sec(train) 1.035sec(infer)\n",
      "Epoch 94 tst: l 0.251 a 0.928 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.175sec\n",
      "Epoch 95 tr: l 0.250 a 0.927 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.587sec(train) 0.952sec(infer)\n",
      "Epoch 95 tst: l 0.250 a 0.929 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.155sec\n",
      "Epoch 96 tr: l 0.249 a 0.927 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.735sec(train) 0.868sec(infer)\n",
      "Epoch 96 tst: l 0.249 a 0.929 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.150sec\n",
      "Epoch 97 tr: l 0.248 a 0.927 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.223sec(train) 1.149sec(infer)\n",
      "Epoch 97 tst: l 0.248 a 0.929 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.171sec\n",
      "Epoch 98 tr: l 0.247 a 0.927 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.057sec(train) 1.134sec(infer)\n",
      "Epoch 98 tst: l 0.247 a 0.929 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.171sec\n",
      "Epoch 99 tr: l 0.246 a 0.928 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.362sec(train) 0.984sec(infer)\n",
      "Epoch 99 tst: l 0.247 a 0.930 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.155sec\n",
      "Epoch 100 tr: l 0.245 a 0.928 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.547sec(train) 0.833sec(infer)\n",
      "Epoch 100 tst: l 0.246 a 0.930 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.131sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 101 tr: l 0.244 a 0.928 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.660sec(train) 1.056sec(infer)\n",
      "Epoch 101 tst: l 0.245 a 0.930 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.167sec\n",
      "Epoch 102 tr: l 0.243 a 0.928 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.767sec(train) 1.087sec(infer)\n",
      "Epoch 102 tst: l 0.244 a 0.930 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.164sec\n",
      "Epoch 103 tr: l 0.242 a 0.929 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.480sec(train) 0.988sec(infer)\n",
      "Epoch 103 tst: l 0.243 a 0.931 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.176sec\n",
      "Epoch 104 tr: l 0.241 a 0.929 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.304sec(train) 0.986sec(infer)\n",
      "Epoch 104 tst: l 0.243 a 0.931 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.161sec\n",
      "Epoch 105 tr: l 0.240 a 0.929 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.121sec(train) 0.894sec(infer)\n",
      "Epoch 105 tst: l 0.242 a 0.931 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.137sec\n",
      "Epoch 106 tr: l 0.239 a 0.929 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.529sec(train) 1.066sec(infer)\n",
      "Epoch 106 tst: l 0.241 a 0.931 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.183sec\n",
      "Epoch 107 tr: l 0.238 a 0.930 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 2.995sec(train) 0.912sec(infer)\n",
      "Epoch 107 tst: l 0.240 a 0.931 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.158sec\n",
      "Epoch 108 tr: l 0.238 a 0.930 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.381sec(train) 0.877sec(infer)\n",
      "Epoch 108 tst: l 0.240 a 0.931 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.143sec\n",
      "Epoch 109 tr: l 0.237 a 0.930 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.476sec(train) 0.986sec(infer)\n",
      "Epoch 109 tst: l 0.239 a 0.931 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.148sec\n",
      "Epoch 110 tr: l 0.236 a 0.930 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.366sec(train) 1.046sec(infer)\n",
      "Epoch 110 tst: l 0.238 a 0.932 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.183sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 111 tr: l 0.235 a 0.931 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.444sec(train) 0.948sec(infer)\n",
      "Epoch 111 tst: l 0.237 a 0.932 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.186sec\n",
      "Epoch 112 tr: l 0.234 a 0.931 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.831sec(train) 0.908sec(infer)\n",
      "Epoch 112 tst: l 0.237 a 0.932 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.144sec\n",
      "Epoch 113 tr: l 0.233 a 0.931 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.662sec(train) 1.044sec(infer)\n",
      "Epoch 113 tst: l 0.236 a 0.932 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.160sec\n",
      "Epoch 114 tr: l 0.232 a 0.932 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.721sec(train) 0.982sec(infer)\n",
      "Epoch 114 tst: l 0.235 a 0.932 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.176sec\n",
      "Epoch 115 tr: l 0.231 a 0.932 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.684sec(train) 0.926sec(infer)\n",
      "Epoch 115 tst: l 0.234 a 0.933 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.147sec\n",
      "Epoch 116 tr: l 0.231 a 0.932 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.472sec(train) 0.905sec(infer)\n",
      "Epoch 116 tst: l 0.234 a 0.933 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.146sec\n",
      "Epoch 117 tr: l 0.230 a 0.933 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.447sec(train) 0.973sec(infer)\n",
      "Epoch 117 tst: l 0.233 a 0.933 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.157sec\n",
      "Epoch 118 tr: l 0.229 a 0.933 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.598sec(train) 0.926sec(infer)\n",
      "Epoch 118 tst: l 0.232 a 0.933 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.154sec\n",
      "Epoch 119 tr: l 0.228 a 0.933 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.231sec(train) 1.012sec(infer)\n",
      "Epoch 119 tst: l 0.231 a 0.933 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.165sec\n",
      "Epoch 120 tr: l 0.227 a 0.933 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.706sec(train) 0.953sec(infer)\n",
      "Epoch 120 tst: l 0.231 a 0.933 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.167sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 121 tr: l 0.226 a 0.933 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.983sec(train) 0.959sec(infer)\n",
      "Epoch 121 tst: l 0.230 a 0.934 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.159sec\n",
      "Epoch 122 tr: l 0.226 a 0.934 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.452sec(train) 0.975sec(infer)\n",
      "Epoch 122 tst: l 0.229 a 0.934 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.163sec\n",
      "Epoch 123 tr: l 0.225 a 0.934 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.938sec(train) 0.963sec(infer)\n",
      "Epoch 123 tst: l 0.229 a 0.934 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.169sec\n",
      "Epoch 124 tr: l 0.224 a 0.934 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.908sec(train) 1.021sec(infer)\n",
      "Epoch 124 tst: l 0.228 a 0.934 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.173sec\n",
      "Epoch 125 tr: l 0.223 a 0.934 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.648sec(train) 0.984sec(infer)\n",
      "Epoch 125 tst: l 0.227 a 0.934 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.163sec\n",
      "Epoch 126 tr: l 0.222 a 0.934 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.460sec(train) 1.019sec(infer)\n",
      "Epoch 126 tst: l 0.227 a 0.935 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.168sec\n",
      "Epoch 127 tr: l 0.222 a 0.935 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.577sec(train) 0.967sec(infer)\n",
      "Epoch 127 tst: l 0.226 a 0.935 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.165sec\n",
      "Epoch 128 tr: l 0.221 a 0.935 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.885sec(train) 0.956sec(infer)\n",
      "Epoch 128 tst: l 0.225 a 0.935 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.160sec\n",
      "Epoch 129 tr: l 0.220 a 0.935 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.702sec(train) 0.961sec(infer)\n",
      "Epoch 129 tst: l 0.224 a 0.936 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.168sec\n",
      "Epoch 130 tr: l 0.219 a 0.935 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.566sec(train) 0.980sec(infer)\n",
      "Epoch 130 tst: l 0.224 a 0.936 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.163sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 131 tr: l 0.218 a 0.935 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.182sec(train) 0.960sec(infer)\n",
      "Epoch 131 tst: l 0.223 a 0.936 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.175sec\n",
      "Epoch 132 tr: l 0.218 a 0.936 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.065sec(train) 1.078sec(infer)\n",
      "Epoch 132 tst: l 0.222 a 0.936 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.184sec\n",
      "Epoch 133 tr: l 0.217 a 0.936 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.707sec(train) 1.022sec(infer)\n",
      "Epoch 133 tst: l 0.222 a 0.936 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.168sec\n",
      "Epoch 134 tr: l 0.216 a 0.936 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.776sec(train) 0.957sec(infer)\n",
      "Epoch 134 tst: l 0.221 a 0.936 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.166sec\n",
      "Epoch 135 tr: l 0.215 a 0.936 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.111sec(train) 1.013sec(infer)\n",
      "Epoch 135 tst: l 0.221 a 0.936 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.184sec\n",
      "Epoch 136 tr: l 0.215 a 0.937 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.830sec(train) 0.896sec(infer)\n",
      "Epoch 136 tst: l 0.220 a 0.937 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.161sec\n",
      "Epoch 137 tr: l 0.214 a 0.937 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.630sec(train) 0.976sec(infer)\n",
      "Epoch 137 tst: l 0.219 a 0.937 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.150sec\n",
      "Epoch 138 tr: l 0.213 a 0.937 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.922sec(train) 1.028sec(infer)\n",
      "Epoch 138 tst: l 0.219 a 0.937 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.162sec\n",
      "Epoch 139 tr: l 0.212 a 0.937 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.692sec(train) 0.948sec(infer)\n",
      "Epoch 139 tst: l 0.218 a 0.938 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.154sec\n",
      "Epoch 140 tr: l 0.212 a 0.937 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.337sec(train) 0.983sec(infer)\n",
      "Epoch 140 tst: l 0.217 a 0.938 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.165sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 141 tr: l 0.211 a 0.938 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.236sec(train) 0.926sec(infer)\n",
      "Epoch 141 tst: l 0.217 a 0.938 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.158sec\n",
      "Epoch 142 tr: l 0.210 a 0.938 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.091sec(train) 0.903sec(infer)\n",
      "Epoch 142 tst: l 0.216 a 0.938 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.147sec\n",
      "Epoch 143 tr: l 0.210 a 0.938 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.276sec(train) 0.988sec(infer)\n",
      "Epoch 143 tst: l 0.215 a 0.938 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.174sec\n",
      "Epoch 144 tr: l 0.209 a 0.938 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.752sec(train) 0.930sec(infer)\n",
      "Epoch 144 tst: l 0.215 a 0.939 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.174sec\n",
      "Epoch 145 tr: l 0.208 a 0.938 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.070sec(train) 1.125sec(infer)\n",
      "Epoch 145 tst: l 0.214 a 0.939 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.176sec\n",
      "Epoch 146 tr: l 0.207 a 0.938 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.258sec(train) 0.919sec(infer)\n",
      "Epoch 146 tst: l 0.214 a 0.939 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.144sec\n",
      "Epoch 147 tr: l 0.207 a 0.939 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.731sec(train) 0.976sec(infer)\n",
      "Epoch 147 tst: l 0.213 a 0.939 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.154sec\n",
      "Epoch 148 tr: l 0.206 a 0.939 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.860sec(train) 1.077sec(infer)\n",
      "Epoch 148 tst: l 0.212 a 0.939 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.179sec\n",
      "Epoch 149 tr: l 0.205 a 0.939 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.428sec(train) 0.996sec(infer)\n",
      "Epoch 149 tst: l 0.212 a 0.939 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.159sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "---train cluster Ended in 0.20 hour (722.067 sec) \n",
      "---------------------------------IFCA, lr: 0.1, seed: 7383---------------------------------\n",
      "config: {'m': 240, 'm_test': 40, 'p': 2, 'n': 500, 'uneven': True, 'local_model_init': False, 'Gp': 0.1, 'graph': 'er', 'agg': 'seq', 'h1': 200, 'num_epochs': 150, 'batch_size': 100, 'tau': 10, 'lr': 0.1, 'data_seed': 7383, 'train_seed': 7383, 'config_override': '', 'project_dir': 'output_dfca_gi'}\n",
      "Using device: cuda:1\n",
      "Epoch -1 tr: l 2.301 a 0.097 clct[np.int64(218), np.int64(22)] cl_acc 0.533  0.983sec\n",
      "Epoch -1 tst: l 2.300 a 0.096 clct[np.int64(37), np.int64(3)] cl_acc 0.575  0.152sec\n",
      "Epoch 0 tr: l 2.173 a 0.402 clct[np.int64(218), np.int64(22)] cl_acc 0.583  lr 0.100000 3.604sec(train) 1.040sec(infer)\n",
      "Epoch 0 tst: l 2.171 a 0.407 clct[np.int64(37), np.int64(3)] cl_acc 0.575  0.184sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 1 tr: l 1.964 a 0.538 clct[np.int64(123), np.int64(117)] cl_acc 0.988  lr 0.100000 3.866sec(train) 0.986sec(infer)\n",
      "Epoch 1 tst: l 1.959 a 0.550 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.164sec\n",
      "Epoch 2 tr: l 1.634 a 0.695 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.869sec(train) 0.930sec(infer)\n",
      "Epoch 2 tst: l 1.624 a 0.706 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.152sec\n",
      "Epoch 3 tr: l 1.319 a 0.764 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.435sec(train) 0.997sec(infer)\n",
      "Epoch 3 tst: l 1.306 a 0.775 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.168sec\n",
      "Epoch 4 tr: l 1.076 a 0.800 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.933sec(train) 0.936sec(infer)\n",
      "Epoch 4 tst: l 1.061 a 0.809 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.148sec\n",
      "Epoch 5 tr: l 0.906 a 0.822 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.607sec(train) 0.969sec(infer)\n",
      "Epoch 5 tst: l 0.890 a 0.830 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.166sec\n",
      "Epoch 6 tr: l 0.788 a 0.836 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.648sec(train) 1.002sec(infer)\n",
      "Epoch 6 tst: l 0.773 a 0.844 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.163sec\n",
      "Epoch 7 tr: l 0.705 a 0.846 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.493sec(train) 0.878sec(infer)\n",
      "Epoch 7 tst: l 0.690 a 0.854 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.136sec\n",
      "Epoch 8 tr: l 0.644 a 0.854 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.977sec(train) 0.938sec(infer)\n",
      "Epoch 8 tst: l 0.629 a 0.863 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.197sec\n",
      "Epoch 9 tr: l 0.598 a 0.860 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.972sec(train) 1.110sec(infer)\n",
      "Epoch 9 tst: l 0.583 a 0.869 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.165sec\n",
      "Epoch 10 tr: l 0.561 a 0.865 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.647sec(train) 1.095sec(infer)\n",
      "Epoch 10 tst: l 0.546 a 0.873 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.152sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 11 tr: l 0.532 a 0.869 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.975sec(train) 1.070sec(infer)\n",
      "Epoch 11 tst: l 0.517 a 0.878 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.178sec\n",
      "Epoch 12 tr: l 0.508 a 0.873 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.822sec(train) 1.024sec(infer)\n",
      "Epoch 12 tst: l 0.493 a 0.881 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.176sec\n",
      "Epoch 13 tr: l 0.487 a 0.876 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.544sec(train) 0.895sec(infer)\n",
      "Epoch 13 tst: l 0.474 a 0.885 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.149sec\n",
      "Epoch 14 tr: l 0.470 a 0.879 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.715sec(train) 1.013sec(infer)\n",
      "Epoch 14 tst: l 0.457 a 0.887 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.166sec\n",
      "Epoch 15 tr: l 0.456 a 0.881 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.428sec(train) 0.974sec(infer)\n",
      "Epoch 15 tst: l 0.443 a 0.889 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.162sec\n",
      "Epoch 16 tr: l 0.443 a 0.884 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.388sec(train) 0.906sec(infer)\n",
      "Epoch 16 tst: l 0.430 a 0.892 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.155sec\n",
      "Epoch 17 tr: l 0.432 a 0.885 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.017sec(train) 0.959sec(infer)\n",
      "Epoch 17 tst: l 0.420 a 0.893 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.209sec\n",
      "Epoch 18 tr: l 0.422 a 0.887 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.528sec(train) 0.998sec(infer)\n",
      "Epoch 18 tst: l 0.410 a 0.895 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.180sec\n",
      "Epoch 19 tr: l 0.413 a 0.888 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.769sec(train) 1.112sec(infer)\n",
      "Epoch 19 tst: l 0.402 a 0.896 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.189sec\n",
      "Epoch 20 tr: l 0.405 a 0.890 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.476sec(train) 0.967sec(infer)\n",
      "Epoch 20 tst: l 0.395 a 0.898 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.176sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 21 tr: l 0.398 a 0.891 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.455sec(train) 0.969sec(infer)\n",
      "Epoch 21 tst: l 0.388 a 0.899 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.143sec\n",
      "Epoch 22 tr: l 0.391 a 0.892 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.841sec(train) 1.019sec(infer)\n",
      "Epoch 22 tst: l 0.382 a 0.899 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.172sec\n",
      "Epoch 23 tr: l 0.386 a 0.893 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.607sec(train) 1.068sec(infer)\n",
      "Epoch 23 tst: l 0.376 a 0.900 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.154sec\n",
      "Epoch 24 tr: l 0.380 a 0.894 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.631sec(train) 0.955sec(infer)\n",
      "Epoch 24 tst: l 0.371 a 0.901 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.150sec\n",
      "Epoch 25 tr: l 0.375 a 0.895 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.355sec(train) 0.936sec(infer)\n",
      "Epoch 25 tst: l 0.367 a 0.901 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.153sec\n",
      "Epoch 26 tr: l 0.370 a 0.897 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.959sec(train) 1.076sec(infer)\n",
      "Epoch 26 tst: l 0.362 a 0.902 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.167sec\n",
      "Epoch 27 tr: l 0.366 a 0.897 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.517sec(train) 1.012sec(infer)\n",
      "Epoch 27 tst: l 0.358 a 0.902 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.169sec\n",
      "Epoch 28 tr: l 0.362 a 0.898 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.385sec(train) 1.036sec(infer)\n",
      "Epoch 28 tst: l 0.355 a 0.903 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.179sec\n",
      "Epoch 29 tr: l 0.358 a 0.899 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.229sec(train) 0.819sec(infer)\n",
      "Epoch 29 tst: l 0.351 a 0.903 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.210sec\n",
      "Epoch 30 tr: l 0.354 a 0.899 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.459sec(train) 1.022sec(infer)\n",
      "Epoch 30 tst: l 0.348 a 0.904 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.165sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 31 tr: l 0.351 a 0.900 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.799sec(train) 1.258sec(infer)\n",
      "Epoch 31 tst: l 0.345 a 0.904 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.182sec\n",
      "Epoch 32 tr: l 0.348 a 0.901 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.652sec(train) 1.011sec(infer)\n",
      "Epoch 32 tst: l 0.342 a 0.905 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.182sec\n",
      "Epoch 33 tr: l 0.345 a 0.902 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.279sec(train) 0.898sec(infer)\n",
      "Epoch 33 tst: l 0.339 a 0.906 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.136sec\n",
      "Epoch 34 tr: l 0.342 a 0.902 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.460sec(train) 0.998sec(infer)\n",
      "Epoch 34 tst: l 0.337 a 0.906 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.146sec\n",
      "Epoch 35 tr: l 0.339 a 0.903 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.450sec(train) 1.072sec(infer)\n",
      "Epoch 35 tst: l 0.334 a 0.907 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.172sec\n",
      "Epoch 36 tr: l 0.336 a 0.904 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.688sec(train) 0.904sec(infer)\n",
      "Epoch 36 tst: l 0.332 a 0.908 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.179sec\n",
      "Epoch 37 tr: l 0.333 a 0.904 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.272sec(train) 0.934sec(infer)\n",
      "Epoch 37 tst: l 0.330 a 0.909 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.150sec\n",
      "Epoch 38 tr: l 0.331 a 0.905 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.432sec(train) 1.033sec(infer)\n",
      "Epoch 38 tst: l 0.327 a 0.909 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.170sec\n",
      "Epoch 39 tr: l 0.329 a 0.905 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.396sec(train) 0.977sec(infer)\n",
      "Epoch 39 tst: l 0.325 a 0.910 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.163sec\n",
      "Epoch 40 tr: l 0.326 a 0.906 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.547sec(train) 0.928sec(infer)\n",
      "Epoch 40 tst: l 0.323 a 0.911 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.158sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 41 tr: l 0.324 a 0.906 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.462sec(train) 1.061sec(infer)\n",
      "Epoch 41 tst: l 0.321 a 0.911 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.172sec\n",
      "Epoch 42 tr: l 0.322 a 0.907 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.468sec(train) 0.973sec(infer)\n",
      "Epoch 42 tst: l 0.320 a 0.912 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.177sec\n",
      "Epoch 43 tr: l 0.320 a 0.908 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.654sec(train) 0.955sec(infer)\n",
      "Epoch 43 tst: l 0.318 a 0.913 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.163sec\n",
      "Epoch 44 tr: l 0.318 a 0.908 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.650sec(train) 0.916sec(infer)\n",
      "Epoch 44 tst: l 0.316 a 0.913 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.165sec\n",
      "Epoch 45 tr: l 0.316 a 0.909 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.281sec(train) 1.006sec(infer)\n",
      "Epoch 45 tst: l 0.314 a 0.914 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.152sec\n",
      "Epoch 46 tr: l 0.314 a 0.909 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.588sec(train) 1.013sec(infer)\n",
      "Epoch 46 tst: l 0.313 a 0.914 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.182sec\n",
      "Epoch 47 tr: l 0.312 a 0.910 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.527sec(train) 0.995sec(infer)\n",
      "Epoch 47 tst: l 0.311 a 0.915 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.171sec\n",
      "Epoch 48 tr: l 0.310 a 0.910 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.428sec(train) 0.841sec(infer)\n",
      "Epoch 48 tst: l 0.310 a 0.915 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.139sec\n",
      "Epoch 49 tr: l 0.308 a 0.910 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.311sec(train) 1.054sec(infer)\n",
      "Epoch 49 tst: l 0.308 a 0.916 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.185sec\n",
      "Epoch 50 tr: l 0.307 a 0.911 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.609sec(train) 1.003sec(infer)\n",
      "Epoch 50 tst: l 0.307 a 0.916 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.164sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 51 tr: l 0.305 a 0.911 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.607sec(train) 0.878sec(infer)\n",
      "Epoch 51 tst: l 0.305 a 0.917 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.148sec\n",
      "Epoch 52 tr: l 0.303 a 0.912 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.946sec(train) 1.007sec(infer)\n",
      "Epoch 52 tst: l 0.304 a 0.917 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.153sec\n",
      "Epoch 53 tr: l 0.302 a 0.912 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.621sec(train) 1.019sec(infer)\n",
      "Epoch 53 tst: l 0.302 a 0.917 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.164sec\n",
      "Epoch 54 tr: l 0.300 a 0.912 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.562sec(train) 0.892sec(infer)\n",
      "Epoch 54 tst: l 0.301 a 0.918 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.145sec\n",
      "Epoch 55 tr: l 0.298 a 0.913 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.060sec(train) 0.839sec(infer)\n",
      "Epoch 55 tst: l 0.300 a 0.918 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.157sec\n",
      "Epoch 56 tr: l 0.297 a 0.913 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.725sec(train) 1.042sec(infer)\n",
      "Epoch 56 tst: l 0.298 a 0.918 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.168sec\n",
      "Epoch 57 tr: l 0.295 a 0.914 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.361sec(train) 0.981sec(infer)\n",
      "Epoch 57 tst: l 0.297 a 0.918 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.159sec\n",
      "Epoch 58 tr: l 0.294 a 0.914 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.635sec(train) 0.909sec(infer)\n",
      "Epoch 58 tst: l 0.296 a 0.919 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.167sec\n",
      "Epoch 59 tr: l 0.292 a 0.914 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.518sec(train) 0.890sec(infer)\n",
      "Epoch 59 tst: l 0.294 a 0.919 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.127sec\n",
      "Epoch 60 tr: l 0.291 a 0.915 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.639sec(train) 1.035sec(infer)\n",
      "Epoch 60 tst: l 0.293 a 0.919 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.166sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 61 tr: l 0.289 a 0.915 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.494sec(train) 0.973sec(infer)\n",
      "Epoch 61 tst: l 0.292 a 0.920 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.166sec\n",
      "Epoch 62 tr: l 0.288 a 0.916 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.451sec(train) 1.335sec(infer)\n",
      "Epoch 62 tst: l 0.291 a 0.920 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.223sec\n",
      "Epoch 63 tr: l 0.287 a 0.916 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.155sec(train) 0.937sec(infer)\n",
      "Epoch 63 tst: l 0.290 a 0.920 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.122sec\n",
      "Epoch 64 tr: l 0.285 a 0.916 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.743sec(train) 1.028sec(infer)\n",
      "Epoch 64 tst: l 0.288 a 0.921 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.168sec\n",
      "Epoch 65 tr: l 0.284 a 0.917 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.452sec(train) 0.950sec(infer)\n",
      "Epoch 65 tst: l 0.287 a 0.921 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.170sec\n",
      "Epoch 66 tr: l 0.283 a 0.917 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.943sec(train) 0.978sec(infer)\n",
      "Epoch 66 tst: l 0.286 a 0.921 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.162sec\n",
      "Epoch 67 tr: l 0.281 a 0.917 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.771sec(train) 0.972sec(infer)\n",
      "Epoch 67 tst: l 0.285 a 0.921 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.171sec\n",
      "Epoch 68 tr: l 0.280 a 0.918 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.564sec(train) 1.140sec(infer)\n",
      "Epoch 68 tst: l 0.284 a 0.922 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.155sec\n",
      "Epoch 69 tr: l 0.279 a 0.918 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.803sec(train) 0.966sec(infer)\n",
      "Epoch 69 tst: l 0.283 a 0.922 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.166sec\n",
      "Epoch 70 tr: l 0.277 a 0.919 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.716sec(train) 1.063sec(infer)\n",
      "Epoch 70 tst: l 0.282 a 0.922 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.213sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 71 tr: l 0.276 a 0.919 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.033sec(train) 1.031sec(infer)\n",
      "Epoch 71 tst: l 0.281 a 0.923 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.177sec\n",
      "Epoch 72 tr: l 0.275 a 0.919 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.526sec(train) 1.023sec(infer)\n",
      "Epoch 72 tst: l 0.280 a 0.923 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.165sec\n",
      "Epoch 73 tr: l 0.274 a 0.920 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.066sec(train) 0.926sec(infer)\n",
      "Epoch 73 tst: l 0.278 a 0.923 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.173sec\n",
      "Epoch 74 tr: l 0.272 a 0.920 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.779sec(train) 1.016sec(infer)\n",
      "Epoch 74 tst: l 0.277 a 0.923 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.172sec\n",
      "Epoch 75 tr: l 0.271 a 0.920 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.842sec(train) 0.908sec(infer)\n",
      "Epoch 75 tst: l 0.276 a 0.924 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.151sec\n",
      "Epoch 76 tr: l 0.270 a 0.921 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.590sec(train) 1.022sec(infer)\n",
      "Epoch 76 tst: l 0.275 a 0.924 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.172sec\n",
      "Epoch 77 tr: l 0.269 a 0.921 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.550sec(train) 0.902sec(infer)\n",
      "Epoch 77 tst: l 0.274 a 0.925 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.162sec\n",
      "Epoch 78 tr: l 0.268 a 0.921 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.279sec(train) 1.013sec(infer)\n",
      "Epoch 78 tst: l 0.273 a 0.925 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.167sec\n",
      "Epoch 79 tr: l 0.267 a 0.922 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.301sec(train) 0.928sec(infer)\n",
      "Epoch 79 tst: l 0.272 a 0.925 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.168sec\n",
      "Epoch 80 tr: l 0.265 a 0.922 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.198sec(train) 1.037sec(infer)\n",
      "Epoch 80 tst: l 0.271 a 0.925 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.168sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 81 tr: l 0.264 a 0.922 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.723sec(train) 0.929sec(infer)\n",
      "Epoch 81 tst: l 0.270 a 0.926 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.162sec\n",
      "Epoch 82 tr: l 0.263 a 0.922 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.058sec(train) 1.021sec(infer)\n",
      "Epoch 82 tst: l 0.270 a 0.926 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.171sec\n",
      "Epoch 83 tr: l 0.262 a 0.923 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.261sec(train) 0.964sec(infer)\n",
      "Epoch 83 tst: l 0.269 a 0.926 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.160sec\n",
      "Epoch 84 tr: l 0.261 a 0.923 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.873sec(train) 1.003sec(infer)\n",
      "Epoch 84 tst: l 0.268 a 0.926 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.165sec\n",
      "Epoch 85 tr: l 0.260 a 0.923 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.531sec(train) 0.904sec(infer)\n",
      "Epoch 85 tst: l 0.267 a 0.926 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.156sec\n",
      "Epoch 86 tr: l 0.259 a 0.924 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.819sec(train) 1.153sec(infer)\n",
      "Epoch 86 tst: l 0.266 a 0.926 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.166sec\n",
      "Epoch 87 tr: l 0.258 a 0.924 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.080sec(train) 0.937sec(infer)\n",
      "Epoch 87 tst: l 0.265 a 0.927 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.118sec\n",
      "Epoch 88 tr: l 0.257 a 0.924 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.604sec(train) 0.956sec(infer)\n",
      "Epoch 88 tst: l 0.264 a 0.927 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.172sec\n",
      "Epoch 89 tr: l 0.256 a 0.925 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.042sec(train) 1.037sec(infer)\n",
      "Epoch 89 tst: l 0.263 a 0.927 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.169sec\n",
      "Epoch 90 tr: l 0.255 a 0.925 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.828sec(train) 1.017sec(infer)\n",
      "Epoch 90 tst: l 0.262 a 0.928 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.166sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 91 tr: l 0.254 a 0.925 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.752sec(train) 0.878sec(infer)\n",
      "Epoch 91 tst: l 0.261 a 0.928 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.163sec\n",
      "Epoch 92 tr: l 0.253 a 0.925 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.848sec(train) 0.977sec(infer)\n",
      "Epoch 92 tst: l 0.260 a 0.928 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.158sec\n",
      "Epoch 93 tr: l 0.252 a 0.926 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.653sec(train) 0.984sec(infer)\n",
      "Epoch 93 tst: l 0.259 a 0.928 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.182sec\n",
      "Epoch 94 tr: l 0.251 a 0.926 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.876sec(train) 0.949sec(infer)\n",
      "Epoch 94 tst: l 0.259 a 0.928 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.165sec\n",
      "Epoch 95 tr: l 0.250 a 0.926 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.782sec(train) 1.009sec(infer)\n",
      "Epoch 95 tst: l 0.258 a 0.929 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.169sec\n",
      "Epoch 96 tr: l 0.249 a 0.927 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.654sec(train) 0.941sec(infer)\n",
      "Epoch 96 tst: l 0.257 a 0.929 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.144sec\n",
      "Epoch 97 tr: l 0.248 a 0.927 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.778sec(train) 1.105sec(infer)\n",
      "Epoch 97 tst: l 0.256 a 0.929 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.193sec\n",
      "Epoch 98 tr: l 0.247 a 0.927 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.529sec(train) 1.022sec(infer)\n",
      "Epoch 98 tst: l 0.255 a 0.929 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.157sec\n",
      "Epoch 99 tr: l 0.246 a 0.928 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.569sec(train) 1.101sec(infer)\n",
      "Epoch 99 tst: l 0.254 a 0.929 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.167sec\n",
      "Epoch 100 tr: l 0.245 a 0.928 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.872sec(train) 1.002sec(infer)\n",
      "Epoch 100 tst: l 0.253 a 0.930 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.174sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 101 tr: l 0.244 a 0.928 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.013sec(train) 0.974sec(infer)\n",
      "Epoch 101 tst: l 0.253 a 0.930 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.158sec\n",
      "Epoch 102 tr: l 0.243 a 0.928 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.632sec(train) 0.917sec(infer)\n",
      "Epoch 102 tst: l 0.252 a 0.930 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.159sec\n",
      "Epoch 103 tr: l 0.242 a 0.929 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.440sec(train) 0.985sec(infer)\n",
      "Epoch 103 tst: l 0.251 a 0.931 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.163sec\n",
      "Epoch 104 tr: l 0.241 a 0.929 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.956sec(train) 1.026sec(infer)\n",
      "Epoch 104 tst: l 0.250 a 0.931 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.162sec\n",
      "Epoch 105 tr: l 0.240 a 0.929 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.221sec(train) 0.965sec(infer)\n",
      "Epoch 105 tst: l 0.249 a 0.931 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.164sec\n",
      "Epoch 106 tr: l 0.239 a 0.929 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.638sec(train) 0.970sec(infer)\n",
      "Epoch 106 tst: l 0.249 a 0.931 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.146sec\n",
      "Epoch 107 tr: l 0.238 a 0.930 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.772sec(train) 1.081sec(infer)\n",
      "Epoch 107 tst: l 0.248 a 0.931 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.174sec\n",
      "Epoch 108 tr: l 0.237 a 0.930 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.588sec(train) 0.841sec(infer)\n",
      "Epoch 108 tst: l 0.247 a 0.931 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.151sec\n",
      "Epoch 109 tr: l 0.236 a 0.930 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.360sec(train) 1.004sec(infer)\n",
      "Epoch 109 tst: l 0.246 a 0.932 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.171sec\n",
      "Epoch 110 tr: l 0.236 a 0.930 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.855sec(train) 0.985sec(infer)\n",
      "Epoch 110 tst: l 0.245 a 0.932 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.154sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 111 tr: l 0.235 a 0.931 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.947sec(train) 0.990sec(infer)\n",
      "Epoch 111 tst: l 0.245 a 0.932 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.178sec\n",
      "Epoch 112 tr: l 0.234 a 0.931 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.600sec(train) 1.075sec(infer)\n",
      "Epoch 112 tst: l 0.244 a 0.932 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.163sec\n",
      "Epoch 113 tr: l 0.233 a 0.931 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.797sec(train) 0.988sec(infer)\n",
      "Epoch 113 tst: l 0.243 a 0.932 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.167sec\n",
      "Epoch 114 tr: l 0.232 a 0.931 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.721sec(train) 1.124sec(infer)\n",
      "Epoch 114 tst: l 0.242 a 0.932 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.183sec\n",
      "Epoch 115 tr: l 0.231 a 0.932 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.308sec(train) 1.122sec(infer)\n",
      "Epoch 115 tst: l 0.242 a 0.933 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.179sec\n",
      "Epoch 116 tr: l 0.230 a 0.932 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.709sec(train) 0.988sec(infer)\n",
      "Epoch 116 tst: l 0.241 a 0.933 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.159sec\n",
      "Epoch 117 tr: l 0.230 a 0.932 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.649sec(train) 1.082sec(infer)\n",
      "Epoch 117 tst: l 0.240 a 0.933 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.192sec\n",
      "Epoch 118 tr: l 0.229 a 0.932 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.202sec(train) 1.068sec(infer)\n",
      "Epoch 118 tst: l 0.239 a 0.933 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.164sec\n",
      "Epoch 119 tr: l 0.228 a 0.933 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.615sec(train) 0.999sec(infer)\n",
      "Epoch 119 tst: l 0.239 a 0.933 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.157sec\n",
      "Epoch 120 tr: l 0.227 a 0.933 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.165sec(train) 1.037sec(infer)\n",
      "Epoch 120 tst: l 0.238 a 0.933 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.190sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 121 tr: l 0.226 a 0.933 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.689sec(train) 0.936sec(infer)\n",
      "Epoch 121 tst: l 0.237 a 0.934 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.169sec\n",
      "Epoch 122 tr: l 0.225 a 0.933 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.223sec(train) 0.930sec(infer)\n",
      "Epoch 122 tst: l 0.237 a 0.934 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.164sec\n",
      "Epoch 123 tr: l 0.225 a 0.933 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.692sec(train) 1.032sec(infer)\n",
      "Epoch 123 tst: l 0.236 a 0.934 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.160sec\n",
      "Epoch 124 tr: l 0.224 a 0.934 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.483sec(train) 1.068sec(infer)\n",
      "Epoch 124 tst: l 0.235 a 0.934 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.178sec\n",
      "Epoch 125 tr: l 0.223 a 0.934 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.250sec(train) 1.012sec(infer)\n",
      "Epoch 125 tst: l 0.234 a 0.935 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.164sec\n",
      "Epoch 126 tr: l 0.222 a 0.934 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.610sec(train) 0.827sec(infer)\n",
      "Epoch 126 tst: l 0.234 a 0.935 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.146sec\n",
      "Epoch 127 tr: l 0.222 a 0.934 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.294sec(train) 1.112sec(infer)\n",
      "Epoch 127 tst: l 0.233 a 0.935 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.185sec\n",
      "Epoch 128 tr: l 0.221 a 0.935 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.435sec(train) 1.047sec(infer)\n",
      "Epoch 128 tst: l 0.232 a 0.936 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.174sec\n",
      "Epoch 129 tr: l 0.220 a 0.935 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.404sec(train) 0.895sec(infer)\n",
      "Epoch 129 tst: l 0.232 a 0.936 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.155sec\n",
      "Epoch 130 tr: l 0.219 a 0.935 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.651sec(train) 0.888sec(infer)\n",
      "Epoch 130 tst: l 0.231 a 0.936 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.153sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 131 tr: l 0.218 a 0.935 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.531sec(train) 0.960sec(infer)\n",
      "Epoch 131 tst: l 0.230 a 0.936 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.146sec\n",
      "Epoch 132 tr: l 0.218 a 0.936 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.277sec(train) 0.981sec(infer)\n",
      "Epoch 132 tst: l 0.230 a 0.936 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.170sec\n",
      "Epoch 133 tr: l 0.217 a 0.936 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.166sec(train) 0.933sec(infer)\n",
      "Epoch 133 tst: l 0.229 a 0.937 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.182sec\n",
      "Epoch 134 tr: l 0.216 a 0.936 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.579sec(train) 0.888sec(infer)\n",
      "Epoch 134 tst: l 0.228 a 0.937 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.161sec\n",
      "Epoch 135 tr: l 0.216 a 0.936 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.199sec(train) 1.058sec(infer)\n",
      "Epoch 135 tst: l 0.228 a 0.937 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.171sec\n",
      "Epoch 136 tr: l 0.215 a 0.936 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.464sec(train) 1.155sec(infer)\n",
      "Epoch 136 tst: l 0.227 a 0.937 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.201sec\n",
      "Epoch 137 tr: l 0.214 a 0.937 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.559sec(train) 0.993sec(infer)\n",
      "Epoch 137 tst: l 0.226 a 0.937 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.164sec\n",
      "Epoch 138 tr: l 0.213 a 0.937 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.492sec(train) 0.929sec(infer)\n",
      "Epoch 138 tst: l 0.226 a 0.937 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.138sec\n",
      "Epoch 139 tr: l 0.213 a 0.937 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.657sec(train) 1.080sec(infer)\n",
      "Epoch 139 tst: l 0.225 a 0.938 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.202sec\n",
      "Epoch 140 tr: l 0.212 a 0.937 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.882sec(train) 1.038sec(infer)\n",
      "Epoch 140 tst: l 0.224 a 0.938 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.177sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 141 tr: l 0.211 a 0.937 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.681sec(train) 1.028sec(infer)\n",
      "Epoch 141 tst: l 0.224 a 0.938 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.177sec\n",
      "Epoch 142 tr: l 0.210 a 0.938 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.450sec(train) 0.938sec(infer)\n",
      "Epoch 142 tst: l 0.223 a 0.938 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.168sec\n",
      "Epoch 143 tr: l 0.210 a 0.938 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.015sec(train) 0.985sec(infer)\n",
      "Epoch 143 tst: l 0.223 a 0.938 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.158sec\n",
      "Epoch 144 tr: l 0.209 a 0.938 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.707sec(train) 1.017sec(infer)\n",
      "Epoch 144 tst: l 0.222 a 0.938 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.159sec\n",
      "Epoch 145 tr: l 0.208 a 0.938 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.530sec(train) 1.069sec(infer)\n",
      "Epoch 145 tst: l 0.221 a 0.938 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.185sec\n",
      "Epoch 146 tr: l 0.208 a 0.938 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.236sec(train) 1.000sec(infer)\n",
      "Epoch 146 tst: l 0.221 a 0.939 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.172sec\n",
      "Epoch 147 tr: l 0.207 a 0.939 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.089sec(train) 0.838sec(infer)\n",
      "Epoch 147 tst: l 0.220 a 0.939 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.179sec\n",
      "Epoch 148 tr: l 0.206 a 0.939 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.978sec(train) 0.857sec(infer)\n",
      "Epoch 148 tst: l 0.219 a 0.939 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.125sec\n",
      "Epoch 149 tr: l 0.206 a 0.939 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.360sec(train) 1.019sec(infer)\n",
      "Epoch 149 tst: l 0.219 a 0.939 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.166sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "---train cluster Ended in 0.20 hour (730.335 sec) \n",
      "---------------------------------IFCA, lr: 0.1, seed: 6930---------------------------------\n",
      "config: {'m': 240, 'm_test': 40, 'p': 2, 'n': 500, 'uneven': True, 'local_model_init': False, 'Gp': 0.1, 'graph': 'er', 'agg': 'seq', 'h1': 200, 'num_epochs': 150, 'batch_size': 100, 'tau': 10, 'lr': 0.1, 'data_seed': 6930, 'train_seed': 6930, 'config_override': '', 'project_dir': 'output_dfca_gi'}\n",
      "Using device: cuda:1\n",
      "Epoch -1 tr: l 2.300 a 0.096 clct[np.int64(106), np.int64(134)] cl_acc 0.892  0.973sec\n",
      "Epoch -1 tst: l 2.298 a 0.095 clct[np.int64(17), np.int64(23)] cl_acc 0.925  0.132sec\n",
      "Epoch 0 tr: l 2.124 a 0.571 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.599sec(train) 1.092sec(infer)\n",
      "Epoch 0 tst: l 2.121 a 0.573 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.186sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 1 tr: l 1.846 a 0.709 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.220sec(train) 1.186sec(infer)\n",
      "Epoch 1 tst: l 1.840 a 0.714 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.199sec\n",
      "Epoch 2 tr: l 1.514 a 0.749 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.567sec(train) 1.053sec(infer)\n",
      "Epoch 2 tst: l 1.502 a 0.755 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.173sec\n",
      "Epoch 3 tr: l 1.217 a 0.781 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.070sec(train) 0.910sec(infer)\n",
      "Epoch 3 tst: l 1.201 a 0.790 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.138sec\n",
      "Epoch 4 tr: l 1.001 a 0.808 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.834sec(train) 0.978sec(infer)\n",
      "Epoch 4 tst: l 0.984 a 0.816 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.151sec\n",
      "Epoch 5 tr: l 0.855 a 0.826 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.322sec(train) 1.057sec(infer)\n",
      "Epoch 5 tst: l 0.836 a 0.833 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.183sec\n",
      "Epoch 6 tr: l 0.754 a 0.838 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.051sec(train) 0.914sec(infer)\n",
      "Epoch 6 tst: l 0.735 a 0.846 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.147sec\n",
      "Epoch 7 tr: l 0.681 a 0.847 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.420sec(train) 0.925sec(infer)\n",
      "Epoch 7 tst: l 0.662 a 0.855 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.151sec\n",
      "Epoch 8 tr: l 0.627 a 0.855 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.524sec(train) 1.027sec(infer)\n",
      "Epoch 8 tst: l 0.607 a 0.862 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.176sec\n",
      "Epoch 9 tr: l 0.585 a 0.861 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.586sec(train) 1.018sec(infer)\n",
      "Epoch 9 tst: l 0.565 a 0.868 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.138sec\n",
      "Epoch 10 tr: l 0.551 a 0.865 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.387sec(train) 0.986sec(infer)\n",
      "Epoch 10 tst: l 0.531 a 0.873 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.193sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 11 tr: l 0.524 a 0.870 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.757sec(train) 0.905sec(infer)\n",
      "Epoch 11 tst: l 0.504 a 0.878 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.146sec\n",
      "Epoch 12 tr: l 0.502 a 0.873 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.419sec(train) 0.914sec(infer)\n",
      "Epoch 12 tst: l 0.481 a 0.881 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.143sec\n",
      "Epoch 13 tr: l 0.483 a 0.876 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.165sec(train) 1.069sec(infer)\n",
      "Epoch 13 tst: l 0.463 a 0.884 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.178sec\n",
      "Epoch 14 tr: l 0.467 a 0.879 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.284sec(train) 1.073sec(infer)\n",
      "Epoch 14 tst: l 0.447 a 0.887 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.193sec\n",
      "Epoch 15 tr: l 0.453 a 0.881 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.471sec(train) 0.877sec(infer)\n",
      "Epoch 15 tst: l 0.433 a 0.889 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.135sec\n",
      "Epoch 16 tr: l 0.441 a 0.883 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.314sec(train) 0.918sec(infer)\n",
      "Epoch 16 tst: l 0.421 a 0.891 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.160sec\n",
      "Epoch 17 tr: l 0.430 a 0.885 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.587sec(train) 0.973sec(infer)\n",
      "Epoch 17 tst: l 0.410 a 0.893 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.166sec\n",
      "Epoch 18 tr: l 0.421 a 0.887 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.509sec(train) 0.989sec(infer)\n",
      "Epoch 18 tst: l 0.401 a 0.894 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.162sec\n",
      "Epoch 19 tr: l 0.412 a 0.889 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.408sec(train) 0.980sec(infer)\n",
      "Epoch 19 tst: l 0.393 a 0.896 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.151sec\n",
      "Epoch 20 tr: l 0.405 a 0.890 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.593sec(train) 1.139sec(infer)\n",
      "Epoch 20 tst: l 0.385 a 0.897 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.168sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 21 tr: l 0.398 a 0.891 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.022sec(train) 1.002sec(infer)\n",
      "Epoch 21 tst: l 0.379 a 0.897 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.164sec\n",
      "Epoch 22 tr: l 0.391 a 0.893 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.849sec(train) 0.873sec(infer)\n",
      "Epoch 22 tst: l 0.373 a 0.898 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.160sec\n",
      "Epoch 23 tr: l 0.386 a 0.894 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.342sec(train) 0.966sec(infer)\n",
      "Epoch 23 tst: l 0.367 a 0.899 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.162sec\n",
      "Epoch 24 tr: l 0.380 a 0.895 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.536sec(train) 0.957sec(infer)\n",
      "Epoch 24 tst: l 0.362 a 0.900 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.159sec\n",
      "Epoch 25 tr: l 0.375 a 0.896 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.288sec(train) 1.049sec(infer)\n",
      "Epoch 25 tst: l 0.357 a 0.901 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.168sec\n",
      "Epoch 26 tr: l 0.371 a 0.897 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.830sec(train) 0.946sec(infer)\n",
      "Epoch 26 tst: l 0.353 a 0.901 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.163sec\n",
      "Epoch 27 tr: l 0.366 a 0.898 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.935sec(train) 1.043sec(infer)\n",
      "Epoch 27 tst: l 0.349 a 0.902 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.158sec\n",
      "Epoch 28 tr: l 0.362 a 0.898 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.565sec(train) 1.085sec(infer)\n",
      "Epoch 28 tst: l 0.345 a 0.903 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.184sec\n",
      "Epoch 29 tr: l 0.359 a 0.899 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.652sec(train) 0.984sec(infer)\n",
      "Epoch 29 tst: l 0.342 a 0.903 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.169sec\n",
      "Epoch 30 tr: l 0.355 a 0.900 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.417sec(train) 0.904sec(infer)\n",
      "Epoch 30 tst: l 0.338 a 0.904 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.149sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 31 tr: l 0.352 a 0.901 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.841sec(train) 1.062sec(infer)\n",
      "Epoch 31 tst: l 0.335 a 0.904 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.178sec\n",
      "Epoch 32 tr: l 0.349 a 0.901 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.024sec(train) 0.993sec(infer)\n",
      "Epoch 32 tst: l 0.332 a 0.905 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.155sec\n",
      "Epoch 33 tr: l 0.345 a 0.902 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.034sec(train) 1.011sec(infer)\n",
      "Epoch 33 tst: l 0.329 a 0.906 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.163sec\n",
      "Epoch 34 tr: l 0.343 a 0.903 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.714sec(train) 1.025sec(infer)\n",
      "Epoch 34 tst: l 0.327 a 0.906 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.162sec\n",
      "Epoch 35 tr: l 0.340 a 0.903 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.875sec(train) 1.024sec(infer)\n",
      "Epoch 35 tst: l 0.324 a 0.907 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.170sec\n",
      "Epoch 36 tr: l 0.337 a 0.904 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.849sec(train) 0.967sec(infer)\n",
      "Epoch 36 tst: l 0.321 a 0.908 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.150sec\n",
      "Epoch 37 tr: l 0.335 a 0.905 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.839sec(train) 0.981sec(infer)\n",
      "Epoch 37 tst: l 0.319 a 0.908 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.176sec\n",
      "Epoch 38 tr: l 0.332 a 0.905 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.259sec(train) 1.011sec(infer)\n",
      "Epoch 38 tst: l 0.317 a 0.909 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.164sec\n",
      "Epoch 39 tr: l 0.330 a 0.906 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.127sec(train) 0.977sec(infer)\n",
      "Epoch 39 tst: l 0.315 a 0.910 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.178sec\n",
      "Epoch 40 tr: l 0.327 a 0.906 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.185sec(train) 0.986sec(infer)\n",
      "Epoch 40 tst: l 0.313 a 0.910 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.182sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 41 tr: l 0.325 a 0.907 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.085sec(train) 0.939sec(infer)\n",
      "Epoch 41 tst: l 0.311 a 0.911 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.153sec\n",
      "Epoch 42 tr: l 0.323 a 0.908 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.363sec(train) 1.122sec(infer)\n",
      "Epoch 42 tst: l 0.309 a 0.912 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.206sec\n",
      "Epoch 43 tr: l 0.321 a 0.908 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.144sec(train) 1.049sec(infer)\n",
      "Epoch 43 tst: l 0.307 a 0.912 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.178sec\n",
      "Epoch 44 tr: l 0.319 a 0.909 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.463sec(train) 0.905sec(infer)\n",
      "Epoch 44 tst: l 0.305 a 0.913 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.154sec\n",
      "Epoch 45 tr: l 0.317 a 0.909 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.089sec(train) 1.077sec(infer)\n",
      "Epoch 45 tst: l 0.303 a 0.913 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.156sec\n",
      "Epoch 46 tr: l 0.315 a 0.910 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.859sec(train) 1.039sec(infer)\n",
      "Epoch 46 tst: l 0.301 a 0.914 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.172sec\n",
      "Epoch 47 tr: l 0.313 a 0.910 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.779sec(train) 0.935sec(infer)\n",
      "Epoch 47 tst: l 0.300 a 0.914 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.152sec\n",
      "Epoch 48 tr: l 0.311 a 0.910 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.535sec(train) 0.900sec(infer)\n",
      "Epoch 48 tst: l 0.298 a 0.915 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.143sec\n",
      "Epoch 49 tr: l 0.309 a 0.911 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.657sec(train) 1.010sec(infer)\n",
      "Epoch 49 tst: l 0.296 a 0.915 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.203sec\n",
      "Epoch 50 tr: l 0.308 a 0.911 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.959sec(train) 1.022sec(infer)\n",
      "Epoch 50 tst: l 0.295 a 0.915 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.182sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 51 tr: l 0.306 a 0.912 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.141sec(train) 0.881sec(infer)\n",
      "Epoch 51 tst: l 0.293 a 0.916 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.149sec\n",
      "Epoch 52 tr: l 0.304 a 0.912 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.841sec(train) 0.949sec(infer)\n",
      "Epoch 52 tst: l 0.292 a 0.916 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.161sec\n",
      "Epoch 53 tr: l 0.303 a 0.913 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.739sec(train) 1.102sec(infer)\n",
      "Epoch 53 tst: l 0.290 a 0.917 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.208sec\n",
      "Epoch 54 tr: l 0.301 a 0.913 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.932sec(train) 0.956sec(infer)\n",
      "Epoch 54 tst: l 0.289 a 0.917 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.149sec\n",
      "Epoch 55 tr: l 0.299 a 0.914 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.600sec(train) 0.996sec(infer)\n",
      "Epoch 55 tst: l 0.288 a 0.918 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.169sec\n",
      "Epoch 56 tr: l 0.298 a 0.914 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.927sec(train) 0.951sec(infer)\n",
      "Epoch 56 tst: l 0.286 a 0.918 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.174sec\n",
      "Epoch 57 tr: l 0.296 a 0.914 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.966sec(train) 1.041sec(infer)\n",
      "Epoch 57 tst: l 0.285 a 0.919 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.161sec\n",
      "Epoch 58 tr: l 0.295 a 0.915 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.409sec(train) 1.133sec(infer)\n",
      "Epoch 58 tst: l 0.284 a 0.919 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.166sec\n",
      "Epoch 59 tr: l 0.293 a 0.915 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.715sec(train) 0.895sec(infer)\n",
      "Epoch 59 tst: l 0.282 a 0.920 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.152sec\n",
      "Epoch 60 tr: l 0.292 a 0.916 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.838sec(train) 0.887sec(infer)\n",
      "Epoch 60 tst: l 0.281 a 0.920 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.140sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 61 tr: l 0.290 a 0.916 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.505sec(train) 0.970sec(infer)\n",
      "Epoch 61 tst: l 0.280 a 0.920 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.159sec\n",
      "Epoch 62 tr: l 0.289 a 0.916 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.446sec(train) 0.934sec(infer)\n",
      "Epoch 62 tst: l 0.279 a 0.921 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.189sec\n",
      "Epoch 63 tr: l 0.288 a 0.917 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.466sec(train) 0.950sec(infer)\n",
      "Epoch 63 tst: l 0.277 a 0.921 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.173sec\n",
      "Epoch 64 tr: l 0.286 a 0.917 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.702sec(train) 0.962sec(infer)\n",
      "Epoch 64 tst: l 0.276 a 0.921 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.160sec\n",
      "Epoch 65 tr: l 0.285 a 0.918 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.543sec(train) 1.053sec(infer)\n",
      "Epoch 65 tst: l 0.275 a 0.922 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.166sec\n",
      "Epoch 66 tr: l 0.283 a 0.918 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.951sec(train) 0.946sec(infer)\n",
      "Epoch 66 tst: l 0.274 a 0.922 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.156sec\n",
      "Epoch 67 tr: l 0.282 a 0.918 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.324sec(train) 0.831sec(infer)\n",
      "Epoch 67 tst: l 0.273 a 0.922 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.139sec\n",
      "Epoch 68 tr: l 0.281 a 0.919 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.312sec(train) 0.971sec(infer)\n",
      "Epoch 68 tst: l 0.272 a 0.923 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.160sec\n",
      "Epoch 69 tr: l 0.280 a 0.919 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.329sec(train) 0.940sec(infer)\n",
      "Epoch 69 tst: l 0.271 a 0.923 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.157sec\n",
      "Epoch 70 tr: l 0.278 a 0.919 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.311sec(train) 1.003sec(infer)\n",
      "Epoch 70 tst: l 0.270 a 0.923 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.243sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 71 tr: l 0.277 a 0.920 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.196sec(train) 0.981sec(infer)\n",
      "Epoch 71 tst: l 0.268 a 0.924 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.155sec\n",
      "Epoch 72 tr: l 0.276 a 0.920 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.714sec(train) 0.980sec(infer)\n",
      "Epoch 72 tst: l 0.267 a 0.924 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.162sec\n",
      "Epoch 73 tr: l 0.275 a 0.920 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.684sec(train) 1.021sec(infer)\n",
      "Epoch 73 tst: l 0.266 a 0.924 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.164sec\n",
      "Epoch 74 tr: l 0.273 a 0.921 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.604sec(train) 0.916sec(infer)\n",
      "Epoch 74 tst: l 0.265 a 0.925 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.163sec\n",
      "Epoch 75 tr: l 0.272 a 0.921 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 2.803sec(train) 0.970sec(infer)\n",
      "Epoch 75 tst: l 0.264 a 0.925 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.165sec\n",
      "Epoch 76 tr: l 0.271 a 0.921 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.032sec(train) 0.956sec(infer)\n",
      "Epoch 76 tst: l 0.263 a 0.925 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.155sec\n",
      "Epoch 77 tr: l 0.270 a 0.922 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.187sec(train) 0.994sec(infer)\n",
      "Epoch 77 tst: l 0.262 a 0.926 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.165sec\n",
      "Epoch 78 tr: l 0.269 a 0.922 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.384sec(train) 0.899sec(infer)\n",
      "Epoch 78 tst: l 0.261 a 0.926 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.141sec\n",
      "Epoch 79 tr: l 0.267 a 0.922 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.535sec(train) 0.973sec(infer)\n",
      "Epoch 79 tst: l 0.260 a 0.926 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.187sec\n",
      "Epoch 80 tr: l 0.266 a 0.923 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.493sec(train) 1.059sec(infer)\n",
      "Epoch 80 tst: l 0.259 a 0.927 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.198sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 81 tr: l 0.265 a 0.923 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.544sec(train) 0.950sec(infer)\n",
      "Epoch 81 tst: l 0.258 a 0.927 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.136sec\n",
      "Epoch 82 tr: l 0.264 a 0.923 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.324sec(train) 0.842sec(infer)\n",
      "Epoch 82 tst: l 0.257 a 0.927 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.144sec\n",
      "Epoch 83 tr: l 0.263 a 0.924 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.600sec(train) 1.168sec(infer)\n",
      "Epoch 83 tst: l 0.257 a 0.927 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.208sec\n",
      "Epoch 84 tr: l 0.262 a 0.924 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.358sec(train) 0.928sec(infer)\n",
      "Epoch 84 tst: l 0.256 a 0.927 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.165sec\n",
      "Epoch 85 tr: l 0.261 a 0.924 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.042sec(train) 0.925sec(infer)\n",
      "Epoch 85 tst: l 0.255 a 0.928 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.171sec\n",
      "Epoch 86 tr: l 0.260 a 0.925 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.263sec(train) 1.050sec(infer)\n",
      "Epoch 86 tst: l 0.254 a 0.928 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.233sec\n",
      "Epoch 87 tr: l 0.259 a 0.925 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.432sec(train) 1.191sec(infer)\n",
      "Epoch 87 tst: l 0.253 a 0.928 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.171sec\n",
      "Epoch 88 tr: l 0.258 a 0.925 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.487sec(train) 1.070sec(infer)\n",
      "Epoch 88 tst: l 0.252 a 0.928 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.163sec\n",
      "Epoch 89 tr: l 0.257 a 0.925 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.754sec(train) 0.936sec(infer)\n",
      "Epoch 89 tst: l 0.251 a 0.928 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.169sec\n",
      "Epoch 90 tr: l 0.255 a 0.925 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.535sec(train) 0.970sec(infer)\n",
      "Epoch 90 tst: l 0.250 a 0.928 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.154sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 91 tr: l 0.254 a 0.926 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.218sec(train) 0.975sec(infer)\n",
      "Epoch 91 tst: l 0.249 a 0.928 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.129sec\n",
      "Epoch 92 tr: l 0.253 a 0.926 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.995sec(train) 0.941sec(infer)\n",
      "Epoch 92 tst: l 0.248 a 0.928 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.154sec\n",
      "Epoch 93 tr: l 0.252 a 0.927 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.474sec(train) 0.875sec(infer)\n",
      "Epoch 93 tst: l 0.248 a 0.929 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.153sec\n",
      "Epoch 94 tr: l 0.251 a 0.927 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.378sec(train) 0.976sec(infer)\n",
      "Epoch 94 tst: l 0.247 a 0.929 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.151sec\n",
      "Epoch 95 tr: l 0.250 a 0.927 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.282sec(train) 0.901sec(infer)\n",
      "Epoch 95 tst: l 0.246 a 0.929 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.156sec\n",
      "Epoch 96 tr: l 0.249 a 0.927 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.723sec(train) 0.932sec(infer)\n",
      "Epoch 96 tst: l 0.245 a 0.929 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.165sec\n",
      "Epoch 97 tr: l 0.248 a 0.928 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.607sec(train) 0.919sec(infer)\n",
      "Epoch 97 tst: l 0.244 a 0.930 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.159sec\n",
      "Epoch 98 tr: l 0.247 a 0.928 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.474sec(train) 1.029sec(infer)\n",
      "Epoch 98 tst: l 0.243 a 0.930 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.168sec\n",
      "Epoch 99 tr: l 0.246 a 0.928 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.755sec(train) 0.928sec(infer)\n",
      "Epoch 99 tst: l 0.243 a 0.930 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.148sec\n",
      "Epoch 100 tr: l 0.245 a 0.929 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.230sec(train) 0.946sec(infer)\n",
      "Epoch 100 tst: l 0.242 a 0.930 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.175sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 101 tr: l 0.245 a 0.929 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.631sec(train) 0.903sec(infer)\n",
      "Epoch 101 tst: l 0.241 a 0.930 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.156sec\n",
      "Epoch 102 tr: l 0.244 a 0.929 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.629sec(train) 0.886sec(infer)\n",
      "Epoch 102 tst: l 0.240 a 0.930 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.140sec\n",
      "Epoch 103 tr: l 0.243 a 0.929 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.647sec(train) 0.984sec(infer)\n",
      "Epoch 103 tst: l 0.239 a 0.930 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.158sec\n",
      "Epoch 104 tr: l 0.242 a 0.930 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.375sec(train) 1.037sec(infer)\n",
      "Epoch 104 tst: l 0.239 a 0.930 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.177sec\n",
      "Epoch 105 tr: l 0.241 a 0.930 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.533sec(train) 0.924sec(infer)\n",
      "Epoch 105 tst: l 0.238 a 0.931 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.156sec\n",
      "Epoch 106 tr: l 0.240 a 0.930 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.420sec(train) 0.835sec(infer)\n",
      "Epoch 106 tst: l 0.237 a 0.931 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.139sec\n",
      "Epoch 107 tr: l 0.239 a 0.930 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.332sec(train) 1.005sec(infer)\n",
      "Epoch 107 tst: l 0.236 a 0.931 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.163sec\n",
      "Epoch 108 tr: l 0.238 a 0.931 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.460sec(train) 1.111sec(infer)\n",
      "Epoch 108 tst: l 0.235 a 0.931 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.171sec\n",
      "Epoch 109 tr: l 0.237 a 0.931 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.442sec(train) 0.992sec(infer)\n",
      "Epoch 109 tst: l 0.235 a 0.932 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.163sec\n",
      "Epoch 110 tr: l 0.236 a 0.931 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.058sec(train) 0.856sec(infer)\n",
      "Epoch 110 tst: l 0.234 a 0.932 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.145sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 111 tr: l 0.235 a 0.931 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.593sec(train) 0.967sec(infer)\n",
      "Epoch 111 tst: l 0.233 a 0.932 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.127sec\n",
      "Epoch 112 tr: l 0.234 a 0.932 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.924sec(train) 0.948sec(infer)\n",
      "Epoch 112 tst: l 0.232 a 0.933 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.164sec\n",
      "Epoch 113 tr: l 0.234 a 0.932 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.973sec(train) 1.161sec(infer)\n",
      "Epoch 113 tst: l 0.232 a 0.933 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.183sec\n",
      "Epoch 114 tr: l 0.233 a 0.932 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.792sec(train) 0.950sec(infer)\n",
      "Epoch 114 tst: l 0.231 a 0.933 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.162sec\n",
      "Epoch 115 tr: l 0.232 a 0.932 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.807sec(train) 1.035sec(infer)\n",
      "Epoch 115 tst: l 0.230 a 0.934 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.165sec\n",
      "Epoch 116 tr: l 0.231 a 0.932 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.178sec(train) 1.086sec(infer)\n",
      "Epoch 116 tst: l 0.230 a 0.934 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.180sec\n",
      "Epoch 117 tr: l 0.230 a 0.933 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.049sec(train) 1.058sec(infer)\n",
      "Epoch 117 tst: l 0.229 a 0.934 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.164sec\n",
      "Epoch 118 tr: l 0.229 a 0.933 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.694sec(train) 1.023sec(infer)\n",
      "Epoch 118 tst: l 0.228 a 0.934 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.184sec\n",
      "Epoch 119 tr: l 0.229 a 0.933 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.762sec(train) 0.955sec(infer)\n",
      "Epoch 119 tst: l 0.227 a 0.935 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.180sec\n",
      "Epoch 120 tr: l 0.228 a 0.934 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.693sec(train) 0.954sec(infer)\n",
      "Epoch 120 tst: l 0.227 a 0.935 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.167sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 121 tr: l 0.227 a 0.934 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.418sec(train) 0.964sec(infer)\n",
      "Epoch 121 tst: l 0.226 a 0.935 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.156sec\n",
      "Epoch 122 tr: l 0.226 a 0.934 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.500sec(train) 0.965sec(infer)\n",
      "Epoch 122 tst: l 0.225 a 0.935 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.159sec\n",
      "Epoch 123 tr: l 0.225 a 0.934 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.720sec(train) 0.881sec(infer)\n",
      "Epoch 123 tst: l 0.225 a 0.935 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.161sec\n",
      "Epoch 124 tr: l 0.224 a 0.934 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.683sec(train) 1.045sec(infer)\n",
      "Epoch 124 tst: l 0.224 a 0.936 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.169sec\n",
      "Epoch 125 tr: l 0.224 a 0.935 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.598sec(train) 0.916sec(infer)\n",
      "Epoch 125 tst: l 0.223 a 0.936 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.158sec\n",
      "Epoch 126 tr: l 0.223 a 0.935 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.045sec(train) 1.043sec(infer)\n",
      "Epoch 126 tst: l 0.223 a 0.936 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.172sec\n",
      "Epoch 127 tr: l 0.222 a 0.935 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.107sec(train) 0.955sec(infer)\n",
      "Epoch 127 tst: l 0.222 a 0.936 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.150sec\n",
      "Epoch 128 tr: l 0.221 a 0.935 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 2.906sec(train) 1.005sec(infer)\n",
      "Epoch 128 tst: l 0.221 a 0.936 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.164sec\n",
      "Epoch 129 tr: l 0.220 a 0.936 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.554sec(train) 1.005sec(infer)\n",
      "Epoch 129 tst: l 0.221 a 0.936 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.168sec\n",
      "Epoch 130 tr: l 0.220 a 0.936 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.319sec(train) 1.067sec(infer)\n",
      "Epoch 130 tst: l 0.220 a 0.937 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.170sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 131 tr: l 0.219 a 0.936 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.566sec(train) 1.011sec(infer)\n",
      "Epoch 131 tst: l 0.219 a 0.937 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.171sec\n",
      "Epoch 132 tr: l 0.218 a 0.936 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.588sec(train) 1.010sec(infer)\n",
      "Epoch 132 tst: l 0.219 a 0.937 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.169sec\n",
      "Epoch 133 tr: l 0.217 a 0.937 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.440sec(train) 0.947sec(infer)\n",
      "Epoch 133 tst: l 0.218 a 0.937 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.155sec\n",
      "Epoch 134 tr: l 0.217 a 0.937 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.749sec(train) 1.047sec(infer)\n",
      "Epoch 134 tst: l 0.217 a 0.937 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.148sec\n",
      "Epoch 135 tr: l 0.216 a 0.937 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.220sec(train) 0.931sec(infer)\n",
      "Epoch 135 tst: l 0.217 a 0.938 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.189sec\n",
      "Epoch 136 tr: l 0.215 a 0.937 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.930sec(train) 0.973sec(infer)\n",
      "Epoch 136 tst: l 0.216 a 0.938 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.166sec\n",
      "Epoch 137 tr: l 0.214 a 0.937 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.930sec(train) 0.961sec(infer)\n",
      "Epoch 137 tst: l 0.216 a 0.938 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.163sec\n",
      "Epoch 138 tr: l 0.214 a 0.938 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.982sec(train) 1.015sec(infer)\n",
      "Epoch 138 tst: l 0.215 a 0.938 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.169sec\n",
      "Epoch 139 tr: l 0.213 a 0.938 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.576sec(train) 0.935sec(infer)\n",
      "Epoch 139 tst: l 0.214 a 0.938 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.170sec\n",
      "Epoch 140 tr: l 0.212 a 0.938 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.386sec(train) 0.985sec(infer)\n",
      "Epoch 140 tst: l 0.214 a 0.938 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.170sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 141 tr: l 0.211 a 0.938 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.498sec(train) 0.945sec(infer)\n",
      "Epoch 141 tst: l 0.213 a 0.938 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.155sec\n",
      "Epoch 142 tr: l 0.211 a 0.938 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.464sec(train) 0.892sec(infer)\n",
      "Epoch 142 tst: l 0.212 a 0.938 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.166sec\n",
      "Epoch 143 tr: l 0.210 a 0.939 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.605sec(train) 1.065sec(infer)\n",
      "Epoch 143 tst: l 0.212 a 0.938 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.168sec\n",
      "Epoch 144 tr: l 0.209 a 0.939 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.791sec(train) 1.042sec(infer)\n",
      "Epoch 144 tst: l 0.211 a 0.938 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.174sec\n",
      "Epoch 145 tr: l 0.209 a 0.939 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.678sec(train) 1.014sec(infer)\n",
      "Epoch 145 tst: l 0.211 a 0.938 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.162sec\n",
      "Epoch 146 tr: l 0.208 a 0.939 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.790sec(train) 0.961sec(infer)\n",
      "Epoch 146 tst: l 0.210 a 0.938 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.179sec\n",
      "Epoch 147 tr: l 0.207 a 0.940 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.789sec(train) 1.098sec(infer)\n",
      "Epoch 147 tst: l 0.210 a 0.938 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.169sec\n",
      "Epoch 148 tr: l 0.206 a 0.940 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.516sec(train) 0.967sec(infer)\n",
      "Epoch 148 tst: l 0.209 a 0.939 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.162sec\n",
      "Epoch 149 tr: l 0.206 a 0.940 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.730sec(train) 1.044sec(infer)\n",
      "Epoch 149 tst: l 0.208 a 0.939 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.194sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "---train cluster Ended in 0.20 hour (725.436 sec) \n",
      "---------------------------------IFCA, lr: 0.1, seed: 6753---------------------------------\n",
      "config: {'m': 240, 'm_test': 40, 'p': 2, 'n': 500, 'uneven': True, 'local_model_init': False, 'Gp': 0.1, 'graph': 'er', 'agg': 'seq', 'h1': 200, 'num_epochs': 150, 'batch_size': 100, 'tau': 10, 'lr': 0.1, 'data_seed': 6753, 'train_seed': 6753, 'config_override': '', 'project_dir': 'output_dfca_gi'}\n",
      "Using device: cuda:1\n",
      "Epoch -1 tr: l 2.300 a 0.116 clct[np.int64(228), np.int64(12)] cl_acc 0.517  1.077sec\n",
      "Epoch -1 tst: l 2.301 a 0.117 clct[np.int64(38), np.int64(2)] cl_acc 0.550  0.229sec\n",
      "Epoch 0 tr: l 2.176 a 0.326 clct[np.int64(203), np.int64(37)] cl_acc 0.637  lr 0.100000 3.703sec(train) 0.878sec(infer)\n",
      "Epoch 0 tst: l 2.175 a 0.332 clct[np.int64(34), np.int64(6)] cl_acc 0.650  0.155sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 1 tr: l 1.957 a 0.546 clct[np.int64(121), np.int64(119)] cl_acc 0.988  lr 0.100000 4.101sec(train) 1.056sec(infer)\n",
      "Epoch 1 tst: l 1.948 a 0.559 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.147sec\n",
      "Epoch 2 tr: l 1.625 a 0.726 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.715sec(train) 0.875sec(infer)\n",
      "Epoch 2 tst: l 1.606 a 0.739 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.177sec\n",
      "Epoch 3 tr: l 1.308 a 0.773 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.855sec(train) 1.071sec(infer)\n",
      "Epoch 3 tst: l 1.283 a 0.786 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.168sec\n",
      "Epoch 4 tr: l 1.064 a 0.801 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.745sec(train) 0.829sec(infer)\n",
      "Epoch 4 tst: l 1.039 a 0.810 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.145sec\n",
      "Epoch 5 tr: l 0.897 a 0.820 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.984sec(train) 1.035sec(infer)\n",
      "Epoch 5 tst: l 0.872 a 0.828 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.155sec\n",
      "Epoch 6 tr: l 0.783 a 0.833 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.626sec(train) 0.896sec(infer)\n",
      "Epoch 6 tst: l 0.760 a 0.842 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.168sec\n",
      "Epoch 7 tr: l 0.703 a 0.843 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.111sec(train) 0.894sec(infer)\n",
      "Epoch 7 tst: l 0.680 a 0.852 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.146sec\n",
      "Epoch 8 tr: l 0.644 a 0.851 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.798sec(train) 1.008sec(infer)\n",
      "Epoch 8 tst: l 0.622 a 0.860 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.176sec\n",
      "Epoch 9 tr: l 0.598 a 0.858 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.911sec(train) 0.993sec(infer)\n",
      "Epoch 9 tst: l 0.577 a 0.865 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.161sec\n",
      "Epoch 10 tr: l 0.563 a 0.863 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.628sec(train) 1.003sec(infer)\n",
      "Epoch 10 tst: l 0.543 a 0.870 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.168sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 11 tr: l 0.534 a 0.868 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.889sec(train) 1.015sec(infer)\n",
      "Epoch 11 tst: l 0.515 a 0.874 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.167sec\n",
      "Epoch 12 tr: l 0.510 a 0.871 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.529sec(train) 0.940sec(infer)\n",
      "Epoch 12 tst: l 0.491 a 0.879 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.149sec\n",
      "Epoch 13 tr: l 0.490 a 0.875 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.394sec(train) 0.963sec(infer)\n",
      "Epoch 13 tst: l 0.472 a 0.882 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.169sec\n",
      "Epoch 14 tr: l 0.473 a 0.878 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.759sec(train) 0.961sec(infer)\n",
      "Epoch 14 tst: l 0.456 a 0.885 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.166sec\n",
      "Epoch 15 tr: l 0.459 a 0.880 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.616sec(train) 0.846sec(infer)\n",
      "Epoch 15 tst: l 0.442 a 0.887 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.164sec\n",
      "Epoch 16 tr: l 0.446 a 0.883 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.265sec(train) 0.984sec(infer)\n",
      "Epoch 16 tst: l 0.430 a 0.890 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.175sec\n",
      "Epoch 17 tr: l 0.435 a 0.885 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.974sec(train) 0.995sec(infer)\n",
      "Epoch 17 tst: l 0.419 a 0.892 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.173sec\n",
      "Epoch 18 tr: l 0.425 a 0.886 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.008sec(train) 1.051sec(infer)\n",
      "Epoch 18 tst: l 0.410 a 0.893 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.163sec\n",
      "Epoch 19 tr: l 0.416 a 0.888 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.469sec(train) 0.857sec(infer)\n",
      "Epoch 19 tst: l 0.402 a 0.895 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.146sec\n",
      "Epoch 20 tr: l 0.408 a 0.889 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.123sec(train) 0.976sec(infer)\n",
      "Epoch 20 tst: l 0.394 a 0.897 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.148sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 21 tr: l 0.401 a 0.891 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.774sec(train) 0.985sec(infer)\n",
      "Epoch 21 tst: l 0.387 a 0.898 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.158sec\n",
      "Epoch 22 tr: l 0.394 a 0.892 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.932sec(train) 0.985sec(infer)\n",
      "Epoch 22 tst: l 0.381 a 0.899 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.170sec\n",
      "Epoch 23 tr: l 0.388 a 0.893 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.373sec(train) 1.094sec(infer)\n",
      "Epoch 23 tst: l 0.376 a 0.900 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.174sec\n",
      "Epoch 24 tr: l 0.382 a 0.894 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.600sec(train) 0.883sec(infer)\n",
      "Epoch 24 tst: l 0.371 a 0.901 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.155sec\n",
      "Epoch 25 tr: l 0.377 a 0.895 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.524sec(train) 0.983sec(infer)\n",
      "Epoch 25 tst: l 0.366 a 0.902 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.167sec\n",
      "Epoch 26 tr: l 0.372 a 0.896 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.448sec(train) 1.006sec(infer)\n",
      "Epoch 26 tst: l 0.362 a 0.903 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.167sec\n",
      "Epoch 27 tr: l 0.368 a 0.897 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.528sec(train) 1.091sec(infer)\n",
      "Epoch 27 tst: l 0.358 a 0.903 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.176sec\n",
      "Epoch 28 tr: l 0.364 a 0.898 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.874sec(train) 1.035sec(infer)\n",
      "Epoch 28 tst: l 0.354 a 0.904 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.173sec\n",
      "Epoch 29 tr: l 0.360 a 0.899 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.384sec(train) 0.980sec(infer)\n",
      "Epoch 29 tst: l 0.350 a 0.905 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.158sec\n",
      "Epoch 30 tr: l 0.356 a 0.900 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.961sec(train) 0.879sec(infer)\n",
      "Epoch 30 tst: l 0.347 a 0.905 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.150sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 31 tr: l 0.352 a 0.901 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 2.990sec(train) 0.981sec(infer)\n",
      "Epoch 31 tst: l 0.344 a 0.906 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.175sec\n",
      "Epoch 32 tr: l 0.349 a 0.901 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 2.875sec(train) 0.868sec(infer)\n",
      "Epoch 32 tst: l 0.341 a 0.906 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.151sec\n",
      "Epoch 33 tr: l 0.346 a 0.902 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.165sec(train) 0.884sec(infer)\n",
      "Epoch 33 tst: l 0.338 a 0.907 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.153sec\n",
      "Epoch 34 tr: l 0.343 a 0.903 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.203sec(train) 0.937sec(infer)\n",
      "Epoch 34 tst: l 0.335 a 0.907 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.108sec\n",
      "Epoch 35 tr: l 0.340 a 0.903 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.128sec(train) 0.860sec(infer)\n",
      "Epoch 35 tst: l 0.333 a 0.908 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.148sec\n",
      "Epoch 36 tr: l 0.337 a 0.904 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.211sec(train) 0.943sec(infer)\n",
      "Epoch 36 tst: l 0.330 a 0.909 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.152sec\n",
      "Epoch 37 tr: l 0.334 a 0.905 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 2.986sec(train) 0.898sec(infer)\n",
      "Epoch 37 tst: l 0.328 a 0.910 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.150sec\n",
      "Epoch 38 tr: l 0.332 a 0.905 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.101sec(train) 0.947sec(infer)\n",
      "Epoch 38 tst: l 0.326 a 0.911 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.154sec\n",
      "Epoch 39 tr: l 0.329 a 0.906 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.388sec(train) 0.976sec(infer)\n",
      "Epoch 39 tst: l 0.324 a 0.912 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.161sec\n",
      "Epoch 40 tr: l 0.327 a 0.906 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.655sec(train) 1.092sec(infer)\n",
      "Epoch 40 tst: l 0.322 a 0.912 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.186sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 41 tr: l 0.324 a 0.907 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.523sec(train) 1.006sec(infer)\n",
      "Epoch 41 tst: l 0.320 a 0.913 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.179sec\n",
      "Epoch 42 tr: l 0.322 a 0.908 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.525sec(train) 0.963sec(infer)\n",
      "Epoch 42 tst: l 0.318 a 0.914 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.173sec\n",
      "Epoch 43 tr: l 0.320 a 0.908 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.479sec(train) 0.970sec(infer)\n",
      "Epoch 43 tst: l 0.316 a 0.914 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.152sec\n",
      "Epoch 44 tr: l 0.318 a 0.909 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.429sec(train) 1.000sec(infer)\n",
      "Epoch 44 tst: l 0.314 a 0.914 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.172sec\n",
      "Epoch 45 tr: l 0.316 a 0.909 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.358sec(train) 0.899sec(infer)\n",
      "Epoch 45 tst: l 0.312 a 0.915 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.146sec\n",
      "Epoch 46 tr: l 0.314 a 0.910 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.526sec(train) 0.948sec(infer)\n",
      "Epoch 46 tst: l 0.311 a 0.915 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.153sec\n",
      "Epoch 47 tr: l 0.312 a 0.910 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.423sec(train) 1.006sec(infer)\n",
      "Epoch 47 tst: l 0.309 a 0.916 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.152sec\n",
      "Epoch 48 tr: l 0.310 a 0.911 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.265sec(train) 0.972sec(infer)\n",
      "Epoch 48 tst: l 0.307 a 0.916 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.160sec\n",
      "Epoch 49 tr: l 0.308 a 0.911 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.834sec(train) 0.956sec(infer)\n",
      "Epoch 49 tst: l 0.306 a 0.916 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.181sec\n",
      "Epoch 50 tr: l 0.306 a 0.912 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.606sec(train) 0.964sec(infer)\n",
      "Epoch 50 tst: l 0.304 a 0.917 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.159sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 51 tr: l 0.304 a 0.912 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.480sec(train) 0.916sec(infer)\n",
      "Epoch 51 tst: l 0.303 a 0.917 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.154sec\n",
      "Epoch 52 tr: l 0.303 a 0.913 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.224sec(train) 1.048sec(infer)\n",
      "Epoch 52 tst: l 0.301 a 0.917 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.172sec\n",
      "Epoch 53 tr: l 0.301 a 0.913 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.391sec(train) 0.878sec(infer)\n",
      "Epoch 53 tst: l 0.300 a 0.918 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.156sec\n",
      "Epoch 54 tr: l 0.299 a 0.914 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.669sec(train) 0.919sec(infer)\n",
      "Epoch 54 tst: l 0.299 a 0.918 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.152sec\n",
      "Epoch 55 tr: l 0.298 a 0.914 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.456sec(train) 1.011sec(infer)\n",
      "Epoch 55 tst: l 0.297 a 0.919 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.185sec\n",
      "Epoch 56 tr: l 0.296 a 0.915 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.614sec(train) 1.083sec(infer)\n",
      "Epoch 56 tst: l 0.296 a 0.919 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.185sec\n",
      "Epoch 57 tr: l 0.294 a 0.915 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.738sec(train) 1.061sec(infer)\n",
      "Epoch 57 tst: l 0.295 a 0.920 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.177sec\n",
      "Epoch 58 tr: l 0.293 a 0.915 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.759sec(train) 0.960sec(infer)\n",
      "Epoch 58 tst: l 0.293 a 0.920 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.182sec\n",
      "Epoch 59 tr: l 0.291 a 0.916 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.067sec(train) 0.891sec(infer)\n",
      "Epoch 59 tst: l 0.292 a 0.920 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.159sec\n",
      "Epoch 60 tr: l 0.290 a 0.916 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.689sec(train) 1.018sec(infer)\n",
      "Epoch 60 tst: l 0.291 a 0.921 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.155sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 61 tr: l 0.288 a 0.917 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.553sec(train) 0.987sec(infer)\n",
      "Epoch 61 tst: l 0.290 a 0.921 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.163sec\n",
      "Epoch 62 tr: l 0.287 a 0.917 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.474sec(train) 1.006sec(infer)\n",
      "Epoch 62 tst: l 0.288 a 0.921 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.150sec\n",
      "Epoch 63 tr: l 0.286 a 0.917 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.616sec(train) 0.901sec(infer)\n",
      "Epoch 63 tst: l 0.287 a 0.921 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.145sec\n",
      "Epoch 64 tr: l 0.284 a 0.918 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.718sec(train) 0.924sec(infer)\n",
      "Epoch 64 tst: l 0.286 a 0.921 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.159sec\n",
      "Epoch 65 tr: l 0.283 a 0.918 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.979sec(train) 0.992sec(infer)\n",
      "Epoch 65 tst: l 0.285 a 0.921 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.163sec\n",
      "Epoch 66 tr: l 0.281 a 0.919 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.601sec(train) 0.956sec(infer)\n",
      "Epoch 66 tst: l 0.284 a 0.922 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.154sec\n",
      "Epoch 67 tr: l 0.280 a 0.919 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.781sec(train) 0.942sec(infer)\n",
      "Epoch 67 tst: l 0.283 a 0.922 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.160sec\n",
      "Epoch 68 tr: l 0.279 a 0.919 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.471sec(train) 0.985sec(infer)\n",
      "Epoch 68 tst: l 0.281 a 0.922 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.170sec\n",
      "Epoch 69 tr: l 0.277 a 0.920 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.571sec(train) 1.032sec(infer)\n",
      "Epoch 69 tst: l 0.280 a 0.922 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.174sec\n",
      "Epoch 70 tr: l 0.276 a 0.920 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.734sec(train) 1.097sec(infer)\n",
      "Epoch 70 tst: l 0.279 a 0.922 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.175sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 71 tr: l 0.275 a 0.920 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.728sec(train) 0.948sec(infer)\n",
      "Epoch 71 tst: l 0.278 a 0.923 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.178sec\n",
      "Epoch 72 tr: l 0.274 a 0.921 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.840sec(train) 0.949sec(infer)\n",
      "Epoch 72 tst: l 0.277 a 0.923 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.162sec\n",
      "Epoch 73 tr: l 0.272 a 0.921 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.627sec(train) 0.870sec(infer)\n",
      "Epoch 73 tst: l 0.276 a 0.923 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.149sec\n",
      "Epoch 74 tr: l 0.271 a 0.921 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.580sec(train) 0.974sec(infer)\n",
      "Epoch 74 tst: l 0.275 a 0.924 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.168sec\n",
      "Epoch 75 tr: l 0.270 a 0.922 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.100sec(train) 0.972sec(infer)\n",
      "Epoch 75 tst: l 0.274 a 0.924 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.163sec\n",
      "Epoch 76 tr: l 0.269 a 0.922 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.733sec(train) 0.927sec(infer)\n",
      "Epoch 76 tst: l 0.273 a 0.924 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.164sec\n",
      "Epoch 77 tr: l 0.267 a 0.922 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.566sec(train) 0.947sec(infer)\n",
      "Epoch 77 tst: l 0.272 a 0.925 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.162sec\n",
      "Epoch 78 tr: l 0.266 a 0.923 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.651sec(train) 0.999sec(infer)\n",
      "Epoch 78 tst: l 0.271 a 0.925 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.162sec\n",
      "Epoch 79 tr: l 0.265 a 0.923 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.324sec(train) 0.948sec(infer)\n",
      "Epoch 79 tst: l 0.270 a 0.925 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.162sec\n",
      "Epoch 80 tr: l 0.264 a 0.923 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.275sec(train) 0.847sec(infer)\n",
      "Epoch 80 tst: l 0.269 a 0.926 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.133sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 81 tr: l 0.263 a 0.924 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.637sec(train) 1.341sec(infer)\n",
      "Epoch 81 tst: l 0.268 a 0.926 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.173sec\n",
      "Epoch 82 tr: l 0.262 a 0.924 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.807sec(train) 1.004sec(infer)\n",
      "Epoch 82 tst: l 0.267 a 0.926 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.167sec\n",
      "Epoch 83 tr: l 0.261 a 0.924 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.488sec(train) 0.962sec(infer)\n",
      "Epoch 83 tst: l 0.266 a 0.926 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.144sec\n",
      "Epoch 84 tr: l 0.259 a 0.925 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.857sec(train) 1.012sec(infer)\n",
      "Epoch 84 tst: l 0.265 a 0.927 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.169sec\n",
      "Epoch 85 tr: l 0.258 a 0.925 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.836sec(train) 1.033sec(infer)\n",
      "Epoch 85 tst: l 0.264 a 0.927 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.197sec\n",
      "Epoch 86 tr: l 0.257 a 0.925 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.867sec(train) 0.971sec(infer)\n",
      "Epoch 86 tst: l 0.263 a 0.927 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.169sec\n",
      "Epoch 87 tr: l 0.256 a 0.925 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.545sec(train) 1.020sec(infer)\n",
      "Epoch 87 tst: l 0.262 a 0.927 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.155sec\n",
      "Epoch 88 tr: l 0.255 a 0.926 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.712sec(train) 0.971sec(infer)\n",
      "Epoch 88 tst: l 0.261 a 0.928 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.164sec\n",
      "Epoch 89 tr: l 0.254 a 0.926 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.419sec(train) 0.941sec(infer)\n",
      "Epoch 89 tst: l 0.261 a 0.928 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.160sec\n",
      "Epoch 90 tr: l 0.253 a 0.926 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.989sec(train) 0.939sec(infer)\n",
      "Epoch 90 tst: l 0.260 a 0.928 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.152sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 91 tr: l 0.252 a 0.926 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.484sec(train) 1.024sec(infer)\n",
      "Epoch 91 tst: l 0.259 a 0.928 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.160sec\n",
      "Epoch 92 tr: l 0.251 a 0.927 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.694sec(train) 1.015sec(infer)\n",
      "Epoch 92 tst: l 0.258 a 0.929 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.154sec\n",
      "Epoch 93 tr: l 0.250 a 0.927 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.878sec(train) 1.233sec(infer)\n",
      "Epoch 93 tst: l 0.257 a 0.929 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.210sec\n",
      "Epoch 94 tr: l 0.249 a 0.927 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.310sec(train) 0.981sec(infer)\n",
      "Epoch 94 tst: l 0.256 a 0.929 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.167sec\n",
      "Epoch 95 tr: l 0.248 a 0.928 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.495sec(train) 0.977sec(infer)\n",
      "Epoch 95 tst: l 0.255 a 0.929 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.158sec\n",
      "Epoch 96 tr: l 0.247 a 0.928 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.837sec(train) 0.988sec(infer)\n",
      "Epoch 96 tst: l 0.254 a 0.929 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.188sec\n",
      "Epoch 97 tr: l 0.246 a 0.928 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.829sec(train) 0.943sec(infer)\n",
      "Epoch 97 tst: l 0.254 a 0.929 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.174sec\n",
      "Epoch 98 tr: l 0.245 a 0.928 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.290sec(train) 0.893sec(infer)\n",
      "Epoch 98 tst: l 0.253 a 0.930 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.148sec\n",
      "Epoch 99 tr: l 0.244 a 0.929 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.436sec(train) 1.002sec(infer)\n",
      "Epoch 99 tst: l 0.252 a 0.930 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.171sec\n",
      "Epoch 100 tr: l 0.243 a 0.929 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.583sec(train) 0.921sec(infer)\n",
      "Epoch 100 tst: l 0.251 a 0.930 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.154sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 101 tr: l 0.242 a 0.929 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.478sec(train) 0.985sec(infer)\n",
      "Epoch 101 tst: l 0.250 a 0.930 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.162sec\n",
      "Epoch 102 tr: l 0.241 a 0.929 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.132sec(train) 1.024sec(infer)\n",
      "Epoch 102 tst: l 0.249 a 0.931 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.174sec\n",
      "Epoch 103 tr: l 0.240 a 0.930 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.266sec(train) 1.005sec(infer)\n",
      "Epoch 103 tst: l 0.249 a 0.931 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.177sec\n",
      "Epoch 104 tr: l 0.239 a 0.930 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.251sec(train) 0.972sec(infer)\n",
      "Epoch 104 tst: l 0.248 a 0.931 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.164sec\n",
      "Epoch 105 tr: l 0.238 a 0.930 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.554sec(train) 0.997sec(infer)\n",
      "Epoch 105 tst: l 0.247 a 0.931 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.155sec\n",
      "Epoch 106 tr: l 0.237 a 0.930 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.701sec(train) 1.036sec(infer)\n",
      "Epoch 106 tst: l 0.246 a 0.932 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.218sec\n",
      "Epoch 107 tr: l 0.237 a 0.931 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.902sec(train) 0.918sec(infer)\n",
      "Epoch 107 tst: l 0.245 a 0.932 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.195sec\n",
      "Epoch 108 tr: l 0.236 a 0.931 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.630sec(train) 0.847sec(infer)\n",
      "Epoch 108 tst: l 0.245 a 0.932 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.158sec\n",
      "Epoch 109 tr: l 0.235 a 0.931 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.579sec(train) 1.051sec(infer)\n",
      "Epoch 109 tst: l 0.244 a 0.932 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.168sec\n",
      "Epoch 110 tr: l 0.234 a 0.932 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.534sec(train) 0.993sec(infer)\n",
      "Epoch 110 tst: l 0.243 a 0.932 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.169sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 111 tr: l 0.233 a 0.932 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.476sec(train) 0.836sec(infer)\n",
      "Epoch 111 tst: l 0.242 a 0.932 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.143sec\n",
      "Epoch 112 tr: l 0.232 a 0.932 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.643sec(train) 0.959sec(infer)\n",
      "Epoch 112 tst: l 0.242 a 0.932 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.154sec\n",
      "Epoch 113 tr: l 0.231 a 0.932 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.885sec(train) 1.033sec(infer)\n",
      "Epoch 113 tst: l 0.241 a 0.932 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.165sec\n",
      "Epoch 114 tr: l 0.230 a 0.933 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.316sec(train) 0.933sec(infer)\n",
      "Epoch 114 tst: l 0.240 a 0.932 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.153sec\n",
      "Epoch 115 tr: l 0.230 a 0.933 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.395sec(train) 0.901sec(infer)\n",
      "Epoch 115 tst: l 0.239 a 0.932 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.147sec\n",
      "Epoch 116 tr: l 0.229 a 0.933 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.016sec(train) 1.174sec(infer)\n",
      "Epoch 116 tst: l 0.239 a 0.933 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.156sec\n",
      "Epoch 117 tr: l 0.228 a 0.933 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.134sec(train) 1.049sec(infer)\n",
      "Epoch 117 tst: l 0.238 a 0.933 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.190sec\n",
      "Epoch 118 tr: l 0.227 a 0.934 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.882sec(train) 0.953sec(infer)\n",
      "Epoch 118 tst: l 0.237 a 0.933 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.162sec\n",
      "Epoch 119 tr: l 0.226 a 0.934 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.840sec(train) 0.966sec(infer)\n",
      "Epoch 119 tst: l 0.237 a 0.933 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.172sec\n",
      "Epoch 120 tr: l 0.225 a 0.934 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.705sec(train) 0.990sec(infer)\n",
      "Epoch 120 tst: l 0.236 a 0.933 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.158sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 121 tr: l 0.225 a 0.934 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.513sec(train) 1.101sec(infer)\n",
      "Epoch 121 tst: l 0.235 a 0.934 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.169sec\n",
      "Epoch 122 tr: l 0.224 a 0.934 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.565sec(train) 0.906sec(infer)\n",
      "Epoch 122 tst: l 0.234 a 0.934 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.154sec\n",
      "Epoch 123 tr: l 0.223 a 0.935 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.666sec(train) 0.948sec(infer)\n",
      "Epoch 123 tst: l 0.234 a 0.934 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.161sec\n",
      "Epoch 124 tr: l 0.222 a 0.935 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.404sec(train) 0.876sec(infer)\n",
      "Epoch 124 tst: l 0.233 a 0.934 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.137sec\n",
      "Epoch 125 tr: l 0.221 a 0.935 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.281sec(train) 1.062sec(infer)\n",
      "Epoch 125 tst: l 0.232 a 0.934 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.181sec\n",
      "Epoch 126 tr: l 0.221 a 0.935 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.284sec(train) 1.017sec(infer)\n",
      "Epoch 126 tst: l 0.232 a 0.934 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.183sec\n",
      "Epoch 127 tr: l 0.220 a 0.936 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.641sec(train) 0.952sec(infer)\n",
      "Epoch 127 tst: l 0.231 a 0.935 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.167sec\n",
      "Epoch 128 tr: l 0.219 a 0.936 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.693sec(train) 0.938sec(infer)\n",
      "Epoch 128 tst: l 0.230 a 0.935 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.165sec\n",
      "Epoch 129 tr: l 0.218 a 0.936 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.404sec(train) 1.032sec(infer)\n",
      "Epoch 129 tst: l 0.230 a 0.935 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.157sec\n",
      "Epoch 130 tr: l 0.218 a 0.936 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.690sec(train) 1.051sec(infer)\n",
      "Epoch 130 tst: l 0.229 a 0.935 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.185sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 131 tr: l 0.217 a 0.936 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.603sec(train) 1.081sec(infer)\n",
      "Epoch 131 tst: l 0.228 a 0.935 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.216sec\n",
      "Epoch 132 tr: l 0.216 a 0.937 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.365sec(train) 1.028sec(infer)\n",
      "Epoch 132 tst: l 0.228 a 0.935 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.182sec\n",
      "Epoch 133 tr: l 0.215 a 0.937 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.568sec(train) 0.924sec(infer)\n",
      "Epoch 133 tst: l 0.227 a 0.935 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.168sec\n",
      "Epoch 134 tr: l 0.215 a 0.937 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.936sec(train) 0.926sec(infer)\n",
      "Epoch 134 tst: l 0.226 a 0.936 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.165sec\n",
      "Epoch 135 tr: l 0.214 a 0.937 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.045sec(train) 0.971sec(infer)\n",
      "Epoch 135 tst: l 0.226 a 0.936 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.164sec\n",
      "Epoch 136 tr: l 0.213 a 0.937 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.162sec(train) 1.109sec(infer)\n",
      "Epoch 136 tst: l 0.225 a 0.936 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.172sec\n",
      "Epoch 137 tr: l 0.212 a 0.938 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.514sec(train) 0.979sec(infer)\n",
      "Epoch 137 tst: l 0.224 a 0.936 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.182sec\n",
      "Epoch 138 tr: l 0.212 a 0.938 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.223sec(train) 0.977sec(infer)\n",
      "Epoch 138 tst: l 0.224 a 0.936 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.167sec\n",
      "Epoch 139 tr: l 0.211 a 0.938 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.365sec(train) 1.003sec(infer)\n",
      "Epoch 139 tst: l 0.223 a 0.936 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.168sec\n",
      "Epoch 140 tr: l 0.210 a 0.938 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.460sec(train) 1.036sec(infer)\n",
      "Epoch 140 tst: l 0.223 a 0.937 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.171sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 141 tr: l 0.210 a 0.938 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.491sec(train) 1.015sec(infer)\n",
      "Epoch 141 tst: l 0.222 a 0.937 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.183sec\n",
      "Epoch 142 tr: l 0.209 a 0.939 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.578sec(train) 0.974sec(infer)\n",
      "Epoch 142 tst: l 0.221 a 0.937 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.153sec\n",
      "Epoch 143 tr: l 0.208 a 0.939 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.216sec(train) 0.910sec(infer)\n",
      "Epoch 143 tst: l 0.221 a 0.937 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.149sec\n",
      "Epoch 144 tr: l 0.208 a 0.939 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.330sec(train) 0.998sec(infer)\n",
      "Epoch 144 tst: l 0.220 a 0.937 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.181sec\n",
      "Epoch 145 tr: l 0.207 a 0.939 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.227sec(train) 1.044sec(infer)\n",
      "Epoch 145 tst: l 0.220 a 0.937 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.175sec\n",
      "Epoch 146 tr: l 0.206 a 0.939 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.803sec(train) 0.951sec(infer)\n",
      "Epoch 146 tst: l 0.219 a 0.937 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.159sec\n",
      "Epoch 147 tr: l 0.206 a 0.940 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.094sec(train) 1.044sec(infer)\n",
      "Epoch 147 tst: l 0.218 a 0.937 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.154sec\n",
      "Epoch 148 tr: l 0.205 a 0.940 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.616sec(train) 0.944sec(infer)\n",
      "Epoch 148 tst: l 0.218 a 0.938 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.173sec\n",
      "Epoch 149 tr: l 0.204 a 0.940 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.283sec(train) 1.030sec(infer)\n",
      "Epoch 149 tst: l 0.217 a 0.938 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.213sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "---train cluster Ended in 0.20 hour (718.760 sec) \n"
     ]
    }
   ],
   "source": [
    "__.display_outputs()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "IFCA Experiment Outputs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-20T07:17:14.239351Z",
     "iopub.status.busy": "2025-09-20T07:17:14.238897Z",
     "iopub.status.idle": "2025-09-20T07:17:14.248561Z",
     "shell.execute_reply": "2025-09-20T07:17:14.247170Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "---------------------------------DFCA-LI, lr: 0.1, seed: 6003---------------------------------\n",
      "config: {'m': 240, 'm_test': 40, 'p': 2, 'n': 500, 'uneven': True, 'local_model_init': True, 'Gp': 0.1, 'graph': 'er', 'agg': 'seq', 'h1': 200, 'num_epochs': 150, 'batch_size': 100, 'tau': 10, 'lr': 0.1, 'data_seed': 6003, 'train_seed': 6003, 'config_override': '', 'project_dir': 'output_dfca_gi'}\n",
      "Using device: cuda:1\n",
      "Epoch -1 tr: l 2.300 a 0.111 clct[np.int64(126), np.int64(114)] cl_acc 0.558  1.269sec\n",
      "Epoch -1 tst: l 2.301 a 0.115 clct[np.int64(19), np.int64(21)] cl_acc 0.625  0.414sec\n",
      "Epoch 0 tr: l 2.275 a 0.364 clct[np.int64(123), np.int64(117)] cl_acc 0.554  lr 0.100000 5.008sec(train) 1.013sec(infer)\n",
      "Epoch 0 tst: l 2.287 a 0.266 clct[np.int64(22), np.int64(18)] cl_acc 0.600  0.422sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 1 tr: l 2.276 a 0.303 clct[np.int64(119), np.int64(121)] cl_acc 0.546  lr 0.100000 5.015sec(train) 1.105sec(infer)\n",
      "Epoch 1 tst: l 2.286 a 0.286 clct[np.int64(22), np.int64(18)] cl_acc 0.600  0.455sec\n",
      "Epoch 2 tr: l 2.269 a 0.236 clct[np.int64(117), np.int64(123)] cl_acc 0.546  lr 0.100000 4.531sec(train) 1.047sec(infer)\n",
      "Epoch 2 tst: l 2.280 a 0.238 clct[np.int64(22), np.int64(18)] cl_acc 0.550  0.426sec\n",
      "Epoch 3 tr: l 2.244 a 0.206 clct[np.int64(120), np.int64(120)] cl_acc 0.558  lr 0.100000 4.619sec(train) 1.061sec(infer)\n",
      "Epoch 3 tst: l 2.260 a 0.215 clct[np.int64(22), np.int64(18)] cl_acc 0.550  0.424sec\n",
      "Epoch 4 tr: l 2.199 a 0.218 clct[np.int64(119), np.int64(121)] cl_acc 0.562  lr 0.100000 4.581sec(train) 1.009sec(infer)\n",
      "Epoch 4 tst: l 2.220 a 0.226 clct[np.int64(18), np.int64(22)] cl_acc 0.500  0.465sec\n",
      "Epoch 5 tr: l 2.127 a 0.282 clct[np.int64(119), np.int64(121)] cl_acc 0.571  lr 0.100000 4.476sec(train) 1.058sec(infer)\n",
      "Epoch 5 tst: l 2.151 a 0.278 clct[np.int64(17), np.int64(23)] cl_acc 0.575  0.430sec\n",
      "Epoch 6 tr: l 2.017 a 0.394 clct[np.int64(118), np.int64(122)] cl_acc 0.583  lr 0.100000 4.398sec(train) 0.982sec(infer)\n",
      "Epoch 6 tst: l 2.046 a 0.382 clct[np.int64(15), np.int64(25)] cl_acc 0.625  0.403sec\n",
      "Epoch 7 tr: l 1.872 a 0.476 clct[np.int64(114), np.int64(126)] cl_acc 0.642  lr 0.100000 4.537sec(train) 1.006sec(infer)\n",
      "Epoch 7 tst: l 1.900 a 0.459 clct[np.int64(18), np.int64(22)] cl_acc 0.700  0.427sec\n",
      "Epoch 8 tr: l 1.713 a 0.530 clct[np.int64(108), np.int64(132)] cl_acc 0.817  lr 0.100000 4.553sec(train) 1.092sec(infer)\n",
      "Epoch 8 tst: l 1.735 a 0.518 clct[np.int64(16), np.int64(24)] cl_acc 0.900  0.470sec\n",
      "Epoch 9 tr: l 1.536 a 0.593 clct[np.int64(120), np.int64(120)] cl_acc 0.967  lr 0.100000 4.867sec(train) 1.018sec(infer)\n",
      "Epoch 9 tst: l 1.565 a 0.572 clct[np.int64(19), np.int64(21)] cl_acc 0.975  0.415sec\n",
      "Epoch 10 tr: l 1.366 a 0.650 clct[np.int64(120), np.int64(120)] cl_acc 0.983  lr 0.100000 5.209sec(train) 1.090sec(infer)\n",
      "Epoch 10 tst: l 1.392 a 0.633 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.443sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 11 tr: l 1.214 a 0.697 clct[np.int64(119), np.int64(121)] cl_acc 0.988  lr 0.100000 4.288sec(train) 1.001sec(infer)\n",
      "Epoch 11 tst: l 1.237 a 0.686 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.408sec\n",
      "Epoch 12 tr: l 1.084 a 0.732 clct[np.int64(120), np.int64(120)] cl_acc 0.992  lr 0.100000 5.038sec(train) 0.973sec(infer)\n",
      "Epoch 12 tst: l 1.101 a 0.721 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.450sec\n",
      "Epoch 13 tr: l 0.966 a 0.758 clct[np.int64(120), np.int64(120)] cl_acc 0.992  lr 0.100000 4.833sec(train) 1.054sec(infer)\n",
      "Epoch 13 tst: l 0.982 a 0.750 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.428sec\n",
      "Epoch 14 tr: l 0.872 a 0.777 clct[np.int64(121), np.int64(119)] cl_acc 0.996  lr 0.100000 4.521sec(train) 1.053sec(infer)\n",
      "Epoch 14 tst: l 0.882 a 0.774 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.319sec\n",
      "Epoch 15 tr: l 0.796 a 0.794 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.454sec(train) 0.961sec(infer)\n",
      "Epoch 15 tst: l 0.805 a 0.793 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.383sec\n",
      "Epoch 16 tr: l 0.733 a 0.809 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.400sec(train) 1.068sec(infer)\n",
      "Epoch 16 tst: l 0.742 a 0.808 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.426sec\n",
      "Epoch 17 tr: l 0.680 a 0.820 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.806sec(train) 1.051sec(infer)\n",
      "Epoch 17 tst: l 0.691 a 0.819 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.417sec\n",
      "Epoch 18 tr: l 0.638 a 0.829 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.261sec(train) 0.965sec(infer)\n",
      "Epoch 18 tst: l 0.649 a 0.830 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.389sec\n",
      "Epoch 19 tr: l 0.604 a 0.837 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.656sec(train) 1.011sec(infer)\n",
      "Epoch 19 tst: l 0.613 a 0.839 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.437sec\n",
      "Epoch 20 tr: l 0.575 a 0.845 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.059sec(train) 1.093sec(infer)\n",
      "Epoch 20 tst: l 0.583 a 0.846 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.439sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 21 tr: l 0.551 a 0.851 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.134sec(train) 1.061sec(infer)\n",
      "Epoch 21 tst: l 0.556 a 0.852 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.467sec\n",
      "Epoch 22 tr: l 0.527 a 0.857 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.457sec(train) 1.034sec(infer)\n",
      "Epoch 22 tst: l 0.533 a 0.858 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.427sec\n",
      "Epoch 23 tr: l 0.508 a 0.862 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.104sec(train) 1.033sec(infer)\n",
      "Epoch 23 tst: l 0.513 a 0.863 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.435sec\n",
      "Epoch 24 tr: l 0.492 a 0.866 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.089sec(train) 1.006sec(infer)\n",
      "Epoch 24 tst: l 0.496 a 0.868 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.403sec\n",
      "Epoch 25 tr: l 0.476 a 0.869 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.099sec(train) 0.904sec(infer)\n",
      "Epoch 25 tst: l 0.480 a 0.871 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.387sec\n",
      "Epoch 26 tr: l 0.463 a 0.872 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.290sec(train) 0.839sec(infer)\n",
      "Epoch 26 tst: l 0.466 a 0.875 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.468sec\n",
      "Epoch 27 tr: l 0.451 a 0.875 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.692sec(train) 0.945sec(infer)\n",
      "Epoch 27 tst: l 0.454 a 0.877 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.423sec\n",
      "Epoch 28 tr: l 0.439 a 0.877 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.517sec(train) 0.912sec(infer)\n",
      "Epoch 28 tst: l 0.444 a 0.880 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.417sec\n",
      "Epoch 29 tr: l 0.430 a 0.880 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.158sec(train) 0.883sec(infer)\n",
      "Epoch 29 tst: l 0.434 a 0.882 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.396sec\n",
      "Epoch 30 tr: l 0.420 a 0.882 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.761sec(train) 0.901sec(infer)\n",
      "Epoch 30 tst: l 0.424 a 0.884 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.365sec\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.884 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.693sec(train) 0.933sec(infer)\n",
      "Epoch 31 tst: l 0.416 a 0.886 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.340sec\n",
      "Epoch 32 tr: l 0.406 a 0.886 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.372sec(train) 0.919sec(infer)\n",
      "Epoch 32 tst: l 0.409 a 0.887 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.378sec\n",
      "Epoch 33 tr: l 0.399 a 0.887 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.216sec(train) 1.051sec(infer)\n",
      "Epoch 33 tst: l 0.402 a 0.888 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.414sec\n",
      "Epoch 34 tr: l 0.392 a 0.889 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.084sec(train) 0.986sec(infer)\n",
      "Epoch 34 tst: l 0.395 a 0.890 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.373sec\n",
      "Epoch 35 tr: l 0.386 a 0.890 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.049sec(train) 1.007sec(infer)\n",
      "Epoch 35 tst: l 0.390 a 0.892 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.407sec\n",
      "Epoch 36 tr: l 0.380 a 0.891 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.749sec(train) 1.016sec(infer)\n",
      "Epoch 36 tst: l 0.384 a 0.893 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.378sec\n",
      "Epoch 37 tr: l 0.375 a 0.893 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.597sec(train) 0.941sec(infer)\n",
      "Epoch 37 tst: l 0.379 a 0.893 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.460sec\n",
      "Epoch 38 tr: l 0.370 a 0.894 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.461sec(train) 0.975sec(infer)\n",
      "Epoch 38 tst: l 0.374 a 0.895 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.426sec\n",
      "Epoch 39 tr: l 0.366 a 0.895 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.568sec(train) 0.963sec(infer)\n",
      "Epoch 39 tst: l 0.370 a 0.896 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.462sec\n",
      "Epoch 40 tr: l 0.362 a 0.895 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.936sec(train) 0.928sec(infer)\n",
      "Epoch 40 tst: l 0.365 a 0.896 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.435sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 41 tr: l 0.358 a 0.897 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.629sec(train) 1.029sec(infer)\n",
      "Epoch 41 tst: l 0.362 a 0.898 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.434sec\n",
      "Epoch 42 tr: l 0.354 a 0.897 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.957sec(train) 1.325sec(infer)\n",
      "Epoch 42 tst: l 0.358 a 0.899 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.461sec\n",
      "Epoch 43 tr: l 0.349 a 0.898 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.809sec(train) 1.035sec(infer)\n",
      "Epoch 43 tst: l 0.355 a 0.899 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.449sec\n",
      "Epoch 44 tr: l 0.346 a 0.899 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.657sec(train) 1.073sec(infer)\n",
      "Epoch 44 tst: l 0.351 a 0.899 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.434sec\n",
      "Epoch 45 tr: l 0.343 a 0.899 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.009sec(train) 1.005sec(infer)\n",
      "Epoch 45 tst: l 0.348 a 0.901 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.365sec\n",
      "Epoch 46 tr: l 0.340 a 0.900 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.142sec(train) 1.051sec(infer)\n",
      "Epoch 46 tst: l 0.345 a 0.901 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.420sec\n",
      "Epoch 47 tr: l 0.339 a 0.901 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.865sec(train) 0.969sec(infer)\n",
      "Epoch 47 tst: l 0.342 a 0.901 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.403sec\n",
      "Epoch 48 tr: l 0.333 a 0.902 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.741sec(train) 0.976sec(infer)\n",
      "Epoch 48 tst: l 0.339 a 0.902 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.471sec\n",
      "Epoch 49 tr: l 0.330 a 0.902 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.190sec(train) 0.969sec(infer)\n",
      "Epoch 49 tst: l 0.337 a 0.902 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.415sec\n",
      "Epoch 50 tr: l 0.330 a 0.903 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.867sec(train) 0.999sec(infer)\n",
      "Epoch 50 tst: l 0.334 a 0.903 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.453sec\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.904 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.910sec(train) 0.962sec(infer)\n",
      "Epoch 51 tst: l 0.332 a 0.904 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.405sec\n",
      "Epoch 52 tr: l 0.325 a 0.904 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.051sec(train) 1.012sec(infer)\n",
      "Epoch 52 tst: l 0.330 a 0.904 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.386sec\n",
      "Epoch 53 tr: l 0.322 a 0.905 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.736sec(train) 0.930sec(infer)\n",
      "Epoch 53 tst: l 0.328 a 0.905 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.429sec\n",
      "Epoch 54 tr: l 0.320 a 0.905 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.299sec(train) 0.983sec(infer)\n",
      "Epoch 54 tst: l 0.326 a 0.905 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.438sec\n",
      "Epoch 55 tr: l 0.319 a 0.906 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.706sec(train) 1.013sec(infer)\n",
      "Epoch 55 tst: l 0.323 a 0.906 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.465sec\n",
      "Epoch 56 tr: l 0.315 a 0.906 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.067sec(train) 1.061sec(infer)\n",
      "Epoch 56 tst: l 0.322 a 0.906 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.382sec\n",
      "Epoch 57 tr: l 0.313 a 0.907 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.044sec(train) 0.991sec(infer)\n",
      "Epoch 57 tst: l 0.320 a 0.907 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.411sec\n",
      "Epoch 58 tr: l 0.311 a 0.907 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.440sec(train) 1.060sec(infer)\n",
      "Epoch 58 tst: l 0.318 a 0.908 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.425sec\n",
      "Epoch 59 tr: l 0.311 a 0.908 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.453sec(train) 1.127sec(infer)\n",
      "Epoch 59 tst: l 0.316 a 0.907 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.383sec\n",
      "Epoch 60 tr: l 0.307 a 0.909 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.668sec(train) 1.037sec(infer)\n",
      "Epoch 60 tst: l 0.315 a 0.909 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.401sec\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.909 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.267sec(train) 0.946sec(infer)\n",
      "Epoch 61 tst: l 0.313 a 0.909 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.392sec\n",
      "Epoch 62 tr: l 0.304 a 0.909 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.405sec(train) 0.963sec(infer)\n",
      "Epoch 62 tst: l 0.311 a 0.909 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.348sec\n",
      "Epoch 63 tr: l 0.303 a 0.910 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.714sec(train) 0.936sec(infer)\n",
      "Epoch 63 tst: l 0.310 a 0.909 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.423sec\n",
      "Epoch 64 tr: l 0.300 a 0.910 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.179sec(train) 1.022sec(infer)\n",
      "Epoch 64 tst: l 0.308 a 0.910 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.400sec\n",
      "Epoch 65 tr: l 0.300 a 0.911 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.264sec(train) 1.110sec(infer)\n",
      "Epoch 65 tst: l 0.307 a 0.910 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.440sec\n",
      "Epoch 66 tr: l 0.298 a 0.911 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.181sec(train) 1.044sec(infer)\n",
      "Epoch 66 tst: l 0.305 a 0.911 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.428sec\n",
      "Epoch 67 tr: l 0.295 a 0.912 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.409sec(train) 1.049sec(infer)\n",
      "Epoch 67 tst: l 0.304 a 0.911 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.415sec\n",
      "Epoch 68 tr: l 0.294 a 0.912 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.487sec(train) 1.024sec(infer)\n",
      "Epoch 68 tst: l 0.303 a 0.912 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.426sec\n",
      "Epoch 69 tr: l 0.294 a 0.912 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.532sec(train) 1.070sec(infer)\n",
      "Epoch 69 tst: l 0.301 a 0.912 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.396sec\n",
      "Epoch 70 tr: l 0.293 a 0.912 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.228sec(train) 1.106sec(infer)\n",
      "Epoch 70 tst: l 0.300 a 0.912 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.438sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 71 tr: l 0.291 a 0.913 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.512sec(train) 0.932sec(infer)\n",
      "Epoch 71 tst: l 0.299 a 0.913 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.390sec\n",
      "Epoch 72 tr: l 0.289 a 0.913 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.673sec(train) 1.491sec(infer)\n",
      "Epoch 72 tst: l 0.298 a 0.913 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.698sec\n",
      "Epoch 73 tr: l 0.289 a 0.913 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.408sec(train) 0.873sec(infer)\n",
      "Epoch 73 tst: l 0.296 a 0.914 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.350sec\n",
      "Epoch 74 tr: l 0.287 a 0.914 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.526sec(train) 1.033sec(infer)\n",
      "Epoch 74 tst: l 0.296 a 0.914 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.442sec\n",
      "Epoch 75 tr: l 0.285 a 0.914 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.343sec(train) 1.080sec(infer)\n",
      "Epoch 75 tst: l 0.294 a 0.914 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.378sec\n",
      "Epoch 76 tr: l 0.284 a 0.914 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.705sec(train) 1.040sec(infer)\n",
      "Epoch 76 tst: l 0.293 a 0.915 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.423sec\n",
      "Epoch 77 tr: l 0.283 a 0.915 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.071sec(train) 0.983sec(infer)\n",
      "Epoch 77 tst: l 0.292 a 0.915 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.437sec\n",
      "Epoch 78 tr: l 0.283 a 0.915 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.272sec(train) 1.137sec(infer)\n",
      "Epoch 78 tst: l 0.291 a 0.915 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.422sec\n",
      "Epoch 79 tr: l 0.282 a 0.915 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.814sec(train) 1.038sec(infer)\n",
      "Epoch 79 tst: l 0.290 a 0.915 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.381sec\n",
      "Epoch 80 tr: l 0.280 a 0.915 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.187sec(train) 0.971sec(infer)\n",
      "Epoch 80 tst: l 0.289 a 0.916 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.376sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 81 tr: l 0.277 a 0.916 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.899sec(train) 0.871sec(infer)\n",
      "Epoch 81 tst: l 0.288 a 0.916 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.419sec\n",
      "Epoch 82 tr: l 0.276 a 0.916 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.695sec(train) 1.129sec(infer)\n",
      "Epoch 82 tst: l 0.287 a 0.916 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.467sec\n",
      "Epoch 83 tr: l 0.276 a 0.916 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.516sec(train) 0.950sec(infer)\n",
      "Epoch 83 tst: l 0.286 a 0.916 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.392sec\n",
      "Epoch 84 tr: l 0.275 a 0.917 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.562sec(train) 1.140sec(infer)\n",
      "Epoch 84 tst: l 0.285 a 0.917 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.523sec\n",
      "Epoch 85 tr: l 0.274 a 0.917 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 6.173sec(train) 1.053sec(infer)\n",
      "Epoch 85 tst: l 0.284 a 0.917 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.374sec\n",
      "Epoch 86 tr: l 0.273 a 0.917 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.376sec(train) 0.965sec(infer)\n",
      "Epoch 86 tst: l 0.283 a 0.917 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.427sec\n",
      "Epoch 87 tr: l 0.271 a 0.918 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.229sec(train) 0.933sec(infer)\n",
      "Epoch 87 tst: l 0.282 a 0.917 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.412sec\n",
      "Epoch 88 tr: l 0.272 a 0.918 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.431sec(train) 0.997sec(infer)\n",
      "Epoch 88 tst: l 0.281 a 0.918 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.389sec\n",
      "Epoch 89 tr: l 0.270 a 0.918 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.209sec(train) 1.025sec(infer)\n",
      "Epoch 89 tst: l 0.281 a 0.918 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.414sec\n",
      "Epoch 90 tr: l 0.269 a 0.918 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.959sec(train) 1.008sec(infer)\n",
      "Epoch 90 tst: l 0.280 a 0.918 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.405sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 91 tr: l 0.267 a 0.919 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.965sec(train) 1.069sec(infer)\n",
      "Epoch 91 tst: l 0.279 a 0.919 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.389sec\n",
      "Epoch 92 tr: l 0.267 a 0.919 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.629sec(train) 1.020sec(infer)\n",
      "Epoch 92 tst: l 0.278 a 0.918 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.420sec\n",
      "Epoch 93 tr: l 0.266 a 0.920 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.979sec(train) 1.070sec(infer)\n",
      "Epoch 93 tst: l 0.277 a 0.919 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.437sec\n",
      "Epoch 94 tr: l 0.264 a 0.920 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.796sec(train) 1.007sec(infer)\n",
      "Epoch 94 tst: l 0.277 a 0.919 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.405sec\n",
      "Epoch 95 tr: l 0.263 a 0.920 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.924sec(train) 1.169sec(infer)\n",
      "Epoch 95 tst: l 0.276 a 0.919 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.448sec\n",
      "Epoch 96 tr: l 0.262 a 0.921 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.233sec(train) 1.087sec(infer)\n",
      "Epoch 96 tst: l 0.275 a 0.920 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.435sec\n",
      "Epoch 97 tr: l 0.262 a 0.921 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.453sec(train) 1.006sec(infer)\n",
      "Epoch 97 tst: l 0.274 a 0.920 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.385sec\n",
      "Epoch 98 tr: l 0.261 a 0.921 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.727sec(train) 0.964sec(infer)\n",
      "Epoch 98 tst: l 0.273 a 0.920 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.407sec\n",
      "Epoch 99 tr: l 0.261 a 0.921 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.075sec(train) 1.072sec(infer)\n",
      "Epoch 99 tst: l 0.272 a 0.920 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.438sec\n",
      "Epoch 100 tr: l 0.259 a 0.921 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.164sec(train) 0.947sec(infer)\n",
      "Epoch 100 tst: l 0.271 a 0.921 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.388sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 101 tr: l 0.258 a 0.921 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.086sec(train) 1.051sec(infer)\n",
      "Epoch 101 tst: l 0.271 a 0.921 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.348sec\n",
      "Epoch 102 tr: l 0.256 a 0.922 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.725sec(train) 1.006sec(infer)\n",
      "Epoch 102 tst: l 0.270 a 0.921 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.413sec\n",
      "Epoch 103 tr: l 0.256 a 0.922 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.727sec(train) 1.107sec(infer)\n",
      "Epoch 103 tst: l 0.270 a 0.922 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.433sec\n",
      "Epoch 104 tr: l 0.255 a 0.922 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.702sec(train) 1.095sec(infer)\n",
      "Epoch 104 tst: l 0.269 a 0.922 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.425sec\n",
      "Epoch 105 tr: l 0.255 a 0.923 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.644sec(train) 1.023sec(infer)\n",
      "Epoch 105 tst: l 0.268 a 0.922 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.420sec\n",
      "Epoch 106 tr: l 0.254 a 0.923 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.278sec(train) 0.958sec(infer)\n",
      "Epoch 106 tst: l 0.267 a 0.922 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.385sec\n",
      "Epoch 107 tr: l 0.253 a 0.923 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.141sec(train) 1.055sec(infer)\n",
      "Epoch 107 tst: l 0.266 a 0.922 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.457sec\n",
      "Epoch 108 tr: l 0.253 a 0.923 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.969sec(train) 0.957sec(infer)\n",
      "Epoch 108 tst: l 0.266 a 0.922 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.405sec\n",
      "Epoch 109 tr: l 0.251 a 0.924 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.465sec(train) 1.003sec(infer)\n",
      "Epoch 109 tst: l 0.265 a 0.922 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.386sec\n",
      "Epoch 110 tr: l 0.250 a 0.924 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.391sec(train) 1.084sec(infer)\n",
      "Epoch 110 tst: l 0.264 a 0.922 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.459sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 111 tr: l 0.249 a 0.924 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.248sec(train) 0.945sec(infer)\n",
      "Epoch 111 tst: l 0.264 a 0.923 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.427sec\n",
      "Epoch 112 tr: l 0.248 a 0.924 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.290sec(train) 1.119sec(infer)\n",
      "Epoch 112 tst: l 0.263 a 0.923 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.435sec\n",
      "Epoch 113 tr: l 0.248 a 0.925 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.411sec(train) 0.935sec(infer)\n",
      "Epoch 113 tst: l 0.262 a 0.923 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.351sec\n",
      "Epoch 114 tr: l 0.247 a 0.924 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.517sec(train) 1.012sec(infer)\n",
      "Epoch 114 tst: l 0.262 a 0.923 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.340sec\n",
      "Epoch 115 tr: l 0.245 a 0.925 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.398sec(train) 1.058sec(infer)\n",
      "Epoch 115 tst: l 0.261 a 0.924 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.429sec\n",
      "Epoch 116 tr: l 0.244 a 0.926 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.400sec(train) 0.918sec(infer)\n",
      "Epoch 116 tst: l 0.260 a 0.924 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.393sec\n",
      "Epoch 117 tr: l 0.245 a 0.926 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.343sec(train) 1.007sec(infer)\n",
      "Epoch 117 tst: l 0.259 a 0.924 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.404sec\n",
      "Epoch 118 tr: l 0.244 a 0.926 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.359sec(train) 1.059sec(infer)\n",
      "Epoch 118 tst: l 0.259 a 0.925 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.416sec\n",
      "Epoch 119 tr: l 0.242 a 0.926 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.335sec(train) 0.883sec(infer)\n",
      "Epoch 119 tst: l 0.258 a 0.925 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.338sec\n",
      "Epoch 120 tr: l 0.243 a 0.926 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.817sec(train) 0.982sec(infer)\n",
      "Epoch 120 tst: l 0.258 a 0.925 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.428sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 121 tr: l 0.243 a 0.926 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.353sec(train) 0.913sec(infer)\n",
      "Epoch 121 tst: l 0.257 a 0.925 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.400sec\n",
      "Epoch 122 tr: l 0.242 a 0.926 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.715sec(train) 1.161sec(infer)\n",
      "Epoch 122 tst: l 0.256 a 0.925 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.467sec\n",
      "Epoch 123 tr: l 0.240 a 0.927 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.249sec(train) 0.981sec(infer)\n",
      "Epoch 123 tst: l 0.256 a 0.925 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.430sec\n",
      "Epoch 124 tr: l 0.239 a 0.927 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.238sec(train) 0.874sec(infer)\n",
      "Epoch 124 tst: l 0.255 a 0.926 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.400sec\n",
      "Epoch 125 tr: l 0.238 a 0.927 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.093sec(train) 1.025sec(infer)\n",
      "Epoch 125 tst: l 0.254 a 0.926 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.362sec\n",
      "Epoch 126 tr: l 0.238 a 0.928 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.189sec(train) 0.920sec(infer)\n",
      "Epoch 126 tst: l 0.253 a 0.926 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.323sec\n",
      "Epoch 127 tr: l 0.236 a 0.928 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.867sec(train) 1.005sec(infer)\n",
      "Epoch 127 tst: l 0.253 a 0.926 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.392sec\n",
      "Epoch 128 tr: l 0.235 a 0.928 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.341sec(train) 1.130sec(infer)\n",
      "Epoch 128 tst: l 0.252 a 0.926 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.441sec\n",
      "Epoch 129 tr: l 0.236 a 0.928 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.730sec(train) 1.024sec(infer)\n",
      "Epoch 129 tst: l 0.252 a 0.927 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.460sec\n",
      "Epoch 130 tr: l 0.234 a 0.929 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.274sec(train) 0.968sec(infer)\n",
      "Epoch 130 tst: l 0.251 a 0.927 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.387sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 131 tr: l 0.235 a 0.929 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.191sec(train) 0.944sec(infer)\n",
      "Epoch 131 tst: l 0.250 a 0.927 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.390sec\n",
      "Epoch 132 tr: l 0.234 a 0.929 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.776sec(train) 0.829sec(infer)\n",
      "Epoch 132 tst: l 0.250 a 0.927 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.356sec\n",
      "Epoch 133 tr: l 0.233 a 0.929 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.790sec(train) 1.071sec(infer)\n",
      "Epoch 133 tst: l 0.249 a 0.927 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.402sec\n",
      "Epoch 134 tr: l 0.232 a 0.929 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.728sec(train) 0.953sec(infer)\n",
      "Epoch 134 tst: l 0.249 a 0.927 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.421sec\n",
      "Epoch 135 tr: l 0.230 a 0.930 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.527sec(train) 1.066sec(infer)\n",
      "Epoch 135 tst: l 0.248 a 0.927 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.449sec\n",
      "Epoch 136 tr: l 0.232 a 0.930 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.414sec(train) 1.063sec(infer)\n",
      "Epoch 136 tst: l 0.247 a 0.927 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.447sec\n",
      "Epoch 137 tr: l 0.230 a 0.930 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.417sec(train) 1.066sec(infer)\n",
      "Epoch 137 tst: l 0.247 a 0.928 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.412sec\n",
      "Epoch 138 tr: l 0.229 a 0.930 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.961sec(train) 0.825sec(infer)\n",
      "Epoch 138 tst: l 0.246 a 0.928 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.403sec\n",
      "Epoch 139 tr: l 0.228 a 0.930 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.445sec(train) 0.857sec(infer)\n",
      "Epoch 139 tst: l 0.246 a 0.928 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.354sec\n",
      "Epoch 140 tr: l 0.227 a 0.931 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.858sec(train) 0.895sec(infer)\n",
      "Epoch 140 tst: l 0.245 a 0.929 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.364sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 141 tr: l 0.227 a 0.931 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.027sec(train) 0.963sec(infer)\n",
      "Epoch 141 tst: l 0.244 a 0.929 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.380sec\n",
      "Epoch 142 tr: l 0.226 a 0.931 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.137sec(train) 0.979sec(infer)\n",
      "Epoch 142 tst: l 0.243 a 0.929 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.392sec\n",
      "Epoch 143 tr: l 0.226 a 0.931 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.491sec(train) 0.916sec(infer)\n",
      "Epoch 143 tst: l 0.243 a 0.929 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.388sec\n",
      "Epoch 144 tr: l 0.224 a 0.932 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.634sec(train) 0.838sec(infer)\n",
      "Epoch 144 tst: l 0.243 a 0.929 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.407sec\n",
      "Epoch 145 tr: l 0.224 a 0.932 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.496sec(train) 1.016sec(infer)\n",
      "Epoch 145 tst: l 0.242 a 0.929 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.388sec\n",
      "Epoch 146 tr: l 0.223 a 0.932 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.609sec(train) 0.980sec(infer)\n",
      "Epoch 146 tst: l 0.241 a 0.929 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.472sec\n",
      "Epoch 147 tr: l 0.222 a 0.932 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.505sec(train) 0.857sec(infer)\n",
      "Epoch 147 tst: l 0.241 a 0.930 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.279sec\n",
      "Epoch 148 tr: l 0.222 a 0.933 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.469sec(train) 0.833sec(infer)\n",
      "Epoch 148 tst: l 0.240 a 0.930 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.389sec\n",
      "Epoch 149 tr: l 0.221 a 0.933 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.679sec(train) 0.883sec(infer)\n",
      "Epoch 149 tst: l 0.240 a 0.930 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.340sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "---train cluster Ended in 0.28 hour (1006.107 sec) \n",
      "---------------------------------DFCA-LI, lr: 0.1, seed: 7293---------------------------------\n",
      "config: {'m': 240, 'm_test': 40, 'p': 2, 'n': 500, 'uneven': True, 'local_model_init': True, 'Gp': 0.1, 'graph': 'er', 'agg': 'seq', 'h1': 200, 'num_epochs': 150, 'batch_size': 100, 'tau': 10, 'lr': 0.1, 'data_seed': 7293, 'train_seed': 7293, 'config_override': '', 'project_dir': 'output_dfca_gi'}\n",
      "Using device: cuda:1\n",
      "Epoch -1 tr: l 2.300 a 0.107 clct[np.int64(108), np.int64(132)] cl_acc 0.508  1.069sec\n",
      "Epoch -1 tst: l 2.300 a 0.116 clct[np.int64(15), np.int64(25)] cl_acc 0.525  0.406sec\n",
      "Epoch 0 tr: l 2.271 a 0.346 clct[np.int64(110), np.int64(130)] cl_acc 0.508  lr 0.100000 4.917sec(train) 0.990sec(infer)\n",
      "Epoch 0 tst: l 2.283 a 0.281 clct[np.int64(22), np.int64(18)] cl_acc 0.500  0.394sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 1 tr: l 2.278 a 0.291 clct[np.int64(127), np.int64(113)] cl_acc 0.546  lr 0.100000 4.844sec(train) 0.984sec(infer)\n",
      "Epoch 1 tst: l 2.282 a 0.288 clct[np.int64(25), np.int64(15)] cl_acc 0.525  0.418sec\n",
      "Epoch 2 tr: l 2.271 a 0.237 clct[np.int64(131), np.int64(109)] cl_acc 0.562  lr 0.100000 4.842sec(train) 1.094sec(infer)\n",
      "Epoch 2 tst: l 2.278 a 0.257 clct[np.int64(25), np.int64(15)] cl_acc 0.525  0.437sec\n",
      "Epoch 3 tr: l 2.250 a 0.218 clct[np.int64(132), np.int64(108)] cl_acc 0.567  lr 0.100000 5.429sec(train) 0.994sec(infer)\n",
      "Epoch 3 tst: l 2.259 a 0.225 clct[np.int64(27), np.int64(13)] cl_acc 0.525  0.413sec\n",
      "Epoch 4 tr: l 2.204 a 0.237 clct[np.int64(138), np.int64(102)] cl_acc 0.592  lr 0.100000 4.472sec(train) 1.021sec(infer)\n",
      "Epoch 4 tst: l 2.218 a 0.236 clct[np.int64(26), np.int64(14)] cl_acc 0.500  0.428sec\n",
      "Epoch 5 tr: l 2.128 a 0.305 clct[np.int64(145), np.int64(95)] cl_acc 0.621  lr 0.100000 4.209sec(train) 0.910sec(infer)\n",
      "Epoch 5 tst: l 2.148 a 0.295 clct[np.int64(29), np.int64(11)] cl_acc 0.525  0.427sec\n",
      "Epoch 6 tr: l 2.013 a 0.408 clct[np.int64(149), np.int64(91)] cl_acc 0.637  lr 0.100000 4.899sec(train) 0.944sec(infer)\n",
      "Epoch 6 tst: l 2.037 a 0.395 clct[np.int64(27), np.int64(13)] cl_acc 0.625  0.412sec\n",
      "Epoch 7 tr: l 1.859 a 0.479 clct[np.int64(155), np.int64(85)] cl_acc 0.662  lr 0.100000 4.646sec(train) 0.952sec(infer)\n",
      "Epoch 7 tst: l 1.889 a 0.470 clct[np.int64(32), np.int64(8)] cl_acc 0.600  0.354sec\n",
      "Epoch 8 tr: l 1.694 a 0.524 clct[np.int64(157), np.int64(83)] cl_acc 0.713  lr 0.100000 5.605sec(train) 1.008sec(infer)\n",
      "Epoch 8 tst: l 1.725 a 0.518 clct[np.int64(26), np.int64(14)] cl_acc 0.800  0.434sec\n",
      "Epoch 9 tr: l 1.547 a 0.567 clct[np.int64(146), np.int64(94)] cl_acc 0.825  lr 0.100000 5.358sec(train) 0.968sec(infer)\n",
      "Epoch 9 tst: l 1.571 a 0.560 clct[np.int64(23), np.int64(17)] cl_acc 0.925  0.413sec\n",
      "Epoch 10 tr: l 1.396 a 0.617 clct[np.int64(123), np.int64(117)] cl_acc 0.979  lr 0.100000 5.954sec(train) 1.220sec(infer)\n",
      "Epoch 10 tst: l 1.420 a 0.605 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.421sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 11 tr: l 1.240 a 0.667 clct[np.int64(121), np.int64(119)] cl_acc 0.996  lr 0.100000 5.568sec(train) 1.005sec(infer)\n",
      "Epoch 11 tst: l 1.264 a 0.658 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.380sec\n",
      "Epoch 12 tr: l 1.112 a 0.709 clct[np.int64(121), np.int64(119)] cl_acc 0.996  lr 0.100000 4.585sec(train) 0.970sec(infer)\n",
      "Epoch 12 tst: l 1.131 a 0.701 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.397sec\n",
      "Epoch 13 tr: l 0.999 a 0.740 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.996sec(train) 1.000sec(infer)\n",
      "Epoch 13 tst: l 1.016 a 0.732 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.372sec\n",
      "Epoch 14 tr: l 0.903 a 0.766 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.966sec(train) 1.006sec(infer)\n",
      "Epoch 14 tst: l 0.913 a 0.763 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.391sec\n",
      "Epoch 15 tr: l 0.822 a 0.785 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.377sec(train) 0.874sec(infer)\n",
      "Epoch 15 tst: l 0.830 a 0.783 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.263sec\n",
      "Epoch 16 tr: l 0.755 a 0.801 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.324sec(train) 0.966sec(infer)\n",
      "Epoch 16 tst: l 0.763 a 0.800 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.370sec\n",
      "Epoch 17 tr: l 0.703 a 0.812 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.382sec(train) 0.940sec(infer)\n",
      "Epoch 17 tst: l 0.706 a 0.814 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.375sec\n",
      "Epoch 18 tr: l 0.660 a 0.822 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.260sec(train) 0.967sec(infer)\n",
      "Epoch 18 tst: l 0.662 a 0.824 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.401sec\n",
      "Epoch 19 tr: l 0.622 a 0.832 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.966sec(train) 1.034sec(infer)\n",
      "Epoch 19 tst: l 0.624 a 0.833 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.399sec\n",
      "Epoch 20 tr: l 0.592 a 0.840 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.995sec(train) 0.897sec(infer)\n",
      "Epoch 20 tst: l 0.592 a 0.841 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.413sec\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.847 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.731sec(train) 0.958sec(infer)\n",
      "Epoch 21 tst: l 0.565 a 0.845 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.452sec\n",
      "Epoch 22 tr: l 0.543 a 0.853 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.818sec(train) 0.919sec(infer)\n",
      "Epoch 22 tst: l 0.542 a 0.853 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.358sec\n",
      "Epoch 23 tr: l 0.521 a 0.858 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.400sec(train) 0.800sec(infer)\n",
      "Epoch 23 tst: l 0.521 a 0.857 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.387sec\n",
      "Epoch 24 tr: l 0.504 a 0.863 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.810sec(train) 0.980sec(infer)\n",
      "Epoch 24 tst: l 0.502 a 0.863 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.368sec\n",
      "Epoch 25 tr: l 0.488 a 0.867 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.117sec(train) 1.018sec(infer)\n",
      "Epoch 25 tst: l 0.486 a 0.868 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.411sec\n",
      "Epoch 26 tr: l 0.472 a 0.870 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.643sec(train) 1.023sec(infer)\n",
      "Epoch 26 tst: l 0.473 a 0.870 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.442sec\n",
      "Epoch 27 tr: l 0.460 a 0.873 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.897sec(train) 1.075sec(infer)\n",
      "Epoch 27 tst: l 0.460 a 0.874 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.464sec\n",
      "Epoch 28 tr: l 0.451 a 0.876 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.835sec(train) 1.061sec(infer)\n",
      "Epoch 28 tst: l 0.448 a 0.878 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.499sec\n",
      "Epoch 29 tr: l 0.438 a 0.877 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.044sec(train) 0.988sec(infer)\n",
      "Epoch 29 tst: l 0.439 a 0.880 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.406sec\n",
      "Epoch 30 tr: l 0.428 a 0.880 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.495sec(train) 1.039sec(infer)\n",
      "Epoch 30 tst: l 0.428 a 0.883 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.406sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 31 tr: l 0.422 a 0.883 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.835sec(train) 0.961sec(infer)\n",
      "Epoch 31 tst: l 0.420 a 0.885 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.389sec\n",
      "Epoch 32 tr: l 0.414 a 0.885 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.597sec(train) 0.916sec(infer)\n",
      "Epoch 32 tst: l 0.412 a 0.887 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.399sec\n",
      "Epoch 33 tr: l 0.405 a 0.886 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.459sec(train) 0.940sec(infer)\n",
      "Epoch 33 tst: l 0.405 a 0.888 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.473sec\n",
      "Epoch 34 tr: l 0.399 a 0.888 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.858sec(train) 0.838sec(infer)\n",
      "Epoch 34 tst: l 0.399 a 0.889 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.394sec\n",
      "Epoch 35 tr: l 0.391 a 0.890 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.037sec(train) 0.897sec(infer)\n",
      "Epoch 35 tst: l 0.393 a 0.891 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.342sec\n",
      "Epoch 36 tr: l 0.387 a 0.890 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.549sec(train) 0.950sec(infer)\n",
      "Epoch 36 tst: l 0.387 a 0.892 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.406sec\n",
      "Epoch 37 tr: l 0.381 a 0.892 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.090sec(train) 0.946sec(infer)\n",
      "Epoch 37 tst: l 0.383 a 0.893 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.403sec\n",
      "Epoch 38 tr: l 0.376 a 0.893 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.567sec(train) 0.953sec(infer)\n",
      "Epoch 38 tst: l 0.378 a 0.894 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.410sec\n",
      "Epoch 39 tr: l 0.372 a 0.894 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.730sec(train) 0.896sec(infer)\n",
      "Epoch 39 tst: l 0.373 a 0.895 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.411sec\n",
      "Epoch 40 tr: l 0.368 a 0.895 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.987sec(train) 0.950sec(infer)\n",
      "Epoch 40 tst: l 0.370 a 0.896 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.418sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 41 tr: l 0.362 a 0.896 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.713sec(train) 0.893sec(infer)\n",
      "Epoch 41 tst: l 0.366 a 0.897 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.379sec\n",
      "Epoch 42 tr: l 0.359 a 0.897 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.466sec(train) 0.921sec(infer)\n",
      "Epoch 42 tst: l 0.362 a 0.898 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.421sec\n",
      "Epoch 43 tr: l 0.356 a 0.898 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.075sec(train) 1.015sec(infer)\n",
      "Epoch 43 tst: l 0.358 a 0.899 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.522sec\n",
      "Epoch 44 tr: l 0.351 a 0.899 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.218sec(train) 0.897sec(infer)\n",
      "Epoch 44 tst: l 0.355 a 0.899 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.380sec\n",
      "Epoch 45 tr: l 0.349 a 0.899 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.032sec(train) 1.244sec(infer)\n",
      "Epoch 45 tst: l 0.352 a 0.900 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.402sec\n",
      "Epoch 46 tr: l 0.345 a 0.900 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.931sec(train) 0.879sec(infer)\n",
      "Epoch 46 tst: l 0.349 a 0.901 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.370sec\n",
      "Epoch 47 tr: l 0.342 a 0.901 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.846sec(train) 0.915sec(infer)\n",
      "Epoch 47 tst: l 0.347 a 0.901 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.370sec\n",
      "Epoch 48 tr: l 0.340 a 0.901 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.782sec(train) 0.951sec(infer)\n",
      "Epoch 48 tst: l 0.344 a 0.902 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.396sec\n",
      "Epoch 49 tr: l 0.336 a 0.902 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.815sec(train) 0.970sec(infer)\n",
      "Epoch 49 tst: l 0.342 a 0.902 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.456sec\n",
      "Epoch 50 tr: l 0.334 a 0.903 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.856sec(train) 0.882sec(infer)\n",
      "Epoch 50 tst: l 0.339 a 0.903 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.379sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 51 tr: l 0.331 a 0.903 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.882sec(train) 0.954sec(infer)\n",
      "Epoch 51 tst: l 0.337 a 0.903 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.440sec\n",
      "Epoch 52 tr: l 0.330 a 0.904 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.167sec(train) 1.057sec(infer)\n",
      "Epoch 52 tst: l 0.335 a 0.904 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.448sec\n",
      "Epoch 53 tr: l 0.326 a 0.904 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.290sec(train) 0.973sec(infer)\n",
      "Epoch 53 tst: l 0.333 a 0.904 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.368sec\n",
      "Epoch 54 tr: l 0.326 a 0.905 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.303sec(train) 1.179sec(infer)\n",
      "Epoch 54 tst: l 0.331 a 0.904 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.495sec\n",
      "Epoch 55 tr: l 0.323 a 0.905 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.031sec(train) 0.934sec(infer)\n",
      "Epoch 55 tst: l 0.329 a 0.905 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.412sec\n",
      "Epoch 56 tr: l 0.321 a 0.906 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.234sec(train) 0.970sec(infer)\n",
      "Epoch 56 tst: l 0.327 a 0.905 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.428sec\n",
      "Epoch 57 tr: l 0.318 a 0.906 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.422sec(train) 0.988sec(infer)\n",
      "Epoch 57 tst: l 0.325 a 0.906 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.412sec\n",
      "Epoch 58 tr: l 0.316 a 0.907 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.442sec(train) 0.922sec(infer)\n",
      "Epoch 58 tst: l 0.324 a 0.906 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.435sec\n",
      "Epoch 59 tr: l 0.315 a 0.908 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.543sec(train) 0.910sec(infer)\n",
      "Epoch 59 tst: l 0.322 a 0.907 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.375sec\n",
      "Epoch 60 tr: l 0.313 a 0.908 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.762sec(train) 0.976sec(infer)\n",
      "Epoch 60 tst: l 0.320 a 0.907 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.375sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 61 tr: l 0.312 a 0.908 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.152sec(train) 0.990sec(infer)\n",
      "Epoch 61 tst: l 0.319 a 0.908 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.401sec\n",
      "Epoch 62 tr: l 0.309 a 0.909 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.929sec(train) 1.007sec(infer)\n",
      "Epoch 62 tst: l 0.317 a 0.909 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.385sec\n",
      "Epoch 63 tr: l 0.307 a 0.909 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.951sec(train) 0.963sec(infer)\n",
      "Epoch 63 tst: l 0.316 a 0.909 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.303sec\n",
      "Epoch 64 tr: l 0.305 a 0.910 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.754sec(train) 1.009sec(infer)\n",
      "Epoch 64 tst: l 0.315 a 0.909 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.414sec\n",
      "Epoch 65 tr: l 0.304 a 0.910 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.024sec(train) 1.023sec(infer)\n",
      "Epoch 65 tst: l 0.313 a 0.910 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.410sec\n",
      "Epoch 66 tr: l 0.302 a 0.910 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.927sec(train) 1.003sec(infer)\n",
      "Epoch 66 tst: l 0.312 a 0.910 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.434sec\n",
      "Epoch 67 tr: l 0.301 a 0.911 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.934sec(train) 0.964sec(infer)\n",
      "Epoch 67 tst: l 0.310 a 0.911 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.432sec\n",
      "Epoch 68 tr: l 0.299 a 0.911 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.957sec(train) 0.871sec(infer)\n",
      "Epoch 68 tst: l 0.309 a 0.911 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.435sec\n",
      "Epoch 69 tr: l 0.298 a 0.911 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.842sec(train) 0.971sec(infer)\n",
      "Epoch 69 tst: l 0.308 a 0.911 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.418sec\n",
      "Epoch 70 tr: l 0.298 a 0.912 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.003sec(train) 1.051sec(infer)\n",
      "Epoch 70 tst: l 0.307 a 0.911 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.457sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 71 tr: l 0.295 a 0.912 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.135sec(train) 1.146sec(infer)\n",
      "Epoch 71 tst: l 0.306 a 0.912 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.439sec\n",
      "Epoch 72 tr: l 0.295 a 0.913 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.080sec(train) 0.984sec(infer)\n",
      "Epoch 72 tst: l 0.304 a 0.912 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.410sec\n",
      "Epoch 73 tr: l 0.293 a 0.912 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.203sec(train) 1.036sec(infer)\n",
      "Epoch 73 tst: l 0.303 a 0.913 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.365sec\n",
      "Epoch 74 tr: l 0.291 a 0.913 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.552sec(train) 0.887sec(infer)\n",
      "Epoch 74 tst: l 0.302 a 0.913 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.385sec\n",
      "Epoch 75 tr: l 0.290 a 0.913 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.220sec(train) 0.978sec(infer)\n",
      "Epoch 75 tst: l 0.301 a 0.913 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.424sec\n",
      "Epoch 76 tr: l 0.289 a 0.913 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.094sec(train) 0.938sec(infer)\n",
      "Epoch 76 tst: l 0.299 a 0.914 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.417sec\n",
      "Epoch 77 tr: l 0.288 a 0.914 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.390sec(train) 1.015sec(infer)\n",
      "Epoch 77 tst: l 0.299 a 0.914 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.437sec\n",
      "Epoch 78 tr: l 0.286 a 0.914 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.254sec(train) 1.020sec(infer)\n",
      "Epoch 78 tst: l 0.298 a 0.914 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.404sec\n",
      "Epoch 79 tr: l 0.286 a 0.914 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.331sec(train) 0.985sec(infer)\n",
      "Epoch 79 tst: l 0.297 a 0.914 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.374sec\n",
      "Epoch 80 tr: l 0.283 a 0.915 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.964sec(train) 0.899sec(infer)\n",
      "Epoch 80 tst: l 0.296 a 0.914 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.374sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 81 tr: l 0.283 a 0.915 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.877sec(train) 0.924sec(infer)\n",
      "Epoch 81 tst: l 0.295 a 0.915 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.368sec\n",
      "Epoch 82 tr: l 0.281 a 0.916 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.514sec(train) 0.964sec(infer)\n",
      "Epoch 82 tst: l 0.294 a 0.915 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.369sec\n",
      "Epoch 83 tr: l 0.281 a 0.916 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.288sec(train) 1.022sec(infer)\n",
      "Epoch 83 tst: l 0.293 a 0.916 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.407sec\n",
      "Epoch 84 tr: l 0.280 a 0.916 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.258sec(train) 1.014sec(infer)\n",
      "Epoch 84 tst: l 0.292 a 0.916 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.412sec\n",
      "Epoch 85 tr: l 0.279 a 0.917 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.411sec(train) 1.023sec(infer)\n",
      "Epoch 85 tst: l 0.291 a 0.916 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.461sec\n",
      "Epoch 86 tr: l 0.278 a 0.917 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.940sec(train) 1.051sec(infer)\n",
      "Epoch 86 tst: l 0.290 a 0.916 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.441sec\n",
      "Epoch 87 tr: l 0.275 a 0.917 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.809sec(train) 0.993sec(infer)\n",
      "Epoch 87 tst: l 0.289 a 0.917 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.455sec\n",
      "Epoch 88 tr: l 0.275 a 0.918 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.905sec(train) 0.902sec(infer)\n",
      "Epoch 88 tst: l 0.289 a 0.917 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.412sec\n",
      "Epoch 89 tr: l 0.275 a 0.918 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.918sec(train) 0.948sec(infer)\n",
      "Epoch 89 tst: l 0.288 a 0.918 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.430sec\n",
      "Epoch 90 tr: l 0.273 a 0.918 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.183sec(train) 0.978sec(infer)\n",
      "Epoch 90 tst: l 0.287 a 0.918 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.477sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 91 tr: l 0.272 a 0.919 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.222sec(train) 1.002sec(infer)\n",
      "Epoch 91 tst: l 0.286 a 0.918 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.421sec\n",
      "Epoch 92 tr: l 0.271 a 0.919 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.698sec(train) 1.027sec(infer)\n",
      "Epoch 92 tst: l 0.285 a 0.918 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.398sec\n",
      "Epoch 93 tr: l 0.270 a 0.919 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.819sec(train) 1.009sec(infer)\n",
      "Epoch 93 tst: l 0.284 a 0.918 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.417sec\n",
      "Epoch 94 tr: l 0.268 a 0.920 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.828sec(train) 0.843sec(infer)\n",
      "Epoch 94 tst: l 0.283 a 0.919 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.399sec\n",
      "Epoch 95 tr: l 0.268 a 0.920 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.659sec(train) 0.902sec(infer)\n",
      "Epoch 95 tst: l 0.282 a 0.919 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.414sec\n",
      "Epoch 96 tr: l 0.267 a 0.920 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.870sec(train) 0.968sec(infer)\n",
      "Epoch 96 tst: l 0.282 a 0.920 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.441sec\n",
      "Epoch 97 tr: l 0.266 a 0.920 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.496sec(train) 0.925sec(infer)\n",
      "Epoch 97 tst: l 0.281 a 0.920 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.391sec\n",
      "Epoch 98 tr: l 0.264 a 0.920 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.626sec(train) 0.914sec(infer)\n",
      "Epoch 98 tst: l 0.280 a 0.920 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.408sec\n",
      "Epoch 99 tr: l 0.263 a 0.921 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.414sec(train) 0.953sec(infer)\n",
      "Epoch 99 tst: l 0.279 a 0.920 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.408sec\n",
      "Epoch 100 tr: l 0.263 a 0.921 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.950sec(train) 0.966sec(infer)\n",
      "Epoch 100 tst: l 0.278 a 0.920 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.397sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 101 tr: l 0.264 a 0.921 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.379sec(train) 0.881sec(infer)\n",
      "Epoch 101 tst: l 0.278 a 0.921 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.377sec\n",
      "Epoch 102 tr: l 0.262 a 0.922 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.921sec(train) 0.942sec(infer)\n",
      "Epoch 102 tst: l 0.277 a 0.920 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.389sec\n",
      "Epoch 103 tr: l 0.259 a 0.922 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.555sec(train) 1.017sec(infer)\n",
      "Epoch 103 tst: l 0.276 a 0.921 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.369sec\n",
      "Epoch 104 tr: l 0.260 a 0.922 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.019sec(train) 1.008sec(infer)\n",
      "Epoch 104 tst: l 0.276 a 0.921 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.412sec\n",
      "Epoch 105 tr: l 0.258 a 0.922 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.828sec(train) 1.043sec(infer)\n",
      "Epoch 105 tst: l 0.275 a 0.921 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.419sec\n",
      "Epoch 106 tr: l 0.258 a 0.923 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.796sec(train) 1.034sec(infer)\n",
      "Epoch 106 tst: l 0.274 a 0.921 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.381sec\n",
      "Epoch 107 tr: l 0.257 a 0.923 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.086sec(train) 1.032sec(infer)\n",
      "Epoch 107 tst: l 0.273 a 0.922 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.415sec\n",
      "Epoch 108 tr: l 0.255 a 0.923 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.097sec(train) 1.101sec(infer)\n",
      "Epoch 108 tst: l 0.273 a 0.922 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.362sec\n",
      "Epoch 109 tr: l 0.256 a 0.923 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.382sec(train) 1.008sec(infer)\n",
      "Epoch 109 tst: l 0.272 a 0.922 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.431sec\n",
      "Epoch 110 tr: l 0.255 a 0.924 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.171sec(train) 1.156sec(infer)\n",
      "Epoch 110 tst: l 0.271 a 0.922 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.449sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 111 tr: l 0.254 a 0.924 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.899sec(train) 1.003sec(infer)\n",
      "Epoch 111 tst: l 0.270 a 0.922 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.413sec\n",
      "Epoch 112 tr: l 0.252 a 0.924 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.102sec(train) 1.078sec(infer)\n",
      "Epoch 112 tst: l 0.270 a 0.923 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.418sec\n",
      "Epoch 113 tr: l 0.252 a 0.924 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.313sec(train) 0.995sec(infer)\n",
      "Epoch 113 tst: l 0.269 a 0.923 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.388sec\n",
      "Epoch 114 tr: l 0.252 a 0.925 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.898sec(train) 0.889sec(infer)\n",
      "Epoch 114 tst: l 0.268 a 0.923 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.367sec\n",
      "Epoch 115 tr: l 0.250 a 0.925 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.018sec(train) 0.955sec(infer)\n",
      "Epoch 115 tst: l 0.268 a 0.923 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.434sec\n",
      "Epoch 116 tr: l 0.250 a 0.925 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.640sec(train) 0.999sec(infer)\n",
      "Epoch 116 tst: l 0.267 a 0.924 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.373sec\n",
      "Epoch 117 tr: l 0.248 a 0.925 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.185sec(train) 1.034sec(infer)\n",
      "Epoch 117 tst: l 0.266 a 0.924 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.447sec\n",
      "Epoch 118 tr: l 0.249 a 0.925 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.990sec(train) 0.889sec(infer)\n",
      "Epoch 118 tst: l 0.265 a 0.924 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.371sec\n",
      "Epoch 119 tr: l 0.248 a 0.925 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.184sec(train) 1.003sec(infer)\n",
      "Epoch 119 tst: l 0.265 a 0.924 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.369sec\n",
      "Epoch 120 tr: l 0.246 a 0.926 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.938sec(train) 1.162sec(infer)\n",
      "Epoch 120 tst: l 0.264 a 0.924 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.388sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 121 tr: l 0.246 a 0.926 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.891sec(train) 0.983sec(infer)\n",
      "Epoch 121 tst: l 0.264 a 0.924 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.417sec\n",
      "Epoch 122 tr: l 0.245 a 0.926 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.430sec(train) 0.923sec(infer)\n",
      "Epoch 122 tst: l 0.263 a 0.925 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.412sec\n",
      "Epoch 123 tr: l 0.244 a 0.926 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.112sec(train) 1.008sec(infer)\n",
      "Epoch 123 tst: l 0.262 a 0.925 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.448sec\n",
      "Epoch 124 tr: l 0.243 a 0.927 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.846sec(train) 0.928sec(infer)\n",
      "Epoch 124 tst: l 0.261 a 0.925 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.413sec\n",
      "Epoch 125 tr: l 0.242 a 0.927 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.864sec(train) 0.926sec(infer)\n",
      "Epoch 125 tst: l 0.261 a 0.926 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.377sec\n",
      "Epoch 126 tr: l 0.242 a 0.927 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.716sec(train) 1.006sec(infer)\n",
      "Epoch 126 tst: l 0.260 a 0.925 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.407sec\n",
      "Epoch 127 tr: l 0.241 a 0.927 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.775sec(train) 0.975sec(infer)\n",
      "Epoch 127 tst: l 0.260 a 0.926 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.377sec\n",
      "Epoch 128 tr: l 0.241 a 0.928 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.556sec(train) 1.094sec(infer)\n",
      "Epoch 128 tst: l 0.259 a 0.926 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.503sec\n",
      "Epoch 129 tr: l 0.240 a 0.928 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.199sec(train) 1.100sec(infer)\n",
      "Epoch 129 tst: l 0.258 a 0.926 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.386sec\n",
      "Epoch 130 tr: l 0.239 a 0.928 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.213sec(train) 1.002sec(infer)\n",
      "Epoch 130 tst: l 0.257 a 0.926 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.412sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 131 tr: l 0.238 a 0.928 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.753sec(train) 1.026sec(infer)\n",
      "Epoch 131 tst: l 0.257 a 0.926 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.394sec\n",
      "Epoch 132 tr: l 0.238 a 0.928 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.759sec(train) 1.010sec(infer)\n",
      "Epoch 132 tst: l 0.257 a 0.927 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.377sec\n",
      "Epoch 133 tr: l 0.237 a 0.928 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.991sec(train) 1.028sec(infer)\n",
      "Epoch 133 tst: l 0.255 a 0.927 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.401sec\n",
      "Epoch 134 tr: l 0.236 a 0.929 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.574sec(train) 1.043sec(infer)\n",
      "Epoch 134 tst: l 0.255 a 0.927 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.439sec\n",
      "Epoch 135 tr: l 0.235 a 0.929 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.896sec(train) 1.000sec(infer)\n",
      "Epoch 135 tst: l 0.255 a 0.927 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.415sec\n",
      "Epoch 136 tr: l 0.233 a 0.930 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.121sec(train) 1.071sec(infer)\n",
      "Epoch 136 tst: l 0.254 a 0.927 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.440sec\n",
      "Epoch 137 tr: l 0.234 a 0.930 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.119sec(train) 1.114sec(infer)\n",
      "Epoch 137 tst: l 0.253 a 0.927 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.451sec\n",
      "Epoch 138 tr: l 0.233 a 0.930 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.757sec(train) 0.953sec(infer)\n",
      "Epoch 138 tst: l 0.252 a 0.928 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.406sec\n",
      "Epoch 139 tr: l 0.232 a 0.930 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.249sec(train) 1.044sec(infer)\n",
      "Epoch 139 tst: l 0.252 a 0.928 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.452sec\n",
      "Epoch 140 tr: l 0.231 a 0.930 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.972sec(train) 1.074sec(infer)\n",
      "Epoch 140 tst: l 0.251 a 0.928 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.438sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 141 tr: l 0.231 a 0.931 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.486sec(train) 1.136sec(infer)\n",
      "Epoch 141 tst: l 0.251 a 0.928 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.469sec\n",
      "Epoch 142 tr: l 0.230 a 0.931 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.408sec(train) 0.971sec(infer)\n",
      "Epoch 142 tst: l 0.250 a 0.929 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.393sec\n",
      "Epoch 143 tr: l 0.230 a 0.931 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.897sec(train) 0.978sec(infer)\n",
      "Epoch 143 tst: l 0.249 a 0.929 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.358sec\n",
      "Epoch 144 tr: l 0.229 a 0.931 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.553sec(train) 1.055sec(infer)\n",
      "Epoch 144 tst: l 0.249 a 0.929 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.421sec\n",
      "Epoch 145 tr: l 0.228 a 0.931 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.140sec(train) 0.944sec(infer)\n",
      "Epoch 145 tst: l 0.249 a 0.929 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.461sec\n",
      "Epoch 146 tr: l 0.227 a 0.932 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.002sec(train) 0.913sec(infer)\n",
      "Epoch 146 tst: l 0.248 a 0.929 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.372sec\n",
      "Epoch 147 tr: l 0.226 a 0.932 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.705sec(train) 0.973sec(infer)\n",
      "Epoch 147 tst: l 0.247 a 0.929 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.407sec\n",
      "Epoch 148 tr: l 0.226 a 0.932 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.067sec(train) 0.868sec(infer)\n",
      "Epoch 148 tst: l 0.247 a 0.930 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.372sec\n",
      "Epoch 149 tr: l 0.226 a 0.932 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.393sec(train) 0.960sec(infer)\n",
      "Epoch 149 tst: l 0.246 a 0.929 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.390sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "---train cluster Ended in 0.27 hour (966.092 sec) \n",
      "---------------------------------DFCA-LI, lr: 0.1, seed: 7383---------------------------------\n",
      "config: {'m': 240, 'm_test': 40, 'p': 2, 'n': 500, 'uneven': True, 'local_model_init': True, 'Gp': 0.1, 'graph': 'er', 'agg': 'seq', 'h1': 200, 'num_epochs': 150, 'batch_size': 100, 'tau': 10, 'lr': 0.1, 'data_seed': 7383, 'train_seed': 7383, 'config_override': '', 'project_dir': 'output_dfca_gi'}\n",
      "Using device: cuda:1\n",
      "Epoch -1 tr: l 2.301 a 0.106 clct[np.int64(113), np.int64(127)] cl_acc 0.504  0.912sec\n",
      "Epoch -1 tst: l 2.300 a 0.116 clct[np.int64(18), np.int64(22)] cl_acc 0.500  0.414sec\n",
      "Epoch 0 tr: l 2.276 a 0.353 clct[np.int64(115), np.int64(125)] cl_acc 0.512  lr 0.100000 5.383sec(train) 0.969sec(infer)\n",
      "Epoch 0 tst: l 2.287 a 0.276 clct[np.int64(24), np.int64(16)] cl_acc 0.600  0.467sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 1 tr: l 2.276 a 0.291 clct[np.int64(129), np.int64(111)] cl_acc 0.504  lr 0.100000 5.511sec(train) 0.938sec(infer)\n",
      "Epoch 1 tst: l 2.286 a 0.276 clct[np.int64(25), np.int64(15)] cl_acc 0.625  0.391sec\n",
      "Epoch 2 tr: l 2.274 a 0.204 clct[np.int64(136), np.int64(104)] cl_acc 0.500  lr 0.100000 4.647sec(train) 0.989sec(infer)\n",
      "Epoch 2 tst: l 2.281 a 0.224 clct[np.int64(30), np.int64(10)] cl_acc 0.600  0.419sec\n",
      "Epoch 3 tr: l 2.250 a 0.174 clct[np.int64(140), np.int64(100)] cl_acc 0.517  lr 0.100000 5.117sec(train) 1.011sec(infer)\n",
      "Epoch 3 tst: l 2.261 a 0.200 clct[np.int64(30), np.int64(10)] cl_acc 0.650  0.414sec\n",
      "Epoch 4 tr: l 2.200 a 0.201 clct[np.int64(147), np.int64(93)] cl_acc 0.554  lr 0.100000 4.845sec(train) 1.023sec(infer)\n",
      "Epoch 4 tst: l 2.221 a 0.212 clct[np.int64(31), np.int64(9)] cl_acc 0.675  0.383sec\n",
      "Epoch 5 tr: l 2.129 a 0.293 clct[np.int64(159), np.int64(81)] cl_acc 0.604  lr 0.100000 5.228sec(train) 0.990sec(infer)\n",
      "Epoch 5 tst: l 2.151 a 0.283 clct[np.int64(32), np.int64(8)] cl_acc 0.700  0.433sec\n",
      "Epoch 6 tr: l 2.022 a 0.403 clct[np.int64(161), np.int64(79)] cl_acc 0.654  lr 0.100000 5.331sec(train) 1.040sec(infer)\n",
      "Epoch 6 tst: l 2.046 a 0.396 clct[np.int64(31), np.int64(9)] cl_acc 0.725  0.423sec\n",
      "Epoch 7 tr: l 1.869 a 0.484 clct[np.int64(152), np.int64(88)] cl_acc 0.783  lr 0.100000 5.287sec(train) 1.086sec(infer)\n",
      "Epoch 7 tst: l 1.898 a 0.478 clct[np.int64(29), np.int64(11)] cl_acc 0.775  0.424sec\n",
      "Epoch 8 tr: l 1.684 a 0.558 clct[np.int64(123), np.int64(117)] cl_acc 0.954  lr 0.100000 5.646sec(train) 1.018sec(infer)\n",
      "Epoch 8 tst: l 1.721 a 0.543 clct[np.int64(23), np.int64(17)] cl_acc 0.925  0.403sec\n",
      "Epoch 9 tr: l 1.497 a 0.628 clct[np.int64(119), np.int64(121)] cl_acc 0.996  lr 0.100000 5.309sec(train) 0.971sec(infer)\n",
      "Epoch 9 tst: l 1.533 a 0.608 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.401sec\n",
      "Epoch 10 tr: l 1.319 a 0.682 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.449sec(train) 1.078sec(infer)\n",
      "Epoch 10 tst: l 1.354 a 0.669 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.432sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 11 tr: l 1.161 a 0.720 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.282sec(train) 1.047sec(infer)\n",
      "Epoch 11 tst: l 1.195 a 0.709 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.384sec\n",
      "Epoch 12 tr: l 1.030 a 0.749 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.693sec(train) 0.974sec(infer)\n",
      "Epoch 12 tst: l 1.057 a 0.742 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.409sec\n",
      "Epoch 13 tr: l 0.920 a 0.771 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.562sec(train) 0.923sec(infer)\n",
      "Epoch 13 tst: l 0.944 a 0.767 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.372sec\n",
      "Epoch 14 tr: l 0.832 a 0.790 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.925sec(train) 1.034sec(infer)\n",
      "Epoch 14 tst: l 0.855 a 0.786 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.407sec\n",
      "Epoch 15 tr: l 0.761 a 0.805 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.189sec(train) 0.935sec(infer)\n",
      "Epoch 15 tst: l 0.782 a 0.802 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.403sec\n",
      "Epoch 16 tr: l 0.705 a 0.818 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.238sec(train) 0.935sec(infer)\n",
      "Epoch 16 tst: l 0.723 a 0.816 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.356sec\n",
      "Epoch 17 tr: l 0.659 a 0.827 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.897sec(train) 0.898sec(infer)\n",
      "Epoch 17 tst: l 0.676 a 0.827 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.349sec\n",
      "Epoch 18 tr: l 0.621 a 0.836 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.960sec(train) 1.039sec(infer)\n",
      "Epoch 18 tst: l 0.636 a 0.837 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.479sec\n",
      "Epoch 19 tr: l 0.588 a 0.844 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.612sec(train) 0.920sec(infer)\n",
      "Epoch 19 tst: l 0.603 a 0.844 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.407sec\n",
      "Epoch 20 tr: l 0.560 a 0.851 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.138sec(train) 0.824sec(infer)\n",
      "Epoch 20 tst: l 0.574 a 0.851 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.361sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 21 tr: l 0.538 a 0.856 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.276sec(train) 1.063sec(infer)\n",
      "Epoch 21 tst: l 0.551 a 0.856 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.417sec\n",
      "Epoch 22 tr: l 0.517 a 0.861 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.416sec(train) 0.934sec(infer)\n",
      "Epoch 22 tst: l 0.529 a 0.862 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.344sec\n",
      "Epoch 23 tr: l 0.499 a 0.866 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.337sec(train) 0.962sec(infer)\n",
      "Epoch 23 tst: l 0.511 a 0.866 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.385sec\n",
      "Epoch 24 tr: l 0.481 a 0.869 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.373sec(train) 0.921sec(infer)\n",
      "Epoch 24 tst: l 0.494 a 0.870 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.389sec\n",
      "Epoch 25 tr: l 0.469 a 0.872 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.185sec(train) 0.979sec(infer)\n",
      "Epoch 25 tst: l 0.480 a 0.873 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.415sec\n",
      "Epoch 26 tr: l 0.457 a 0.875 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.558sec(train) 1.019sec(infer)\n",
      "Epoch 26 tst: l 0.469 a 0.876 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.493sec\n",
      "Epoch 27 tr: l 0.444 a 0.878 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.389sec(train) 0.952sec(infer)\n",
      "Epoch 27 tst: l 0.457 a 0.878 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.439sec\n",
      "Epoch 28 tr: l 0.434 a 0.880 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.439sec(train) 0.910sec(infer)\n",
      "Epoch 28 tst: l 0.447 a 0.881 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.372sec\n",
      "Epoch 29 tr: l 0.423 a 0.882 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.744sec(train) 0.877sec(infer)\n",
      "Epoch 29 tst: l 0.437 a 0.883 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.343sec\n",
      "Epoch 30 tr: l 0.416 a 0.884 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.447sec(train) 0.859sec(infer)\n",
      "Epoch 30 tst: l 0.429 a 0.885 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.380sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 31 tr: l 0.409 a 0.886 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.337sec(train) 0.990sec(infer)\n",
      "Epoch 31 tst: l 0.421 a 0.887 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.441sec\n",
      "Epoch 32 tr: l 0.401 a 0.887 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.628sec(train) 0.958sec(infer)\n",
      "Epoch 32 tst: l 0.414 a 0.888 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.414sec\n",
      "Epoch 33 tr: l 0.395 a 0.889 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.575sec(train) 0.794sec(infer)\n",
      "Epoch 33 tst: l 0.408 a 0.890 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.339sec\n",
      "Epoch 34 tr: l 0.387 a 0.890 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.793sec(train) 0.887sec(infer)\n",
      "Epoch 34 tst: l 0.402 a 0.890 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.377sec\n",
      "Epoch 35 tr: l 0.384 a 0.892 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.710sec(train) 0.812sec(infer)\n",
      "Epoch 35 tst: l 0.397 a 0.892 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.358sec\n",
      "Epoch 36 tr: l 0.377 a 0.893 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.231sec(train) 1.022sec(infer)\n",
      "Epoch 36 tst: l 0.391 a 0.893 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.444sec\n",
      "Epoch 37 tr: l 0.373 a 0.893 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.039sec(train) 1.019sec(infer)\n",
      "Epoch 37 tst: l 0.387 a 0.894 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.420sec\n",
      "Epoch 38 tr: l 0.369 a 0.895 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.686sec(train) 0.871sec(infer)\n",
      "Epoch 38 tst: l 0.382 a 0.896 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.436sec\n",
      "Epoch 39 tr: l 0.365 a 0.896 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.373sec(train) 0.851sec(infer)\n",
      "Epoch 39 tst: l 0.378 a 0.896 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.416sec\n",
      "Epoch 40 tr: l 0.359 a 0.896 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.098sec(train) 0.991sec(infer)\n",
      "Epoch 40 tst: l 0.375 a 0.897 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.398sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 41 tr: l 0.356 a 0.897 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.604sec(train) 1.046sec(infer)\n",
      "Epoch 41 tst: l 0.371 a 0.897 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.446sec\n",
      "Epoch 42 tr: l 0.352 a 0.898 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.959sec(train) 1.004sec(infer)\n",
      "Epoch 42 tst: l 0.368 a 0.898 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.415sec\n",
      "Epoch 43 tr: l 0.348 a 0.899 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.504sec(train) 0.897sec(infer)\n",
      "Epoch 43 tst: l 0.364 a 0.899 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.377sec\n",
      "Epoch 44 tr: l 0.348 a 0.899 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.529sec(train) 0.919sec(infer)\n",
      "Epoch 44 tst: l 0.361 a 0.900 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.415sec\n",
      "Epoch 45 tr: l 0.344 a 0.900 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.621sec(train) 1.005sec(infer)\n",
      "Epoch 45 tst: l 0.358 a 0.900 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.425sec\n",
      "Epoch 46 tr: l 0.340 a 0.901 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.344sec(train) 0.911sec(infer)\n",
      "Epoch 46 tst: l 0.356 a 0.901 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.377sec\n",
      "Epoch 47 tr: l 0.337 a 0.902 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.685sec(train) 0.895sec(infer)\n",
      "Epoch 47 tst: l 0.353 a 0.901 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.413sec\n",
      "Epoch 48 tr: l 0.335 a 0.902 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.962sec(train) 0.937sec(infer)\n",
      "Epoch 48 tst: l 0.350 a 0.902 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.423sec\n",
      "Epoch 49 tr: l 0.332 a 0.903 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.973sec(train) 0.947sec(infer)\n",
      "Epoch 49 tst: l 0.348 a 0.902 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.403sec\n",
      "Epoch 50 tr: l 0.329 a 0.903 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.715sec(train) 0.897sec(infer)\n",
      "Epoch 50 tst: l 0.346 a 0.903 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.435sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 51 tr: l 0.326 a 0.904 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.259sec(train) 1.017sec(infer)\n",
      "Epoch 51 tst: l 0.344 a 0.904 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.490sec\n",
      "Epoch 52 tr: l 0.325 a 0.904 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.920sec(train) 0.941sec(infer)\n",
      "Epoch 52 tst: l 0.342 a 0.904 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.393sec\n",
      "Epoch 53 tr: l 0.323 a 0.905 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.745sec(train) 0.944sec(infer)\n",
      "Epoch 53 tst: l 0.340 a 0.904 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.392sec\n",
      "Epoch 54 tr: l 0.319 a 0.905 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.079sec(train) 0.971sec(infer)\n",
      "Epoch 54 tst: l 0.338 a 0.905 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.347sec\n",
      "Epoch 55 tr: l 0.319 a 0.906 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.453sec(train) 0.951sec(infer)\n",
      "Epoch 55 tst: l 0.336 a 0.906 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.346sec\n",
      "Epoch 56 tr: l 0.315 a 0.906 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.358sec(train) 1.115sec(infer)\n",
      "Epoch 56 tst: l 0.334 a 0.906 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.479sec\n",
      "Epoch 57 tr: l 0.312 a 0.907 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.487sec(train) 1.127sec(infer)\n",
      "Epoch 57 tst: l 0.333 a 0.907 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.504sec\n",
      "Epoch 58 tr: l 0.309 a 0.908 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.782sec(train) 1.000sec(infer)\n",
      "Epoch 58 tst: l 0.331 a 0.907 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.449sec\n",
      "Epoch 59 tr: l 0.310 a 0.908 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.442sec(train) 0.920sec(infer)\n",
      "Epoch 59 tst: l 0.329 a 0.907 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.381sec\n",
      "Epoch 60 tr: l 0.309 a 0.909 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.042sec(train) 0.929sec(infer)\n",
      "Epoch 60 tst: l 0.328 a 0.908 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.373sec\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.909 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.289sec(train) 0.984sec(infer)\n",
      "Epoch 61 tst: l 0.326 a 0.908 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.430sec\n",
      "Epoch 62 tr: l 0.305 a 0.909 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.707sec(train) 1.147sec(infer)\n",
      "Epoch 62 tst: l 0.325 a 0.909 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.629sec\n",
      "Epoch 63 tr: l 0.303 a 0.910 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 6.870sec(train) 1.011sec(infer)\n",
      "Epoch 63 tst: l 0.324 a 0.909 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.406sec\n",
      "Epoch 64 tr: l 0.302 a 0.910 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.726sec(train) 1.061sec(infer)\n",
      "Epoch 64 tst: l 0.322 a 0.910 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.472sec\n",
      "Epoch 65 tr: l 0.299 a 0.910 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.416sec(train) 0.898sec(infer)\n",
      "Epoch 65 tst: l 0.320 a 0.910 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.371sec\n",
      "Epoch 66 tr: l 0.299 a 0.911 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.714sec(train) 1.119sec(infer)\n",
      "Epoch 66 tst: l 0.319 a 0.910 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.423sec\n",
      "Epoch 67 tr: l 0.296 a 0.911 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.519sec(train) 1.033sec(infer)\n",
      "Epoch 67 tst: l 0.318 a 0.911 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.469sec\n",
      "Epoch 68 tr: l 0.296 a 0.911 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.736sec(train) 0.962sec(infer)\n",
      "Epoch 68 tst: l 0.317 a 0.911 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.428sec\n",
      "Epoch 69 tr: l 0.295 a 0.912 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.345sec(train) 1.017sec(infer)\n",
      "Epoch 69 tst: l 0.315 a 0.911 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.435sec\n",
      "Epoch 70 tr: l 0.293 a 0.912 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.553sec(train) 1.053sec(infer)\n",
      "Epoch 70 tst: l 0.314 a 0.912 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.416sec\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.913 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.406sec(train) 0.957sec(infer)\n",
      "Epoch 71 tst: l 0.313 a 0.912 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.401sec\n",
      "Epoch 72 tr: l 0.290 a 0.913 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.485sec(train) 1.117sec(infer)\n",
      "Epoch 72 tst: l 0.312 a 0.912 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.445sec\n",
      "Epoch 73 tr: l 0.289 a 0.913 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.943sec(train) 0.902sec(infer)\n",
      "Epoch 73 tst: l 0.311 a 0.913 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.394sec\n",
      "Epoch 74 tr: l 0.287 a 0.914 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.602sec(train) 1.008sec(infer)\n",
      "Epoch 74 tst: l 0.310 a 0.913 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.440sec\n",
      "Epoch 75 tr: l 0.287 a 0.914 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.688sec(train) 1.039sec(infer)\n",
      "Epoch 75 tst: l 0.309 a 0.913 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.414sec\n",
      "Epoch 76 tr: l 0.285 a 0.914 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.655sec(train) 0.989sec(infer)\n",
      "Epoch 76 tst: l 0.307 a 0.914 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.418sec\n",
      "Epoch 77 tr: l 0.284 a 0.915 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.268sec(train) 0.967sec(infer)\n",
      "Epoch 77 tst: l 0.307 a 0.914 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.429sec\n",
      "Epoch 78 tr: l 0.283 a 0.915 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.309sec(train) 0.948sec(infer)\n",
      "Epoch 78 tst: l 0.306 a 0.915 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.409sec\n",
      "Epoch 79 tr: l 0.283 a 0.915 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.388sec(train) 1.092sec(infer)\n",
      "Epoch 79 tst: l 0.305 a 0.915 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.452sec\n",
      "Epoch 80 tr: l 0.279 a 0.915 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.889sec(train) 1.083sec(infer)\n",
      "Epoch 80 tst: l 0.304 a 0.915 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.479sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 81 tr: l 0.280 a 0.916 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.002sec(train) 1.022sec(infer)\n",
      "Epoch 81 tst: l 0.303 a 0.916 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.437sec\n",
      "Epoch 82 tr: l 0.280 a 0.916 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.818sec(train) 1.215sec(infer)\n",
      "Epoch 82 tst: l 0.302 a 0.916 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.520sec\n",
      "Epoch 83 tr: l 0.279 a 0.916 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.318sec(train) 0.995sec(infer)\n",
      "Epoch 83 tst: l 0.301 a 0.916 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.437sec\n",
      "Epoch 84 tr: l 0.276 a 0.917 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.387sec(train) 1.031sec(infer)\n",
      "Epoch 84 tst: l 0.300 a 0.916 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.441sec\n",
      "Epoch 85 tr: l 0.275 a 0.917 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.646sec(train) 0.979sec(infer)\n",
      "Epoch 85 tst: l 0.299 a 0.916 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.412sec\n",
      "Epoch 86 tr: l 0.274 a 0.917 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.141sec(train) 0.965sec(infer)\n",
      "Epoch 86 tst: l 0.298 a 0.917 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.426sec\n",
      "Epoch 87 tr: l 0.272 a 0.918 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.381sec(train) 1.173sec(infer)\n",
      "Epoch 87 tst: l 0.297 a 0.917 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.407sec\n",
      "Epoch 88 tr: l 0.273 a 0.917 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.168sec(train) 1.063sec(infer)\n",
      "Epoch 88 tst: l 0.297 a 0.917 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.388sec\n",
      "Epoch 89 tr: l 0.270 a 0.918 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.247sec(train) 0.997sec(infer)\n",
      "Epoch 89 tst: l 0.296 a 0.917 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.393sec\n",
      "Epoch 90 tr: l 0.269 a 0.918 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.765sec(train) 1.111sec(infer)\n",
      "Epoch 90 tst: l 0.294 a 0.918 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.462sec\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.919 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.324sec(train) 0.929sec(infer)\n",
      "Epoch 91 tst: l 0.294 a 0.918 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.419sec\n",
      "Epoch 92 tr: l 0.269 a 0.919 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.820sec(train) 0.994sec(infer)\n",
      "Epoch 92 tst: l 0.292 a 0.918 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.409sec\n",
      "Epoch 93 tr: l 0.267 a 0.919 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.005sec(train) 0.964sec(infer)\n",
      "Epoch 93 tst: l 0.292 a 0.918 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.365sec\n",
      "Epoch 94 tr: l 0.265 a 0.919 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.687sec(train) 0.968sec(infer)\n",
      "Epoch 94 tst: l 0.291 a 0.918 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.395sec\n",
      "Epoch 95 tr: l 0.265 a 0.920 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.843sec(train) 0.927sec(infer)\n",
      "Epoch 95 tst: l 0.290 a 0.919 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.420sec\n",
      "Epoch 96 tr: l 0.264 a 0.920 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.663sec(train) 0.975sec(infer)\n",
      "Epoch 96 tst: l 0.289 a 0.919 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.457sec\n",
      "Epoch 97 tr: l 0.263 a 0.920 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.687sec(train) 0.966sec(infer)\n",
      "Epoch 97 tst: l 0.289 a 0.919 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.386sec\n",
      "Epoch 98 tr: l 0.263 a 0.920 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.670sec(train) 0.968sec(infer)\n",
      "Epoch 98 tst: l 0.288 a 0.920 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.405sec\n",
      "Epoch 99 tr: l 0.261 a 0.921 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.132sec(train) 1.003sec(infer)\n",
      "Epoch 99 tst: l 0.287 a 0.920 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.453sec\n",
      "Epoch 100 tr: l 0.262 a 0.921 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.170sec(train) 0.985sec(infer)\n",
      "Epoch 100 tst: l 0.286 a 0.920 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.465sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 101 tr: l 0.260 a 0.921 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.698sec(train) 1.024sec(infer)\n",
      "Epoch 101 tst: l 0.285 a 0.920 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.483sec\n",
      "Epoch 102 tr: l 0.259 a 0.921 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.178sec(train) 1.060sec(infer)\n",
      "Epoch 102 tst: l 0.285 a 0.921 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.383sec\n",
      "Epoch 103 tr: l 0.256 a 0.922 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.016sec(train) 1.050sec(infer)\n",
      "Epoch 103 tst: l 0.284 a 0.921 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.457sec\n",
      "Epoch 104 tr: l 0.256 a 0.922 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.009sec(train) 1.062sec(infer)\n",
      "Epoch 104 tst: l 0.283 a 0.921 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.397sec\n",
      "Epoch 105 tr: l 0.255 a 0.922 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.882sec(train) 0.982sec(infer)\n",
      "Epoch 105 tst: l 0.283 a 0.921 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.432sec\n",
      "Epoch 106 tr: l 0.256 a 0.922 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.951sec(train) 1.020sec(infer)\n",
      "Epoch 106 tst: l 0.282 a 0.922 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.436sec\n",
      "Epoch 107 tr: l 0.254 a 0.923 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.373sec(train) 0.997sec(infer)\n",
      "Epoch 107 tst: l 0.281 a 0.922 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.382sec\n",
      "Epoch 108 tr: l 0.252 a 0.923 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.705sec(train) 0.954sec(infer)\n",
      "Epoch 108 tst: l 0.280 a 0.922 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.428sec\n",
      "Epoch 109 tr: l 0.252 a 0.923 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.947sec(train) 1.092sec(infer)\n",
      "Epoch 109 tst: l 0.279 a 0.922 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.419sec\n",
      "Epoch 110 tr: l 0.251 a 0.923 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.272sec(train) 0.939sec(infer)\n",
      "Epoch 110 tst: l 0.279 a 0.922 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.362sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 111 tr: l 0.250 a 0.924 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.783sec(train) 1.052sec(infer)\n",
      "Epoch 111 tst: l 0.278 a 0.922 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.406sec\n",
      "Epoch 112 tr: l 0.250 a 0.924 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.866sec(train) 0.948sec(infer)\n",
      "Epoch 112 tst: l 0.277 a 0.922 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.384sec\n",
      "Epoch 113 tr: l 0.248 a 0.924 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.081sec(train) 0.921sec(infer)\n",
      "Epoch 113 tst: l 0.276 a 0.923 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.394sec\n",
      "Epoch 114 tr: l 0.248 a 0.924 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.093sec(train) 0.943sec(infer)\n",
      "Epoch 114 tst: l 0.276 a 0.923 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.351sec\n",
      "Epoch 115 tr: l 0.248 a 0.924 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.782sec(train) 0.929sec(infer)\n",
      "Epoch 115 tst: l 0.275 a 0.923 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.363sec\n",
      "Epoch 116 tr: l 0.248 a 0.925 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.827sec(train) 0.895sec(infer)\n",
      "Epoch 116 tst: l 0.275 a 0.923 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.350sec\n",
      "Epoch 117 tr: l 0.245 a 0.925 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.431sec(train) 0.971sec(infer)\n",
      "Epoch 117 tst: l 0.274 a 0.923 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.382sec\n",
      "Epoch 118 tr: l 0.245 a 0.925 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.406sec(train) 0.990sec(infer)\n",
      "Epoch 118 tst: l 0.273 a 0.924 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.415sec\n",
      "Epoch 119 tr: l 0.243 a 0.926 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.380sec(train) 0.894sec(infer)\n",
      "Epoch 119 tst: l 0.273 a 0.924 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.361sec\n",
      "Epoch 120 tr: l 0.242 a 0.926 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.248sec(train) 1.006sec(infer)\n",
      "Epoch 120 tst: l 0.272 a 0.924 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.410sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 121 tr: l 0.244 a 0.926 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.188sec(train) 0.957sec(infer)\n",
      "Epoch 121 tst: l 0.271 a 0.924 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.373sec\n",
      "Epoch 122 tr: l 0.241 a 0.926 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.411sec(train) 0.949sec(infer)\n",
      "Epoch 122 tst: l 0.271 a 0.925 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.394sec\n",
      "Epoch 123 tr: l 0.241 a 0.926 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.494sec(train) 1.050sec(infer)\n",
      "Epoch 123 tst: l 0.270 a 0.925 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.376sec\n",
      "Epoch 124 tr: l 0.239 a 0.927 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.248sec(train) 1.012sec(infer)\n",
      "Epoch 124 tst: l 0.269 a 0.925 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.403sec\n",
      "Epoch 125 tr: l 0.240 a 0.927 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.970sec(train) 1.004sec(infer)\n",
      "Epoch 125 tst: l 0.268 a 0.926 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.394sec\n",
      "Epoch 126 tr: l 0.239 a 0.927 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.593sec(train) 0.894sec(infer)\n",
      "Epoch 126 tst: l 0.268 a 0.926 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.399sec\n",
      "Epoch 127 tr: l 0.238 a 0.927 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.708sec(train) 0.893sec(infer)\n",
      "Epoch 127 tst: l 0.267 a 0.926 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.377sec\n",
      "Epoch 128 tr: l 0.236 a 0.928 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.800sec(train) 0.885sec(infer)\n",
      "Epoch 128 tst: l 0.266 a 0.926 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.351sec\n",
      "Epoch 129 tr: l 0.236 a 0.928 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.784sec(train) 1.057sec(infer)\n",
      "Epoch 129 tst: l 0.266 a 0.925 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.378sec\n",
      "Epoch 130 tr: l 0.236 a 0.928 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.813sec(train) 1.003sec(infer)\n",
      "Epoch 130 tst: l 0.265 a 0.926 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.403sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 131 tr: l 0.235 a 0.928 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.213sec(train) 0.963sec(infer)\n",
      "Epoch 131 tst: l 0.265 a 0.926 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.384sec\n",
      "Epoch 132 tr: l 0.234 a 0.929 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.199sec(train) 0.954sec(infer)\n",
      "Epoch 132 tst: l 0.264 a 0.927 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.360sec\n",
      "Epoch 133 tr: l 0.233 a 0.929 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.098sec(train) 0.996sec(infer)\n",
      "Epoch 133 tst: l 0.263 a 0.927 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.402sec\n",
      "Epoch 134 tr: l 0.232 a 0.929 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.717sec(train) 0.974sec(infer)\n",
      "Epoch 134 tst: l 0.262 a 0.927 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.376sec\n",
      "Epoch 135 tr: l 0.233 a 0.929 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.463sec(train) 0.872sec(infer)\n",
      "Epoch 135 tst: l 0.262 a 0.927 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.343sec\n",
      "Epoch 136 tr: l 0.230 a 0.929 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.166sec(train) 0.998sec(infer)\n",
      "Epoch 136 tst: l 0.261 a 0.928 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.405sec\n",
      "Epoch 137 tr: l 0.231 a 0.930 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.015sec(train) 1.035sec(infer)\n",
      "Epoch 137 tst: l 0.261 a 0.928 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.384sec\n",
      "Epoch 138 tr: l 0.229 a 0.930 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.219sec(train) 1.071sec(infer)\n",
      "Epoch 138 tst: l 0.260 a 0.928 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.422sec\n",
      "Epoch 139 tr: l 0.228 a 0.930 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.954sec(train) 0.938sec(infer)\n",
      "Epoch 139 tst: l 0.259 a 0.928 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.409sec\n",
      "Epoch 140 tr: l 0.228 a 0.930 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.155sec(train) 0.954sec(infer)\n",
      "Epoch 140 tst: l 0.258 a 0.928 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.358sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 141 tr: l 0.228 a 0.931 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.347sec(train) 1.000sec(infer)\n",
      "Epoch 141 tst: l 0.258 a 0.928 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.421sec\n",
      "Epoch 142 tr: l 0.226 a 0.931 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.169sec(train) 0.938sec(infer)\n",
      "Epoch 142 tst: l 0.257 a 0.928 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.362sec\n",
      "Epoch 143 tr: l 0.226 a 0.931 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.269sec(train) 0.929sec(infer)\n",
      "Epoch 143 tst: l 0.257 a 0.928 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.367sec\n",
      "Epoch 144 tr: l 0.226 a 0.931 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.988sec(train) 0.859sec(infer)\n",
      "Epoch 144 tst: l 0.256 a 0.929 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.365sec\n",
      "Epoch 145 tr: l 0.225 a 0.931 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.262sec(train) 0.896sec(infer)\n",
      "Epoch 145 tst: l 0.255 a 0.929 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.374sec\n",
      "Epoch 146 tr: l 0.223 a 0.932 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.011sec(train) 0.982sec(infer)\n",
      "Epoch 146 tst: l 0.255 a 0.930 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.470sec\n",
      "Epoch 147 tr: l 0.223 a 0.932 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.052sec(train) 0.942sec(infer)\n",
      "Epoch 147 tst: l 0.254 a 0.929 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.373sec\n",
      "Epoch 148 tr: l 0.222 a 0.932 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.107sec(train) 0.870sec(infer)\n",
      "Epoch 148 tst: l 0.254 a 0.930 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.448sec\n",
      "Epoch 149 tr: l 0.222 a 0.932 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.949sec(train) 1.093sec(infer)\n",
      "Epoch 149 tst: l 0.253 a 0.930 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.459sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "---train cluster Ended in 0.27 hour (982.372 sec) \n",
      "---------------------------------DFCA-LI, lr: 0.1, seed: 6930---------------------------------\n",
      "config: {'m': 240, 'm_test': 40, 'p': 2, 'n': 500, 'uneven': True, 'local_model_init': True, 'Gp': 0.1, 'graph': 'er', 'agg': 'seq', 'h1': 200, 'num_epochs': 150, 'batch_size': 100, 'tau': 10, 'lr': 0.1, 'data_seed': 6930, 'train_seed': 6930, 'config_override': '', 'project_dir': 'output_dfca_gi'}\n",
      "Using device: cuda:1\n",
      "Epoch -1 tr: l 2.302 a 0.106 clct[np.int64(101), np.int64(139)] cl_acc 0.512  1.016sec\n",
      "Epoch -1 tst: l 2.302 a 0.115 clct[np.int64(17), np.int64(23)] cl_acc 0.525  0.410sec\n",
      "Epoch 0 tr: l 2.272 a 0.372 clct[np.int64(104), np.int64(136)] cl_acc 0.517  lr 0.100000 5.406sec(train) 0.997sec(infer)\n",
      "Epoch 0 tst: l 2.284 a 0.299 clct[np.int64(23), np.int64(17)] cl_acc 0.525  0.391sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 1 tr: l 2.277 a 0.311 clct[np.int64(112), np.int64(128)] cl_acc 0.525  lr 0.100000 4.879sec(train) 0.877sec(infer)\n",
      "Epoch 1 tst: l 2.283 a 0.290 clct[np.int64(29), np.int64(11)] cl_acc 0.525  0.389sec\n",
      "Epoch 2 tr: l 2.271 a 0.226 clct[np.int64(120), np.int64(120)] cl_acc 0.542  lr 0.100000 5.096sec(train) 0.911sec(infer)\n",
      "Epoch 2 tst: l 2.276 a 0.239 clct[np.int64(32), np.int64(8)] cl_acc 0.550  0.395sec\n",
      "Epoch 3 tr: l 2.246 a 0.196 clct[np.int64(125), np.int64(115)] cl_acc 0.554  lr 0.100000 5.057sec(train) 0.926sec(infer)\n",
      "Epoch 3 tst: l 2.257 a 0.204 clct[np.int64(32), np.int64(8)] cl_acc 0.550  0.392sec\n",
      "Epoch 4 tr: l 2.202 a 0.217 clct[np.int64(125), np.int64(115)] cl_acc 0.554  lr 0.100000 4.800sec(train) 0.885sec(infer)\n",
      "Epoch 4 tst: l 2.215 a 0.222 clct[np.int64(34), np.int64(6)] cl_acc 0.500  0.383sec\n",
      "Epoch 5 tr: l 2.130 a 0.288 clct[np.int64(126), np.int64(114)] cl_acc 0.558  lr 0.100000 5.086sec(train) 1.026sec(infer)\n",
      "Epoch 5 tst: l 2.145 a 0.295 clct[np.int64(36), np.int64(4)] cl_acc 0.550  0.453sec\n",
      "Epoch 6 tr: l 2.023 a 0.391 clct[np.int64(131), np.int64(109)] cl_acc 0.579  lr 0.100000 5.084sec(train) 0.972sec(infer)\n",
      "Epoch 6 tst: l 2.039 a 0.392 clct[np.int64(34), np.int64(6)] cl_acc 0.550  0.437sec\n",
      "Epoch 7 tr: l 1.881 a 0.460 clct[np.int64(136), np.int64(104)] cl_acc 0.592  lr 0.100000 5.038sec(train) 1.033sec(infer)\n",
      "Epoch 7 tst: l 1.899 a 0.458 clct[np.int64(36), np.int64(4)] cl_acc 0.550  0.409sec\n",
      "Epoch 8 tr: l 1.724 a 0.504 clct[np.int64(140), np.int64(100)] cl_acc 0.608  lr 0.100000 4.997sec(train) 0.990sec(infer)\n",
      "Epoch 8 tst: l 1.743 a 0.497 clct[np.int64(33), np.int64(7)] cl_acc 0.625  0.410sec\n",
      "Epoch 9 tr: l 1.581 a 0.538 clct[np.int64(148), np.int64(92)] cl_acc 0.642  lr 0.100000 4.992sec(train) 1.073sec(infer)\n",
      "Epoch 9 tst: l 1.605 a 0.532 clct[np.int64(25), np.int64(15)] cl_acc 0.775  0.431sec\n",
      "Epoch 10 tr: l 1.467 a 0.572 clct[np.int64(142), np.int64(98)] cl_acc 0.742  lr 0.100000 5.164sec(train) 0.969sec(infer)\n",
      "Epoch 10 tst: l 1.487 a 0.564 clct[np.int64(25), np.int64(15)] cl_acc 0.825  0.372sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 11 tr: l 1.355 a 0.611 clct[np.int64(124), np.int64(116)] cl_acc 0.925  lr 0.100000 4.932sec(train) 1.026sec(infer)\n",
      "Epoch 11 tst: l 1.377 a 0.603 clct[np.int64(21), np.int64(19)] cl_acc 0.975  0.428sec\n",
      "Epoch 12 tr: l 1.225 a 0.667 clct[np.int64(121), np.int64(119)] cl_acc 0.988  lr 0.100000 4.564sec(train) 0.885sec(infer)\n",
      "Epoch 12 tst: l 1.245 a 0.657 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.375sec\n",
      "Epoch 13 tr: l 1.097 a 0.711 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.521sec(train) 0.944sec(infer)\n",
      "Epoch 13 tst: l 1.117 a 0.705 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.375sec\n",
      "Epoch 14 tr: l 0.982 a 0.746 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.872sec(train) 0.893sec(infer)\n",
      "Epoch 14 tst: l 1.002 a 0.741 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.369sec\n",
      "Epoch 15 tr: l 0.887 a 0.771 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.079sec(train) 1.040sec(infer)\n",
      "Epoch 15 tst: l 0.905 a 0.768 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.412sec\n",
      "Epoch 16 tr: l 0.810 a 0.790 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.022sec(train) 0.985sec(infer)\n",
      "Epoch 16 tst: l 0.826 a 0.787 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.458sec\n",
      "Epoch 17 tr: l 0.748 a 0.805 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.392sec(train) 0.964sec(infer)\n",
      "Epoch 17 tst: l 0.759 a 0.805 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.394sec\n",
      "Epoch 18 tr: l 0.696 a 0.817 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.727sec(train) 0.947sec(infer)\n",
      "Epoch 18 tst: l 0.704 a 0.818 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.427sec\n",
      "Epoch 19 tr: l 0.654 a 0.827 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.843sec(train) 1.035sec(infer)\n",
      "Epoch 19 tst: l 0.661 a 0.829 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.420sec\n",
      "Epoch 20 tr: l 0.617 a 0.836 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.913sec(train) 0.950sec(infer)\n",
      "Epoch 20 tst: l 0.625 a 0.839 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.424sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 21 tr: l 0.588 a 0.843 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.926sec(train) 1.071sec(infer)\n",
      "Epoch 21 tst: l 0.594 a 0.847 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.417sec\n",
      "Epoch 22 tr: l 0.562 a 0.851 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.804sec(train) 1.063sec(infer)\n",
      "Epoch 22 tst: l 0.566 a 0.853 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.486sec\n",
      "Epoch 23 tr: l 0.539 a 0.857 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.935sec(train) 1.085sec(infer)\n",
      "Epoch 23 tst: l 0.543 a 0.859 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.467sec\n",
      "Epoch 24 tr: l 0.517 a 0.862 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.962sec(train) 1.063sec(infer)\n",
      "Epoch 24 tst: l 0.522 a 0.864 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.453sec\n",
      "Epoch 25 tr: l 0.501 a 0.866 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.540sec(train) 0.961sec(infer)\n",
      "Epoch 25 tst: l 0.503 a 0.869 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.379sec\n",
      "Epoch 26 tr: l 0.484 a 0.870 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.702sec(train) 1.023sec(infer)\n",
      "Epoch 26 tst: l 0.487 a 0.873 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.397sec\n",
      "Epoch 27 tr: l 0.470 a 0.873 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.469sec(train) 0.932sec(infer)\n",
      "Epoch 27 tst: l 0.473 a 0.877 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.379sec\n",
      "Epoch 28 tr: l 0.457 a 0.876 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.626sec(train) 1.001sec(infer)\n",
      "Epoch 28 tst: l 0.460 a 0.880 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.437sec\n",
      "Epoch 29 tr: l 0.447 a 0.879 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.902sec(train) 1.036sec(infer)\n",
      "Epoch 29 tst: l 0.448 a 0.882 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.440sec\n",
      "Epoch 30 tr: l 0.436 a 0.881 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.421sec(train) 0.927sec(infer)\n",
      "Epoch 30 tst: l 0.438 a 0.884 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.418sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 31 tr: l 0.426 a 0.883 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.906sec(train) 0.953sec(infer)\n",
      "Epoch 31 tst: l 0.428 a 0.886 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.404sec\n",
      "Epoch 32 tr: l 0.417 a 0.885 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.159sec(train) 0.883sec(infer)\n",
      "Epoch 32 tst: l 0.419 a 0.888 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.388sec\n",
      "Epoch 33 tr: l 0.410 a 0.887 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.270sec(train) 0.984sec(infer)\n",
      "Epoch 33 tst: l 0.412 a 0.890 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.428sec\n",
      "Epoch 34 tr: l 0.403 a 0.888 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.781sec(train) 0.980sec(infer)\n",
      "Epoch 34 tst: l 0.404 a 0.891 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.427sec\n",
      "Epoch 35 tr: l 0.395 a 0.890 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.028sec(train) 1.156sec(infer)\n",
      "Epoch 35 tst: l 0.398 a 0.892 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.469sec\n",
      "Epoch 36 tr: l 0.390 a 0.891 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.176sec(train) 1.017sec(infer)\n",
      "Epoch 36 tst: l 0.392 a 0.893 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.422sec\n",
      "Epoch 37 tr: l 0.383 a 0.893 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.201sec(train) 1.055sec(infer)\n",
      "Epoch 37 tst: l 0.386 a 0.894 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.443sec\n",
      "Epoch 38 tr: l 0.379 a 0.894 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.248sec(train) 1.088sec(infer)\n",
      "Epoch 38 tst: l 0.382 a 0.895 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.436sec\n",
      "Epoch 39 tr: l 0.373 a 0.895 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.609sec(train) 0.845sec(infer)\n",
      "Epoch 39 tst: l 0.377 a 0.896 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.413sec\n",
      "Epoch 40 tr: l 0.370 a 0.896 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.039sec(train) 0.965sec(infer)\n",
      "Epoch 40 tst: l 0.372 a 0.897 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.391sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 41 tr: l 0.365 a 0.897 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.641sec(train) 0.951sec(infer)\n",
      "Epoch 41 tst: l 0.368 a 0.898 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.416sec\n",
      "Epoch 42 tr: l 0.360 a 0.898 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.202sec(train) 1.038sec(infer)\n",
      "Epoch 42 tst: l 0.364 a 0.899 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.411sec\n",
      "Epoch 43 tr: l 0.357 a 0.899 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.683sec(train) 0.996sec(infer)\n",
      "Epoch 43 tst: l 0.360 a 0.900 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.417sec\n",
      "Epoch 44 tr: l 0.353 a 0.900 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.083sec(train) 0.978sec(infer)\n",
      "Epoch 44 tst: l 0.356 a 0.901 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.427sec\n",
      "Epoch 45 tr: l 0.348 a 0.900 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.248sec(train) 1.011sec(infer)\n",
      "Epoch 45 tst: l 0.354 a 0.901 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.421sec\n",
      "Epoch 46 tr: l 0.346 a 0.901 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.900sec(train) 0.978sec(infer)\n",
      "Epoch 46 tst: l 0.350 a 0.902 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.410sec\n",
      "Epoch 47 tr: l 0.343 a 0.901 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.846sec(train) 1.136sec(infer)\n",
      "Epoch 47 tst: l 0.347 a 0.902 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.476sec\n",
      "Epoch 48 tr: l 0.339 a 0.902 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.820sec(train) 1.025sec(infer)\n",
      "Epoch 48 tst: l 0.345 a 0.903 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.440sec\n",
      "Epoch 49 tr: l 0.338 a 0.903 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.479sec(train) 1.016sec(infer)\n",
      "Epoch 49 tst: l 0.342 a 0.904 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.400sec\n",
      "Epoch 50 tr: l 0.335 a 0.903 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.738sec(train) 1.061sec(infer)\n",
      "Epoch 50 tst: l 0.339 a 0.904 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.422sec\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.904 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.919sec(train) 0.934sec(infer)\n",
      "Epoch 51 tst: l 0.337 a 0.905 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.394sec\n",
      "Epoch 52 tr: l 0.330 a 0.904 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.696sec(train) 0.827sec(infer)\n",
      "Epoch 52 tst: l 0.334 a 0.905 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.348sec\n",
      "Epoch 53 tr: l 0.328 a 0.905 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.933sec(train) 0.904sec(infer)\n",
      "Epoch 53 tst: l 0.332 a 0.906 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.445sec\n",
      "Epoch 54 tr: l 0.326 a 0.905 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.774sec(train) 0.910sec(infer)\n",
      "Epoch 54 tst: l 0.330 a 0.906 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.360sec\n",
      "Epoch 55 tr: l 0.323 a 0.906 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.498sec(train) 1.191sec(infer)\n",
      "Epoch 55 tst: l 0.328 a 0.907 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.623sec\n",
      "Epoch 56 tr: l 0.320 a 0.906 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.439sec(train) 0.980sec(infer)\n",
      "Epoch 56 tst: l 0.326 a 0.907 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.432sec\n",
      "Epoch 57 tr: l 0.318 a 0.907 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.375sec(train) 0.958sec(infer)\n",
      "Epoch 57 tst: l 0.325 a 0.907 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.420sec\n",
      "Epoch 58 tr: l 0.317 a 0.907 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.632sec(train) 1.018sec(infer)\n",
      "Epoch 58 tst: l 0.323 a 0.908 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.447sec\n",
      "Epoch 59 tr: l 0.316 a 0.908 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.127sec(train) 0.976sec(infer)\n",
      "Epoch 59 tst: l 0.321 a 0.908 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.417sec\n",
      "Epoch 60 tr: l 0.314 a 0.908 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.389sec(train) 0.950sec(infer)\n",
      "Epoch 60 tst: l 0.319 a 0.909 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.460sec\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.909 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.241sec(train) 1.103sec(infer)\n",
      "Epoch 61 tst: l 0.318 a 0.910 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.487sec\n",
      "Epoch 62 tr: l 0.309 a 0.909 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.459sec(train) 1.051sec(infer)\n",
      "Epoch 62 tst: l 0.316 a 0.910 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.410sec\n",
      "Epoch 63 tr: l 0.307 a 0.910 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.178sec(train) 0.925sec(infer)\n",
      "Epoch 63 tst: l 0.314 a 0.910 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.389sec\n",
      "Epoch 64 tr: l 0.306 a 0.910 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.868sec(train) 1.033sec(infer)\n",
      "Epoch 64 tst: l 0.313 a 0.911 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.416sec\n",
      "Epoch 65 tr: l 0.305 a 0.911 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.010sec(train) 1.037sec(infer)\n",
      "Epoch 65 tst: l 0.311 a 0.911 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.425sec\n",
      "Epoch 66 tr: l 0.303 a 0.911 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.591sec(train) 1.034sec(infer)\n",
      "Epoch 66 tst: l 0.310 a 0.911 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.455sec\n",
      "Epoch 67 tr: l 0.300 a 0.912 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.546sec(train) 1.055sec(infer)\n",
      "Epoch 67 tst: l 0.309 a 0.912 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.448sec\n",
      "Epoch 68 tr: l 0.299 a 0.912 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.244sec(train) 1.040sec(infer)\n",
      "Epoch 68 tst: l 0.307 a 0.912 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.418sec\n",
      "Epoch 69 tr: l 0.297 a 0.912 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.223sec(train) 1.107sec(infer)\n",
      "Epoch 69 tst: l 0.306 a 0.913 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.464sec\n",
      "Epoch 70 tr: l 0.296 a 0.912 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.275sec(train) 1.085sec(infer)\n",
      "Epoch 70 tst: l 0.305 a 0.913 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.417sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 71 tr: l 0.296 a 0.913 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.009sec(train) 1.100sec(infer)\n",
      "Epoch 71 tst: l 0.303 a 0.913 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.398sec\n",
      "Epoch 72 tr: l 0.294 a 0.913 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.481sec(train) 1.088sec(infer)\n",
      "Epoch 72 tst: l 0.302 a 0.913 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.424sec\n",
      "Epoch 73 tr: l 0.292 a 0.914 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.371sec(train) 0.963sec(infer)\n",
      "Epoch 73 tst: l 0.301 a 0.914 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.396sec\n",
      "Epoch 74 tr: l 0.291 a 0.914 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.043sec(train) 0.976sec(infer)\n",
      "Epoch 74 tst: l 0.300 a 0.914 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.401sec\n",
      "Epoch 75 tr: l 0.290 a 0.914 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.411sec(train) 1.144sec(infer)\n",
      "Epoch 75 tst: l 0.299 a 0.914 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.412sec\n",
      "Epoch 76 tr: l 0.290 a 0.914 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.146sec(train) 1.056sec(infer)\n",
      "Epoch 76 tst: l 0.298 a 0.915 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.419sec\n",
      "Epoch 77 tr: l 0.286 a 0.915 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.200sec(train) 1.072sec(infer)\n",
      "Epoch 77 tst: l 0.296 a 0.915 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.434sec\n",
      "Epoch 78 tr: l 0.286 a 0.915 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.363sec(train) 0.987sec(infer)\n",
      "Epoch 78 tst: l 0.295 a 0.915 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.384sec\n",
      "Epoch 79 tr: l 0.285 a 0.915 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.081sec(train) 1.043sec(infer)\n",
      "Epoch 79 tst: l 0.294 a 0.915 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.311sec\n",
      "Epoch 80 tr: l 0.284 a 0.916 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.510sec(train) 1.026sec(infer)\n",
      "Epoch 80 tst: l 0.293 a 0.916 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.358sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 81 tr: l 0.283 a 0.916 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.413sec(train) 1.245sec(infer)\n",
      "Epoch 81 tst: l 0.292 a 0.916 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.585sec\n",
      "Epoch 82 tr: l 0.282 a 0.916 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 6.126sec(train) 1.014sec(infer)\n",
      "Epoch 82 tst: l 0.291 a 0.917 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.378sec\n",
      "Epoch 83 tr: l 0.280 a 0.917 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.486sec(train) 1.009sec(infer)\n",
      "Epoch 83 tst: l 0.290 a 0.917 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.368sec\n",
      "Epoch 84 tr: l 0.278 a 0.917 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.922sec(train) 0.886sec(infer)\n",
      "Epoch 84 tst: l 0.289 a 0.917 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.371sec\n",
      "Epoch 85 tr: l 0.278 a 0.917 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.578sec(train) 1.021sec(infer)\n",
      "Epoch 85 tst: l 0.288 a 0.918 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.401sec\n",
      "Epoch 86 tr: l 0.277 a 0.917 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.087sec(train) 1.059sec(infer)\n",
      "Epoch 86 tst: l 0.287 a 0.918 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.406sec\n",
      "Epoch 87 tr: l 0.275 a 0.918 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.655sec(train) 0.838sec(infer)\n",
      "Epoch 87 tst: l 0.286 a 0.918 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.363sec\n",
      "Epoch 88 tr: l 0.274 a 0.918 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.280sec(train) 0.892sec(infer)\n",
      "Epoch 88 tst: l 0.286 a 0.919 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.373sec\n",
      "Epoch 89 tr: l 0.274 a 0.918 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.598sec(train) 0.971sec(infer)\n",
      "Epoch 89 tst: l 0.285 a 0.919 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.433sec\n",
      "Epoch 90 tr: l 0.271 a 0.919 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.543sec(train) 1.001sec(infer)\n",
      "Epoch 90 tst: l 0.284 a 0.919 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.369sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 91 tr: l 0.271 a 0.919 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.728sec(train) 0.895sec(infer)\n",
      "Epoch 91 tst: l 0.283 a 0.919 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.402sec\n",
      "Epoch 92 tr: l 0.271 a 0.919 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.634sec(train) 1.009sec(infer)\n",
      "Epoch 92 tst: l 0.282 a 0.920 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.382sec\n",
      "Epoch 93 tr: l 0.269 a 0.919 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.461sec(train) 0.939sec(infer)\n",
      "Epoch 93 tst: l 0.281 a 0.920 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.394sec\n",
      "Epoch 94 tr: l 0.268 a 0.920 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.018sec(train) 1.081sec(infer)\n",
      "Epoch 94 tst: l 0.280 a 0.920 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.399sec\n",
      "Epoch 95 tr: l 0.268 a 0.920 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.263sec(train) 0.892sec(infer)\n",
      "Epoch 95 tst: l 0.279 a 0.920 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.355sec\n",
      "Epoch 96 tr: l 0.267 a 0.920 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 6.163sec(train) 1.049sec(infer)\n",
      "Epoch 96 tst: l 0.279 a 0.921 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.480sec\n",
      "Epoch 97 tr: l 0.264 a 0.921 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.404sec(train) 1.028sec(infer)\n",
      "Epoch 97 tst: l 0.278 a 0.921 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.391sec\n",
      "Epoch 98 tr: l 0.265 a 0.921 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.797sec(train) 0.998sec(infer)\n",
      "Epoch 98 tst: l 0.277 a 0.922 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.432sec\n",
      "Epoch 99 tr: l 0.264 a 0.921 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.405sec(train) 1.056sec(infer)\n",
      "Epoch 99 tst: l 0.276 a 0.922 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.428sec\n",
      "Epoch 100 tr: l 0.264 a 0.921 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.635sec(train) 1.026sec(infer)\n",
      "Epoch 100 tst: l 0.275 a 0.922 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.393sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 101 tr: l 0.262 a 0.922 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.719sec(train) 0.930sec(infer)\n",
      "Epoch 101 tst: l 0.274 a 0.922 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.414sec\n",
      "Epoch 102 tr: l 0.261 a 0.922 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.743sec(train) 1.088sec(infer)\n",
      "Epoch 102 tst: l 0.274 a 0.922 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.462sec\n",
      "Epoch 103 tr: l 0.260 a 0.922 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.787sec(train) 0.913sec(infer)\n",
      "Epoch 103 tst: l 0.273 a 0.922 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.399sec\n",
      "Epoch 104 tr: l 0.259 a 0.922 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.878sec(train) 1.078sec(infer)\n",
      "Epoch 104 tst: l 0.272 a 0.922 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.458sec\n",
      "Epoch 105 tr: l 0.258 a 0.923 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.381sec(train) 1.123sec(infer)\n",
      "Epoch 105 tst: l 0.271 a 0.923 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.461sec\n",
      "Epoch 106 tr: l 0.257 a 0.923 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.514sec(train) 0.981sec(infer)\n",
      "Epoch 106 tst: l 0.270 a 0.923 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.299sec\n",
      "Epoch 107 tr: l 0.255 a 0.923 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.735sec(train) 0.855sec(infer)\n",
      "Epoch 107 tst: l 0.270 a 0.923 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.307sec\n",
      "Epoch 108 tr: l 0.255 a 0.923 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.121sec(train) 0.784sec(infer)\n",
      "Epoch 108 tst: l 0.269 a 0.923 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.316sec\n",
      "Epoch 109 tr: l 0.255 a 0.923 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.802sec(train) 0.731sec(infer)\n",
      "Epoch 109 tst: l 0.268 a 0.924 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.302sec\n",
      "Epoch 110 tr: l 0.253 a 0.924 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.106sec(train) 0.754sec(infer)\n",
      "Epoch 110 tst: l 0.267 a 0.924 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.308sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 111 tr: l 0.253 a 0.924 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.487sec(train) 0.846sec(infer)\n",
      "Epoch 111 tst: l 0.267 a 0.924 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.333sec\n",
      "Epoch 112 tr: l 0.251 a 0.924 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.154sec(train) 0.790sec(infer)\n",
      "Epoch 112 tst: l 0.266 a 0.924 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.351sec\n",
      "Epoch 113 tr: l 0.251 a 0.925 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.232sec(train) 0.867sec(infer)\n",
      "Epoch 113 tst: l 0.265 a 0.924 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.340sec\n",
      "Epoch 114 tr: l 0.251 a 0.925 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.563sec(train) 0.866sec(infer)\n",
      "Epoch 114 tst: l 0.264 a 0.924 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.319sec\n",
      "Epoch 115 tr: l 0.250 a 0.925 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.041sec(train) 0.865sec(infer)\n",
      "Epoch 115 tst: l 0.264 a 0.925 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.353sec\n",
      "Epoch 116 tr: l 0.248 a 0.925 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.208sec(train) 0.801sec(infer)\n",
      "Epoch 116 tst: l 0.263 a 0.925 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.307sec\n",
      "Epoch 117 tr: l 0.247 a 0.925 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.005sec(train) 0.819sec(infer)\n",
      "Epoch 117 tst: l 0.262 a 0.925 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.329sec\n",
      "Epoch 118 tr: l 0.248 a 0.926 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.345sec(train) 0.730sec(infer)\n",
      "Epoch 118 tst: l 0.262 a 0.925 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.308sec\n",
      "Epoch 119 tr: l 0.247 a 0.926 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.316sec(train) 0.827sec(infer)\n",
      "Epoch 119 tst: l 0.261 a 0.925 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.355sec\n",
      "Epoch 120 tr: l 0.246 a 0.926 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.232sec(train) 0.731sec(infer)\n",
      "Epoch 120 tst: l 0.260 a 0.926 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.333sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 121 tr: l 0.245 a 0.926 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.356sec(train) 0.805sec(infer)\n",
      "Epoch 121 tst: l 0.259 a 0.926 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.363sec\n",
      "Epoch 122 tr: l 0.244 a 0.927 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.363sec(train) 0.778sec(infer)\n",
      "Epoch 122 tst: l 0.259 a 0.926 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.314sec\n",
      "Epoch 123 tr: l 0.244 a 0.927 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.686sec(train) 0.696sec(infer)\n",
      "Epoch 123 tst: l 0.258 a 0.926 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.296sec\n",
      "Epoch 124 tr: l 0.243 a 0.927 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.391sec(train) 0.953sec(infer)\n",
      "Epoch 124 tst: l 0.257 a 0.927 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.396sec\n",
      "Epoch 125 tr: l 0.242 a 0.927 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.785sec(train) 0.742sec(infer)\n",
      "Epoch 125 tst: l 0.257 a 0.927 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.301sec\n",
      "Epoch 126 tr: l 0.241 a 0.927 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.417sec(train) 0.785sec(infer)\n",
      "Epoch 126 tst: l 0.256 a 0.927 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.315sec\n",
      "Epoch 127 tr: l 0.241 a 0.927 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.351sec(train) 0.860sec(infer)\n",
      "Epoch 127 tst: l 0.255 a 0.927 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.349sec\n",
      "Epoch 128 tr: l 0.240 a 0.928 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.297sec(train) 0.892sec(infer)\n",
      "Epoch 128 tst: l 0.255 a 0.927 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.311sec\n",
      "Epoch 129 tr: l 0.239 a 0.928 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.128sec(train) 0.821sec(infer)\n",
      "Epoch 129 tst: l 0.254 a 0.927 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.325sec\n",
      "Epoch 130 tr: l 0.236 a 0.928 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.064sec(train) 0.961sec(infer)\n",
      "Epoch 130 tst: l 0.253 a 0.928 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.334sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 131 tr: l 0.238 a 0.928 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.311sec(train) 0.951sec(infer)\n",
      "Epoch 131 tst: l 0.253 a 0.928 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.390sec\n",
      "Epoch 132 tr: l 0.237 a 0.929 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.141sec(train) 0.736sec(infer)\n",
      "Epoch 132 tst: l 0.252 a 0.928 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.309sec\n",
      "Epoch 133 tr: l 0.236 a 0.929 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.195sec(train) 0.822sec(infer)\n",
      "Epoch 133 tst: l 0.252 a 0.928 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.343sec\n",
      "Epoch 134 tr: l 0.235 a 0.929 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.236sec(train) 0.873sec(infer)\n",
      "Epoch 134 tst: l 0.251 a 0.928 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.337sec\n",
      "Epoch 135 tr: l 0.234 a 0.929 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.068sec(train) 0.818sec(infer)\n",
      "Epoch 135 tst: l 0.250 a 0.929 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.317sec\n",
      "Epoch 136 tr: l 0.234 a 0.929 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.418sec(train) 0.800sec(infer)\n",
      "Epoch 136 tst: l 0.250 a 0.929 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.327sec\n",
      "Epoch 137 tr: l 0.232 a 0.930 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.432sec(train) 0.936sec(infer)\n",
      "Epoch 137 tst: l 0.249 a 0.929 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.348sec\n",
      "Epoch 138 tr: l 0.232 a 0.930 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.539sec(train) 0.856sec(infer)\n",
      "Epoch 138 tst: l 0.248 a 0.930 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.341sec\n",
      "Epoch 139 tr: l 0.231 a 0.930 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.423sec(train) 0.753sec(infer)\n",
      "Epoch 139 tst: l 0.248 a 0.929 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.299sec\n",
      "Epoch 140 tr: l 0.230 a 0.930 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.189sec(train) 0.802sec(infer)\n",
      "Epoch 140 tst: l 0.247 a 0.930 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.329sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 141 tr: l 0.228 a 0.931 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.968sec(train) 0.741sec(infer)\n",
      "Epoch 141 tst: l 0.247 a 0.930 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.300sec\n",
      "Epoch 142 tr: l 0.229 a 0.931 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.710sec(train) 0.725sec(infer)\n",
      "Epoch 142 tst: l 0.246 a 0.930 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.308sec\n",
      "Epoch 143 tr: l 0.228 a 0.931 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.954sec(train) 0.795sec(infer)\n",
      "Epoch 143 tst: l 0.245 a 0.930 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.343sec\n",
      "Epoch 144 tr: l 0.227 a 0.931 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.959sec(train) 0.769sec(infer)\n",
      "Epoch 144 tst: l 0.244 a 0.930 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.312sec\n",
      "Epoch 145 tr: l 0.226 a 0.931 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.153sec(train) 0.913sec(infer)\n",
      "Epoch 145 tst: l 0.244 a 0.930 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.370sec\n",
      "Epoch 146 tr: l 0.226 a 0.932 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.009sec(train) 0.670sec(infer)\n",
      "Epoch 146 tst: l 0.243 a 0.931 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.284sec\n",
      "Epoch 147 tr: l 0.225 a 0.932 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.848sec(train) 0.869sec(infer)\n",
      "Epoch 147 tst: l 0.243 a 0.930 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.319sec\n",
      "Epoch 148 tr: l 0.224 a 0.932 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.657sec(train) 0.742sec(infer)\n",
      "Epoch 148 tst: l 0.242 a 0.931 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.307sec\n",
      "Epoch 149 tr: l 0.223 a 0.932 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.686sec(train) 0.662sec(infer)\n",
      "Epoch 149 tst: l 0.241 a 0.931 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.274sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "---train cluster Ended in 0.27 hour (967.465 sec) \n",
      "---------------------------------DFCA-LI, lr: 0.1, seed: 6753---------------------------------\n",
      "config: {'m': 240, 'm_test': 40, 'p': 2, 'n': 500, 'uneven': True, 'local_model_init': True, 'Gp': 0.1, 'graph': 'er', 'agg': 'seq', 'h1': 200, 'num_epochs': 150, 'batch_size': 100, 'tau': 10, 'lr': 0.1, 'data_seed': 6753, 'train_seed': 6753, 'config_override': '', 'project_dir': 'output_dfca_gi'}\n",
      "Using device: cuda:1\n",
      "Epoch -1 tr: l 2.301 a 0.105 clct[np.int64(109), np.int64(131)] cl_acc 0.529  0.983sec\n",
      "Epoch -1 tst: l 2.300 a 0.114 clct[np.int64(17), np.int64(23)] cl_acc 0.525  0.369sec\n",
      "Epoch 0 tr: l 2.275 a 0.350 clct[np.int64(111), np.int64(129)] cl_acc 0.529  lr 0.100000 5.760sec(train) 0.566sec(infer)\n",
      "Epoch 0 tst: l 2.286 a 0.266 clct[np.int64(21), np.int64(19)] cl_acc 0.675  0.290sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 1 tr: l 2.281 a 0.279 clct[np.int64(122), np.int64(118)] cl_acc 0.542  lr 0.100000 5.022sec(train) 0.734sec(infer)\n",
      "Epoch 1 tst: l 2.285 a 0.290 clct[np.int64(22), np.int64(18)] cl_acc 0.750  0.289sec\n",
      "Epoch 2 tr: l 2.275 a 0.213 clct[np.int64(124), np.int64(116)] cl_acc 0.550  lr 0.100000 4.316sec(train) 0.704sec(infer)\n",
      "Epoch 2 tst: l 2.279 a 0.234 clct[np.int64(23), np.int64(17)] cl_acc 0.775  0.281sec\n",
      "Epoch 3 tr: l 2.250 a 0.181 clct[np.int64(123), np.int64(117)] cl_acc 0.554  lr 0.100000 4.558sec(train) 0.779sec(infer)\n",
      "Epoch 3 tst: l 2.259 a 0.199 clct[np.int64(23), np.int64(17)] cl_acc 0.775  0.314sec\n",
      "Epoch 4 tr: l 2.209 a 0.205 clct[np.int64(124), np.int64(116)] cl_acc 0.558  lr 0.100000 4.910sec(train) 0.853sec(infer)\n",
      "Epoch 4 tst: l 2.218 a 0.219 clct[np.int64(25), np.int64(15)] cl_acc 0.825  0.323sec\n",
      "Epoch 5 tr: l 2.138 a 0.291 clct[np.int64(130), np.int64(110)] cl_acc 0.583  lr 0.100000 4.923sec(train) 0.781sec(infer)\n",
      "Epoch 5 tst: l 2.148 a 0.291 clct[np.int64(25), np.int64(15)] cl_acc 0.825  0.294sec\n",
      "Epoch 6 tr: l 2.031 a 0.400 clct[np.int64(156), np.int64(84)] cl_acc 0.692  lr 0.100000 4.927sec(train) 0.762sec(infer)\n",
      "Epoch 6 tst: l 2.037 a 0.392 clct[np.int64(26), np.int64(14)] cl_acc 0.800  0.323sec\n",
      "Epoch 7 tr: l 1.873 a 0.489 clct[np.int64(164), np.int64(76)] cl_acc 0.767  lr 0.100000 4.495sec(train) 0.709sec(infer)\n",
      "Epoch 7 tst: l 1.885 a 0.473 clct[np.int64(25), np.int64(15)] cl_acc 0.875  0.299sec\n",
      "Epoch 8 tr: l 1.697 a 0.555 clct[np.int64(136), np.int64(104)] cl_acc 0.883  lr 0.100000 5.183sec(train) 0.862sec(infer)\n",
      "Epoch 8 tst: l 1.712 a 0.530 clct[np.int64(24), np.int64(16)] cl_acc 0.900  0.379sec\n",
      "Epoch 9 tr: l 1.520 a 0.619 clct[np.int64(120), np.int64(120)] cl_acc 0.975  lr 0.100000 5.614sec(train) 0.864sec(infer)\n",
      "Epoch 9 tst: l 1.537 a 0.593 clct[np.int64(21), np.int64(19)] cl_acc 0.975  0.307sec\n",
      "Epoch 10 tr: l 1.345 a 0.673 clct[np.int64(118), np.int64(122)] cl_acc 0.992  lr 0.100000 5.113sec(train) 0.776sec(infer)\n",
      "Epoch 10 tst: l 1.364 a 0.654 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.324sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 11 tr: l 1.188 a 0.715 clct[np.int64(118), np.int64(122)] cl_acc 0.992  lr 0.100000 5.141sec(train) 0.855sec(infer)\n",
      "Epoch 11 tst: l 1.204 a 0.706 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.332sec\n",
      "Epoch 12 tr: l 1.053 a 0.745 clct[np.int64(119), np.int64(121)] cl_acc 0.996  lr 0.100000 5.358sec(train) 0.824sec(infer)\n",
      "Epoch 12 tst: l 1.064 a 0.739 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.369sec\n",
      "Epoch 13 tr: l 0.938 a 0.769 clct[np.int64(119), np.int64(121)] cl_acc 0.996  lr 0.100000 5.117sec(train) 0.753sec(infer)\n",
      "Epoch 13 tst: l 0.945 a 0.767 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.316sec\n",
      "Epoch 14 tr: l 0.841 a 0.787 clct[np.int64(119), np.int64(121)] cl_acc 0.996  lr 0.100000 5.136sec(train) 0.725sec(infer)\n",
      "Epoch 14 tst: l 0.855 a 0.784 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.303sec\n",
      "Epoch 15 tr: l 0.775 a 0.801 clct[np.int64(119), np.int64(121)] cl_acc 0.996  lr 0.100000 5.222sec(train) 0.802sec(infer)\n",
      "Epoch 15 tst: l 0.783 a 0.800 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.319sec\n",
      "Epoch 16 tr: l 0.718 a 0.813 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.049sec(train) 0.744sec(infer)\n",
      "Epoch 16 tst: l 0.726 a 0.813 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.312sec\n",
      "Epoch 17 tr: l 0.670 a 0.823 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.995sec(train) 0.846sec(infer)\n",
      "Epoch 17 tst: l 0.679 a 0.822 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.331sec\n",
      "Epoch 18 tr: l 0.632 a 0.832 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.421sec(train) 0.737sec(infer)\n",
      "Epoch 18 tst: l 0.641 a 0.831 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.302sec\n",
      "Epoch 19 tr: l 0.600 a 0.840 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.052sec(train) 0.758sec(infer)\n",
      "Epoch 19 tst: l 0.608 a 0.839 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.338sec\n",
      "Epoch 20 tr: l 0.570 a 0.847 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.544sec(train) 0.716sec(infer)\n",
      "Epoch 20 tst: l 0.581 a 0.846 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.303sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 21 tr: l 0.548 a 0.853 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.927sec(train) 0.758sec(infer)\n",
      "Epoch 21 tst: l 0.556 a 0.852 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.308sec\n",
      "Epoch 22 tr: l 0.526 a 0.858 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.233sec(train) 0.887sec(infer)\n",
      "Epoch 22 tst: l 0.535 a 0.857 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.348sec\n",
      "Epoch 23 tr: l 0.508 a 0.863 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.253sec(train) 0.812sec(infer)\n",
      "Epoch 23 tst: l 0.516 a 0.863 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.333sec\n",
      "Epoch 24 tr: l 0.492 a 0.867 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.084sec(train) 0.792sec(infer)\n",
      "Epoch 24 tst: l 0.500 a 0.867 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.338sec\n",
      "Epoch 25 tr: l 0.477 a 0.870 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.329sec(train) 0.726sec(infer)\n",
      "Epoch 25 tst: l 0.486 a 0.871 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.314sec\n",
      "Epoch 26 tr: l 0.465 a 0.873 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.075sec(train) 0.661sec(infer)\n",
      "Epoch 26 tst: l 0.474 a 0.873 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.290sec\n",
      "Epoch 27 tr: l 0.452 a 0.875 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.224sec(train) 0.795sec(infer)\n",
      "Epoch 27 tst: l 0.462 a 0.876 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.341sec\n",
      "Epoch 28 tr: l 0.440 a 0.878 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.020sec(train) 0.808sec(infer)\n",
      "Epoch 28 tst: l 0.451 a 0.880 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.321sec\n",
      "Epoch 29 tr: l 0.430 a 0.880 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.664sec(train) 0.831sec(infer)\n",
      "Epoch 29 tst: l 0.442 a 0.883 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.350sec\n",
      "Epoch 30 tr: l 0.423 a 0.883 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.869sec(train) 0.708sec(infer)\n",
      "Epoch 30 tst: l 0.434 a 0.885 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.314sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 31 tr: l 0.415 a 0.884 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.493sec(train) 0.695sec(infer)\n",
      "Epoch 31 tst: l 0.426 a 0.886 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.301sec\n",
      "Epoch 32 tr: l 0.406 a 0.886 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.773sec(train) 0.707sec(infer)\n",
      "Epoch 32 tst: l 0.419 a 0.888 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.277sec\n",
      "Epoch 33 tr: l 0.401 a 0.888 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.869sec(train) 0.680sec(infer)\n",
      "Epoch 33 tst: l 0.413 a 0.889 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.310sec\n",
      "Epoch 34 tr: l 0.395 a 0.889 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.955sec(train) 0.840sec(infer)\n",
      "Epoch 34 tst: l 0.407 a 0.890 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.347sec\n",
      "Epoch 35 tr: l 0.389 a 0.890 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.745sec(train) 0.784sec(infer)\n",
      "Epoch 35 tst: l 0.401 a 0.892 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.322sec\n",
      "Epoch 36 tr: l 0.382 a 0.892 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.953sec(train) 0.801sec(infer)\n",
      "Epoch 36 tst: l 0.396 a 0.892 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.317sec\n",
      "Epoch 37 tr: l 0.377 a 0.893 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.716sec(train) 0.883sec(infer)\n",
      "Epoch 37 tst: l 0.391 a 0.893 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.329sec\n",
      "Epoch 38 tr: l 0.372 a 0.894 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.780sec(train) 0.829sec(infer)\n",
      "Epoch 38 tst: l 0.387 a 0.894 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.324sec\n",
      "Epoch 39 tr: l 0.368 a 0.895 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.983sec(train) 0.737sec(infer)\n",
      "Epoch 39 tst: l 0.383 a 0.895 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.314sec\n",
      "Epoch 40 tr: l 0.365 a 0.896 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.524sec(train) 0.756sec(infer)\n",
      "Epoch 40 tst: l 0.379 a 0.897 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.285sec\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.897 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.332sec(train) 0.840sec(infer)\n",
      "Epoch 41 tst: l 0.376 a 0.897 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.307sec\n",
      "Epoch 42 tr: l 0.356 a 0.897 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.666sec(train) 0.780sec(infer)\n",
      "Epoch 42 tst: l 0.372 a 0.898 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.291sec\n",
      "Epoch 43 tr: l 0.353 a 0.898 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.663sec(train) 0.719sec(infer)\n",
      "Epoch 43 tst: l 0.368 a 0.899 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.300sec\n",
      "Epoch 44 tr: l 0.349 a 0.899 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.708sec(train) 0.748sec(infer)\n",
      "Epoch 44 tst: l 0.365 a 0.900 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.300sec\n",
      "Epoch 45 tr: l 0.347 a 0.900 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.868sec(train) 0.768sec(infer)\n",
      "Epoch 45 tst: l 0.362 a 0.900 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.321sec\n",
      "Epoch 46 tr: l 0.343 a 0.901 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.127sec(train) 0.874sec(infer)\n",
      "Epoch 46 tst: l 0.359 a 0.901 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.353sec\n",
      "Epoch 47 tr: l 0.341 a 0.901 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.524sec(train) 0.797sec(infer)\n",
      "Epoch 47 tst: l 0.357 a 0.901 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.310sec\n",
      "Epoch 48 tr: l 0.336 a 0.902 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.742sec(train) 0.760sec(infer)\n",
      "Epoch 48 tst: l 0.354 a 0.902 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.307sec\n",
      "Epoch 49 tr: l 0.336 a 0.902 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.415sec(train) 0.693sec(infer)\n",
      "Epoch 49 tst: l 0.352 a 0.903 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.308sec\n",
      "Epoch 50 tr: l 0.332 a 0.903 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.268sec(train) 0.747sec(infer)\n",
      "Epoch 50 tst: l 0.350 a 0.903 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.295sec\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.904 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.432sec(train) 0.735sec(infer)\n",
      "Epoch 51 tst: l 0.347 a 0.904 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.302sec\n",
      "Epoch 52 tr: l 0.326 a 0.904 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.096sec(train) 0.700sec(infer)\n",
      "Epoch 52 tst: l 0.346 a 0.904 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.278sec\n",
      "Epoch 53 tr: l 0.326 a 0.905 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.459sec(train) 0.769sec(infer)\n",
      "Epoch 53 tst: l 0.343 a 0.905 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.277sec\n",
      "Epoch 54 tr: l 0.323 a 0.905 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.385sec(train) 0.783sec(infer)\n",
      "Epoch 54 tst: l 0.341 a 0.906 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.274sec\n",
      "Epoch 55 tr: l 0.320 a 0.906 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.761sec(train) 0.830sec(infer)\n",
      "Epoch 55 tst: l 0.339 a 0.906 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.383sec\n",
      "Epoch 56 tr: l 0.320 a 0.906 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.153sec(train) 0.919sec(infer)\n",
      "Epoch 56 tst: l 0.337 a 0.907 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.370sec\n",
      "Epoch 57 tr: l 0.317 a 0.907 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.760sec(train) 0.792sec(infer)\n",
      "Epoch 57 tst: l 0.335 a 0.907 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.315sec\n",
      "Epoch 58 tr: l 0.316 a 0.907 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.739sec(train) 0.898sec(infer)\n",
      "Epoch 58 tst: l 0.334 a 0.907 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.309sec\n",
      "Epoch 59 tr: l 0.314 a 0.908 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.739sec(train) 0.687sec(infer)\n",
      "Epoch 59 tst: l 0.332 a 0.908 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.280sec\n",
      "Epoch 60 tr: l 0.311 a 0.908 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.587sec(train) 0.747sec(infer)\n",
      "Epoch 60 tst: l 0.331 a 0.908 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.308sec\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.909 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.227sec(train) 0.695sec(infer)\n",
      "Epoch 61 tst: l 0.329 a 0.909 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.289sec\n",
      "Epoch 62 tr: l 0.308 a 0.909 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.433sec(train) 0.737sec(infer)\n",
      "Epoch 62 tst: l 0.328 a 0.909 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.303sec\n",
      "Epoch 63 tr: l 0.307 a 0.909 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.574sec(train) 0.806sec(infer)\n",
      "Epoch 63 tst: l 0.326 a 0.910 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.328sec\n",
      "Epoch 64 tr: l 0.307 a 0.910 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.406sec(train) 0.746sec(infer)\n",
      "Epoch 64 tst: l 0.324 a 0.910 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.314sec\n",
      "Epoch 65 tr: l 0.302 a 0.910 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.970sec(train) 0.690sec(infer)\n",
      "Epoch 65 tst: l 0.324 a 0.910 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.276sec\n",
      "Epoch 66 tr: l 0.302 a 0.911 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.455sec(train) 0.778sec(infer)\n",
      "Epoch 66 tst: l 0.322 a 0.911 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.321sec\n",
      "Epoch 67 tr: l 0.300 a 0.911 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.036sec(train) 0.714sec(infer)\n",
      "Epoch 67 tst: l 0.320 a 0.911 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.318sec\n",
      "Epoch 68 tr: l 0.300 a 0.912 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.935sec(train) 0.677sec(infer)\n",
      "Epoch 68 tst: l 0.319 a 0.911 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.301sec\n",
      "Epoch 69 tr: l 0.298 a 0.912 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.944sec(train) 0.633sec(infer)\n",
      "Epoch 69 tst: l 0.318 a 0.912 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.242sec\n",
      "Epoch 70 tr: l 0.295 a 0.912 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.908sec(train) 0.677sec(infer)\n",
      "Epoch 70 tst: l 0.317 a 0.912 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.272sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 71 tr: l 0.296 a 0.913 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.904sec(train) 0.768sec(infer)\n",
      "Epoch 71 tst: l 0.315 a 0.913 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.297sec\n",
      "Epoch 72 tr: l 0.293 a 0.913 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.160sec(train) 0.689sec(infer)\n",
      "Epoch 72 tst: l 0.315 a 0.913 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.282sec\n",
      "Epoch 73 tr: l 0.293 a 0.913 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.868sec(train) 0.706sec(infer)\n",
      "Epoch 73 tst: l 0.313 a 0.913 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.298sec\n",
      "Epoch 74 tr: l 0.292 a 0.913 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 3.993sec(train) 0.789sec(infer)\n",
      "Epoch 74 tst: l 0.312 a 0.913 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.314sec\n",
      "Epoch 75 tr: l 0.290 a 0.914 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.932sec(train) 0.812sec(infer)\n",
      "Epoch 75 tst: l 0.311 a 0.913 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.344sec\n",
      "Epoch 76 tr: l 0.289 a 0.914 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.036sec(train) 0.732sec(infer)\n",
      "Epoch 76 tst: l 0.310 a 0.914 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.310sec\n",
      "Epoch 77 tr: l 0.287 a 0.915 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.463sec(train) 0.799sec(infer)\n",
      "Epoch 77 tst: l 0.309 a 0.914 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.330sec\n",
      "Epoch 78 tr: l 0.285 a 0.915 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.582sec(train) 0.750sec(infer)\n",
      "Epoch 78 tst: l 0.308 a 0.914 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.366sec\n",
      "Epoch 79 tr: l 0.286 a 0.915 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.779sec(train) 0.693sec(infer)\n",
      "Epoch 79 tst: l 0.307 a 0.914 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.297sec\n",
      "Epoch 80 tr: l 0.281 a 0.916 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.415sec(train) 0.895sec(infer)\n",
      "Epoch 80 tst: l 0.305 a 0.915 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.353sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 81 tr: l 0.283 a 0.916 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.661sec(train) 0.777sec(infer)\n",
      "Epoch 81 tst: l 0.305 a 0.915 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.336sec\n",
      "Epoch 82 tr: l 0.281 a 0.916 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.781sec(train) 0.969sec(infer)\n",
      "Epoch 82 tst: l 0.304 a 0.916 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.374sec\n",
      "Epoch 83 tr: l 0.279 a 0.917 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.948sec(train) 0.714sec(infer)\n",
      "Epoch 83 tst: l 0.303 a 0.915 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.302sec\n",
      "Epoch 84 tr: l 0.279 a 0.917 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.014sec(train) 0.767sec(infer)\n",
      "Epoch 84 tst: l 0.302 a 0.915 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.306sec\n",
      "Epoch 85 tr: l 0.277 a 0.917 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.827sec(train) 0.833sec(infer)\n",
      "Epoch 85 tst: l 0.301 a 0.916 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.348sec\n",
      "Epoch 86 tr: l 0.277 a 0.917 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.870sec(train) 0.713sec(infer)\n",
      "Epoch 86 tst: l 0.300 a 0.916 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.285sec\n",
      "Epoch 87 tr: l 0.275 a 0.918 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.564sec(train) 0.785sec(infer)\n",
      "Epoch 87 tst: l 0.299 a 0.916 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.313sec\n",
      "Epoch 88 tr: l 0.275 a 0.918 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.616sec(train) 0.719sec(infer)\n",
      "Epoch 88 tst: l 0.298 a 0.917 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.294sec\n",
      "Epoch 89 tr: l 0.275 a 0.918 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.042sec(train) 0.771sec(infer)\n",
      "Epoch 89 tst: l 0.297 a 0.917 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.341sec\n",
      "Epoch 90 tr: l 0.273 a 0.918 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.561sec(train) 0.705sec(infer)\n",
      "Epoch 90 tst: l 0.296 a 0.917 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.299sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 91 tr: l 0.272 a 0.918 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.073sec(train) 0.718sec(infer)\n",
      "Epoch 91 tst: l 0.295 a 0.918 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.297sec\n",
      "Epoch 92 tr: l 0.271 a 0.919 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.139sec(train) 0.737sec(infer)\n",
      "Epoch 92 tst: l 0.294 a 0.918 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.274sec\n",
      "Epoch 93 tr: l 0.268 a 0.919 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.451sec(train) 0.767sec(infer)\n",
      "Epoch 93 tst: l 0.294 a 0.918 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.295sec\n",
      "Epoch 94 tr: l 0.268 a 0.920 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.618sec(train) 0.737sec(infer)\n",
      "Epoch 94 tst: l 0.293 a 0.918 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.300sec\n",
      "Epoch 95 tr: l 0.269 a 0.919 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.680sec(train) 0.673sec(infer)\n",
      "Epoch 95 tst: l 0.292 a 0.918 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.282sec\n",
      "Epoch 96 tr: l 0.266 a 0.920 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.634sec(train) 0.707sec(infer)\n",
      "Epoch 96 tst: l 0.291 a 0.919 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.292sec\n",
      "Epoch 97 tr: l 0.267 a 0.920 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.771sec(train) 0.650sec(infer)\n",
      "Epoch 97 tst: l 0.290 a 0.919 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.304sec\n",
      "Epoch 98 tr: l 0.264 a 0.920 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.327sec(train) 0.658sec(infer)\n",
      "Epoch 98 tst: l 0.290 a 0.919 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.281sec\n",
      "Epoch 99 tr: l 0.263 a 0.921 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.019sec(train) 0.647sec(infer)\n",
      "Epoch 99 tst: l 0.289 a 0.919 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.269sec\n",
      "Epoch 100 tr: l 0.262 a 0.921 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.608sec(train) 0.858sec(infer)\n",
      "Epoch 100 tst: l 0.288 a 0.920 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.342sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 101 tr: l 0.263 a 0.921 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.015sec(train) 0.786sec(infer)\n",
      "Epoch 101 tst: l 0.287 a 0.920 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.339sec\n",
      "Epoch 102 tr: l 0.260 a 0.921 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.038sec(train) 0.798sec(infer)\n",
      "Epoch 102 tst: l 0.286 a 0.920 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.326sec\n",
      "Epoch 103 tr: l 0.260 a 0.922 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.426sec(train) 0.682sec(infer)\n",
      "Epoch 103 tst: l 0.285 a 0.920 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.280sec\n",
      "Epoch 104 tr: l 0.259 a 0.922 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.831sec(train) 0.751sec(infer)\n",
      "Epoch 104 tst: l 0.285 a 0.921 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.289sec\n",
      "Epoch 105 tr: l 0.259 a 0.922 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.656sec(train) 0.840sec(infer)\n",
      "Epoch 105 tst: l 0.284 a 0.921 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.343sec\n",
      "Epoch 106 tr: l 0.258 a 0.923 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.497sec(train) 0.721sec(infer)\n",
      "Epoch 106 tst: l 0.283 a 0.921 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.300sec\n",
      "Epoch 107 tr: l 0.257 a 0.923 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.910sec(train) 0.718sec(infer)\n",
      "Epoch 107 tst: l 0.282 a 0.922 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.288sec\n",
      "Epoch 108 tr: l 0.257 a 0.923 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.094sec(train) 0.922sec(infer)\n",
      "Epoch 108 tst: l 0.282 a 0.921 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.305sec\n",
      "Epoch 109 tr: l 0.255 a 0.923 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.061sec(train) 0.781sec(infer)\n",
      "Epoch 109 tst: l 0.281 a 0.922 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.342sec\n",
      "Epoch 110 tr: l 0.254 a 0.923 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.377sec(train) 0.745sec(infer)\n",
      "Epoch 110 tst: l 0.280 a 0.922 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.321sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 111 tr: l 0.255 a 0.923 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.459sec(train) 0.859sec(infer)\n",
      "Epoch 111 tst: l 0.279 a 0.922 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.338sec\n",
      "Epoch 112 tr: l 0.252 a 0.924 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.180sec(train) 0.874sec(infer)\n",
      "Epoch 112 tst: l 0.279 a 0.922 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.346sec\n",
      "Epoch 113 tr: l 0.253 a 0.924 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.894sec(train) 0.702sec(infer)\n",
      "Epoch 113 tst: l 0.278 a 0.922 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.267sec\n",
      "Epoch 114 tr: l 0.251 a 0.924 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.198sec(train) 0.804sec(infer)\n",
      "Epoch 114 tst: l 0.277 a 0.923 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.339sec\n",
      "Epoch 115 tr: l 0.250 a 0.925 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.584sec(train) 0.800sec(infer)\n",
      "Epoch 115 tst: l 0.277 a 0.923 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.342sec\n",
      "Epoch 116 tr: l 0.250 a 0.925 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.908sec(train) 0.713sec(infer)\n",
      "Epoch 116 tst: l 0.276 a 0.923 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.283sec\n",
      "Epoch 117 tr: l 0.248 a 0.925 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.485sec(train) 0.732sec(infer)\n",
      "Epoch 117 tst: l 0.275 a 0.924 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.307sec\n",
      "Epoch 118 tr: l 0.248 a 0.925 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.408sec(train) 0.946sec(infer)\n",
      "Epoch 118 tst: l 0.274 a 0.923 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.363sec\n",
      "Epoch 119 tr: l 0.248 a 0.925 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 6.408sec(train) 0.942sec(infer)\n",
      "Epoch 119 tst: l 0.273 a 0.924 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.350sec\n",
      "Epoch 120 tr: l 0.246 a 0.926 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.173sec(train) 0.875sec(infer)\n",
      "Epoch 120 tst: l 0.273 a 0.924 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.369sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 121 tr: l 0.245 a 0.926 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.460sec(train) 0.858sec(infer)\n",
      "Epoch 121 tst: l 0.272 a 0.924 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.374sec\n",
      "Epoch 122 tr: l 0.245 a 0.926 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.404sec(train) 0.891sec(infer)\n",
      "Epoch 122 tst: l 0.272 a 0.924 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.360sec\n",
      "Epoch 123 tr: l 0.243 a 0.926 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.921sec(train) 0.732sec(infer)\n",
      "Epoch 123 tst: l 0.271 a 0.924 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.313sec\n",
      "Epoch 124 tr: l 0.243 a 0.927 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.600sec(train) 0.699sec(infer)\n",
      "Epoch 124 tst: l 0.270 a 0.924 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.285sec\n",
      "Epoch 125 tr: l 0.242 a 0.927 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.999sec(train) 0.806sec(infer)\n",
      "Epoch 125 tst: l 0.270 a 0.925 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.322sec\n",
      "Epoch 126 tr: l 0.241 a 0.927 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.140sec(train) 0.833sec(infer)\n",
      "Epoch 126 tst: l 0.269 a 0.925 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.336sec\n",
      "Epoch 127 tr: l 0.240 a 0.928 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.359sec(train) 1.108sec(infer)\n",
      "Epoch 127 tst: l 0.268 a 0.925 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.386sec\n",
      "Epoch 128 tr: l 0.240 a 0.927 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.299sec(train) 0.808sec(infer)\n",
      "Epoch 128 tst: l 0.267 a 0.926 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.329sec\n",
      "Epoch 129 tr: l 0.238 a 0.928 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.607sec(train) 0.742sec(infer)\n",
      "Epoch 129 tst: l 0.266 a 0.926 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.291sec\n",
      "Epoch 130 tr: l 0.239 a 0.928 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.503sec(train) 0.730sec(infer)\n",
      "Epoch 130 tst: l 0.266 a 0.926 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.287sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 131 tr: l 0.238 a 0.928 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.821sec(train) 0.756sec(infer)\n",
      "Epoch 131 tst: l 0.265 a 0.926 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.285sec\n",
      "Epoch 132 tr: l 0.236 a 0.928 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.730sec(train) 0.882sec(infer)\n",
      "Epoch 132 tst: l 0.265 a 0.926 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.325sec\n",
      "Epoch 133 tr: l 0.236 a 0.929 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.650sec(train) 0.778sec(infer)\n",
      "Epoch 133 tst: l 0.264 a 0.926 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.331sec\n",
      "Epoch 134 tr: l 0.235 a 0.929 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.109sec(train) 0.826sec(infer)\n",
      "Epoch 134 tst: l 0.263 a 0.927 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.325sec\n",
      "Epoch 135 tr: l 0.235 a 0.929 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.488sec(train) 0.802sec(infer)\n",
      "Epoch 135 tst: l 0.262 a 0.927 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.331sec\n",
      "Epoch 136 tr: l 0.234 a 0.929 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.567sec(train) 0.701sec(infer)\n",
      "Epoch 136 tst: l 0.262 a 0.927 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.296sec\n",
      "Epoch 137 tr: l 0.233 a 0.930 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.235sec(train) 0.768sec(infer)\n",
      "Epoch 137 tst: l 0.261 a 0.927 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.250sec\n",
      "Epoch 138 tr: l 0.232 a 0.930 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.551sec(train) 0.507sec(infer)\n",
      "Epoch 138 tst: l 0.261 a 0.927 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.207sec\n",
      "Epoch 139 tr: l 0.232 a 0.930 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.346sec(train) 0.741sec(infer)\n",
      "Epoch 139 tst: l 0.260 a 0.928 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.314sec\n",
      "Epoch 140 tr: l 0.231 a 0.930 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.126sec(train) 0.798sec(infer)\n",
      "Epoch 140 tst: l 0.260 a 0.928 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.301sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 141 tr: l 0.230 a 0.931 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.912sec(train) 0.647sec(infer)\n",
      "Epoch 141 tst: l 0.259 a 0.928 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.263sec\n",
      "Epoch 142 tr: l 0.229 a 0.931 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.631sec(train) 0.630sec(infer)\n",
      "Epoch 142 tst: l 0.258 a 0.928 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.262sec\n",
      "Epoch 143 tr: l 0.229 a 0.931 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.066sec(train) 0.736sec(infer)\n",
      "Epoch 143 tst: l 0.257 a 0.928 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.353sec\n",
      "Epoch 144 tr: l 0.227 a 0.931 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.949sec(train) 0.654sec(infer)\n",
      "Epoch 144 tst: l 0.257 a 0.929 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.252sec\n",
      "Epoch 145 tr: l 0.226 a 0.931 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.938sec(train) 0.722sec(infer)\n",
      "Epoch 145 tst: l 0.256 a 0.929 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.292sec\n",
      "Epoch 146 tr: l 0.227 a 0.932 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.157sec(train) 0.960sec(infer)\n",
      "Epoch 146 tst: l 0.255 a 0.929 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.360sec\n",
      "Epoch 147 tr: l 0.226 a 0.932 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.802sec(train) 0.675sec(infer)\n",
      "Epoch 147 tst: l 0.255 a 0.929 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.279sec\n",
      "Epoch 148 tr: l 0.225 a 0.932 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 4.752sec(train) 0.544sec(infer)\n",
      "Epoch 148 tst: l 0.254 a 0.929 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.218sec\n",
      "Epoch 149 tr: l 0.224 a 0.932 clct[np.int64(120), np.int64(120)] cl_acc 1.000  lr 0.100000 5.461sec(train) 0.504sec(infer)\n",
      "Epoch 149 tst: l 0.254 a 0.929 clct[np.int64(20), np.int64(20)] cl_acc 1.000  0.219sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "---train cluster Ended in 0.25 hour (897.195 sec) \n"
     ]
    }
   ],
   "source": [
    "___.display_outputs()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Plots"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-20T07:17:14.254232Z",
     "iopub.status.busy": "2025-09-20T07:17:14.253769Z",
     "iopub.status.idle": "2025-09-20T07:17:16.227235Z",
     "shell.execute_reply": "2025-09-20T07:17:16.226010Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "DFCA-GI Acc:  [np.float64(93.6025), np.float64(93.75), np.float64(93.785), np.float64(93.815), np.float64(93.75)]\n",
      "DFCA-LI Acc:  [np.float64(93.0025), np.float64(92.92), np.float64(93.00500000000001), np.float64(93.085), np.float64(92.915)]\n",
      "IFCA Acc:  [np.float64(93.805), np.float64(93.93), np.float64(93.925), np.float64(93.86), np.float64(93.77499999999999)]\n",
      "DFedAvgM Acc:  [np.float64(91.29), np.float64(91.34), np.float64(91.21000000000001), np.float64(91.69500000000001), np.float64(91.685)]\n",
      "DFCA-GI Avg Acc (%):  [0.937405]\n",
      "DFCA-LI Avg Acc (%):  [0.9298550000000001]\n",
      "IFCA Avg Acc (%):  [0.9385900000000001]\n",
      "DFedAvgM Avg Acc (%):  [0.9144399999999999]\n",
      "DFCA-GI Std:  0.07315052973150314\n",
      "DFCA-LI Std:  0.06297618597533189\n",
      "IFCA Std:  0.06224146527838381\n",
      "DFedAvgM Std:  0.20511947737842862\n"
     ]
    },
    {
     "data": {
      "image/png": "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WpaORPXeOlTvrUP13jpU761D9d46VO+tQ/UeGsYYCgoKyMjIwG6vexSbWtxamN1up0ePHq1djCCJiYn6gWsFqvfWoXpvHar31qF6bx2q99ahem8dqvemO1JLm58mJxEREREREQlzCm4iIiIiIiJhTsGtA4uKiuKee+4hKiqqtYvSoajeW4fqvXWo3luH6r11qN5bh+q9dajeW54mJxEREREREQlzanETEREREREJcwpuIiIiIiIiYU7BTUREREREJMwpuImIiIiIiIQ5BbcOqKCggNmzZzN8+HDi4+NJSkriuOOO49FHH6WsrKy1i9fmHDp0iBdffJHLL7+cIUOGEBcXR1RUFD169OCCCy7gnXfeOeI99JmEzoMPPojNZgs86qJ6b5r8/Hweeughxo4dS+fOnQPf96eeeiqzZ88mNze3xutU7403f/58Lr74Ynr37k10dDQxMTH07duXyy67jC+++KLOa1Xv1RUXF/PRRx/xl7/8hQsvvJDevXsH/u2YPXt2ve6xb98+brvtNgYOHEhMTAydOnVi/PjxPPfcc9Rn/retW7dy3XXXkZmZSXR0NJ07d+bMM8/krbfeauJXF76aUu+7du3iySef5KKLLuKoo44iJiaGmJgYMjMzmT59OgsXLqxXGZr6ubVFofh+r+r6668P3KNPnz5HPL8j1ntIGelQsrOzTZ8+fQxgABMbG2uioqICr0eOHGlycnJau5htSkRERKD+ABMdHW3i4uKC9p111lmmqKioxuv1mYTOxo0bTXR0dFDd10b13jQLFy40Xbt2DdRXZGSkSU5ODqr71atXV7tO9d44Pp/PXHfddUH1GxMTY2JiYoL23XLLLTVer3qv2aJFi4Lqr/LjnnvuOeL1K1asMKmpqYFr4uPjg/5POPPMM43L5ar1+g8++MDExsYGzk9MTDR2uz3w+qqrrjI+ny+EX3F4aGy979ixw9hstqDzY2Njq/0cXH311cbj8dR6n6Z+bm1VU7/fq1q4cGHQ59G7d+86z++o9R5KCm4diNvtNsOHDzeA6datm5k/f74xxhiv12vmzJljEhISDGDOPvvsVi5p2wKY448/3jz55JNm69atgf1ZWVnmmmuuCfyDdPnll1e7Vp9J6Hi9XjN27FgDmDFjxtQZ3FTvTbNkyZLAL0oXXnihWb58eeCXy6KiIvPtt9+aO++802zbti3oOtV7473wwguB7+mpU6eazZs3B45t3LjRnH/++YHjb7/9dtC1qvfaLVq0yKSkpJiJEyeaWbNmmTfeeMOkp6fX6xfZ3NzcwLmDBg0yy5cvN8YY43K5zD//+U/jdDoNYG644YYar9+2bVvgj3zjxo0zmzZtMsYYU1BQYO6+++7A5/nQQw+F9GsOB42t96ysLAOYiRMnmpdfftns2rXLGGN9L69bty7o5+Cuu+6q8R5N/dzasqZ8v1dVVFRk+vXrZ5xOpzn22GOPGNw6cr2HkoJbB/Lcc88F/kH76quvqh1//fXXA8c/++yzVihh27Rw4cI6j1f+K/mOHTuCjukzCZ2//e1vBjCXXXaZueeee+oMbqr3xisqKjJ9+/Y1gPnNb37ToGtV7403YcIEA5ijjjrKuN3uasfLysoCn8sll1wSdEz1XruaWmV69+5dr19k77rrrkDLZ9U/UhhjzP33328A43A4AqGssssvv9wAJj093Rw+fLja8WuvvTbQCtfeWkMbW++5ublm5cqVtR73+Xxm8uTJgdackpKSauc09XNry5ry/V7VzTffbABz5513mhkzZhwxuHXkeg8lBbcOZPz48QYwp556ao3HfT6fyczMNIC54oorWrh07de3335b61/C9ZmEhv8v16mpqWb//v1HDG6q98Z76qmnAr9s1vRLUV1U7403cOBAA5gpU6bUes6FF15oAHPuuecG7Ve9N0x9f5Ht1atXoDtjTQoKCkx8fLwBzN133x10rLCwMNBqfe+999Z4vb91CTAvvPBCo76WtqSxAaKquXPnBupt1apV1Y435XNrjxpT78uWLTN2u90MGDDAlJSU1Cu4qd5DQ5OTdBDFxcUsXboUgLPOOqvGc2w2G5MnTwbg008/bbGytXfR0dGBba/XG9jWZxI6M2fOpKioiMcee4zOnTvXea7qvWleeeUVAC666KKg7+0jUb03Td++fQH4/vvv8Xg81Y673W6+++47AI499tjAftV789i0aRM7duwAaq/X+Ph4xo8fD1Sv1yVLllBSUlLn9X369GHw4ME1Xi+1q+3/XGj65ybgcrm4+uqrMcbwzDPP1Ov/AdV76Ci4dRAbNmzA5/MBMGzYsFrP8x/bu3cvOTk5LVK29u7zzz8PbA8fPjywrc8kNJ599lkWLFjApEmTuOKKK454vuq98VwuFytWrABg9OjR7Nixg2uvvZaePXsSGRlJ165dOe+88/jggw+qXat6b5obbrgBgC1btjB9+nS2bNkSOLZp0yYuvvhitm3bRr9+/bjlllsCx1TvzeOHH34IbNenXtevX9+k69etW9eocnZE/v9zIyMjGTBgQNCxpn5uAn/605/YsGED11xzDaecckq9rlG9h46CWwexe/fuwHb37t1rPa/yscrXSOPk5ubywAMPADB+/HgGDhwYOKbPpOl27drFrFmziImJ4emnn67XNar3xsvOzg5MG79t2zaGDRvGs88+y/79+4mLi2P//v28//77nHvuucycOTNoamfVe9Ocd955PP7440RGRjJv3jz69+9PbGwssbGxDBo0iM8//5wbbriBb7/9lsTExMB1qvfm0dB6zc/Pp7CwsNr1KSkpxMTEHPF6fSb1k5WVxVNPPQXAtGnTgn4WoOmfW0e3evVq/vrXv9K1a1cefvjhel+neg8dBbcOoqCgILAdGxtb63mVj1W+RhrO5/Pxi1/8gj179hAdHc0///nPoOP6TJruuuuuIy8vj9mzZwe6kh2J6r3xDh8+HNj+y1/+gtPp5M0336SwsJDDhw+zfft2LrroIgCee+45Hn/88cD5qvemu/nmm3n77bfp0qULACUlJYHudmVlZRQWFpKXlxd0jeq9eTS1Xv3bdV1b+bg+kyMrKSnhoosuori4mLS0NB588MFq5+jnofE8Hg9XX301Ho+H//u//yM5Obne16reQ0fBTaSZ3HTTTbz//vsAPPHEExx99NGtXKL25d///jcffPABI0aM4NZbb23t4nQI/i53/u3nn3+eqVOn4nQ6AejVqxdz5szhmGOOAeD++++vcTyWNFxxcTHTpk3j3HPPpVevXnz66accOHCAAwcO8OmnnzJkyBBeffVVjj/+eNasWdPaxRVpUR6Ph0svvZSVK1fidDp57bXXyMjIaO1itSsPPvgg3333Heeeey4XX3xxaxenw1Jw6yASEhIC28XFxbWeV/lY5WukYW6//fZAC9vjjz/O1VdfXe0cfSaNt2/fPm6++WYcDgfPPvssERER9b5W9d54leuhf//+XHDBBdXOsdvt3H777QAcOnSIlStXVrtW9d5ws2bNYu7cuQwcOJDFixdz+umnk5aWRlpaGqeffjpffvklAwYM4ODBg9x4442B61TvzaOp9erfruvaysf1mdTO6/Vy2WWX8d///peIiAhef/11zjjjjBrP1c9D46xfv54///nPxMfH8+STTzb4etV76Ci4dRCV//K0a9euWs+rfEx/rWqc3/3udzz66KMAPPLII9x88801nqfPpPH+8Ic/cOjQIa699loGDRpEYWFh0MM/Dguotk/13niVxyYMGjSo1vOGDBkS2N6+fTugem+KgoICnnnmGQBuvPHGGmdxi4mJ4de//jVgzVi4f/9+QPXeXBpar4mJicTHx1e7/vDhw4HurnVdr8+kZl6vl8svv5y5c+ficDj497//zdSpU2s9v6mfW0d14403UlZWxp133klKSkq1/3P9PSuMMYF9brc7cL3qPXQU3DqIwYMHY7dbH3fl2X2q8h9LT0+nU6dOLVK29mTWrFmBAbt//etfue2222o9V59J42VlZQHwr3/9i4SEhGoP/4QwQGDf7373O0D13hSdOnWqc2C5X+VJSWw2G6B6b4rNmzcHfjHq169fref1798/sO3/GVG9N4/KM+PVp14r/zGjMdcPHTq0UeVsz/wtbXPmzAmEtmnTptV5TVM/t47K/+/JHXfcUeP/ua+99hoAO3bsCOx74oknAter3kNHwa2DiI2NZdy4cQB8/PHHNZ5jjOGTTz4BqLWbgdTu9ttv55FHHgGs0DZr1qw6z9dn0jpU703jr48NGzbUek7lqZwzMzMB1XtT+IMXVLRg1mTfvn2BbX83I9V78xgwYAC9evUCaq/XoqIiFi9eDFSv15NOOikwm2Rt12/fvj3wc6bPJZjX6+XSSy/lP//5TyC0XXLJJUe8rqmfmzSO6j2EWm3pb2lxzz33nAGMzWYzX3/9dbXj//nPfwxgAPPZZ5+1Qgnbrttuuy1Qd4888ki9r9Nn0jzuueeeQL3VRPXeeF9++WWgbt55551qx71erzn66KMNYLp37268Xm/gmOq9cYqLi01MTIwBzKhRo4zb7a52jsfjMWPHjjWASUlJMR6PJ3BM9d4wvXv3NoC555576jzvrrvuMoCJjY01WVlZ1Y4/9NBDBjAOh8Ns2rSp2vHLL7/cAKZbt24mNze32vEbbrjBACYhIcHk5OQ09stpM+pb7x6Px0ybNs0AJiIiwsyZM6dB79PUz629qW+912XGjBkGML179671HNV7aCi4dSBut9sMHz488AuV/z9or9dr5s6daxITEw1gzjrrrFYuadsya9aswC89jz32WIOu1WfSPI4U3FTvTTN16lQDmNTUVDNv3rxAkNi+fbu5+OKLA3X/0ksvBV2nem+83/zmN4F6nTx5slmzZo3xer3G6/Wa77//3pxxxhmB4/fee2/Qtar3uuXk5JgDBw4EHj179jSAmTVrVtD+goKCoOtyc3NNenq6AcyQIUPMihUrjDHGuFwu8+STT5rIyEgDmBtuuKHG9922bZuJi4szgBk/frzZvHmzMcaYwsJCc++99xqbzWYA89BDDzVvBbSSxtS7x+Mxl1xySSC0zZ07t8Hv29TPra1r7Pd7XeoT3Dp6vYeKglsHk5WVZfr06RP4Dz42NtZER0cHXo8cObJD/GUvVLZv3x6oO7vdbrp27Vrn4+GHH652D30moXek4GaM6r0pCgsLzcknnxyoq6ioKJOSkhJ4Xddfb1XvjVNcXGwmT54cVMdRUVEmKioqaN/06dODWtv8VO+187c4HOkxY8aMateuWLHCpKamBs5JSEgwTqcz8PqMM84wpaWltb73Bx98YGJjYwPnJyUlGYfDEXh91VVXGZ/P14xffetpTL1/8cUXgf1Op/OI/+fW1hrX1M+tLWvK93tt6hPcjOnY9R4qGuPWwfTp04c1a9Zw9913M2zYMGw2G06nk9GjR/PII4/w9ddfk5KS0trFbDOqrmu1b9++Oh+FhYXV7qHPpHWo3hsvLi6ORYsW8eyzz3LyyScTFxdHYWEh3bt355JLLmHp0qXMnj27xmtV740TExPDhx9+yJtvvsn5559Pjx49ApPA9OzZkylTpvD+++/z+uuv43A4ql2vem8eo0ePZt26ddxyyy30798ft9tNXFwcJ510Es8++ywfffQRUVFRtV5/9tlns2bNGmbOnEmfPn0oLS0lJSWF008/nXnz5vHCCy8EJviR4P9z3W73Ef/PrW3GzqZ+btI4qvemsxlTafovERERERERCTtqcRMREREREQlzCm4iIiIiIiJhTsFNREREREQkzCm4iYiIiIiIhDkFNxERERERkTCn4CYiIiIiIhLmFNxERERERETCnIKbiIiIiIhImFNwExERERERCXMKbiIiIiIiImFOwU1ERKSdmzBhAjabjQkTJrR2UUREpJEU3ERERERERMKcgpuIiIiIiEiYU3ATEREREREJcwpuIiIiIiIiYU7BTUREREREJMwpuImISIewaNEi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",
      "text/plain": [
       "<Figure size 1000x800 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA24AAALeCAYAAADS7EKmAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjMsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvZiW1igAAAAlwSFlzAAAPYQAAD2EBqD+naQAA+QlJREFUeJzs3Xd8U1X/B/DPbWZHkm66oLRIAZlSNvIwRBAEFReIIqCgqKA+igqiAuqDC/Vxoj4iIDIEF0vGj6WC7L1ktWV0QPdeae7vjzShaZI2bXOTjs/79eqr6b3nnnuSlpJvzznfryCKoggiIiIiIiKqtzzcPQAiIiIiIiKqGgM3IiIiIiKieo6BGxERERERUT3HwI2IiIiIiKieY+BGRERERERUzzFwIyIiIiIiqucYuBEREREREdVzDNyIiIiIiIjqOQZuRERERERE9RwDNyJyiwkTJkAQBIuPAQMGuHtYRNTAJSQkWP1uEQQBO3fudNuYXnnlFYuxNGvWDIWFhVbtWrZsaTXuOXPmuH7AZNeHH35o8f3RarVISUlx97CoiWDgRlSP2fpPvC4fEyZMcPdTapBsBZmCICAhIcHdQ6NGZufOnXX6N+7O4IRsO3v2LD7++GOLYy+88AI8PT3dNCL3+OOPPzBt2jR07NgRgYGBUKlUCAsLQ69evTB79mycPXtWkvsWFRVh3759+OKLLzBx4kR07NgRcrm81n84nDJlCgICAsxf5+bm4qWXXpJk7ESVyd09ACIiIqLGaubMmSgtLTV/7efnh6efftqNI3KtxMRETJ48GRs3brQ6l5ycjOTkZOzbtw/z5s3DM888g/fffx9KpdJp92/fvj3i4uKc1p+3tzeee+45vPHGG+Zjy5Ytw4svvoguXbo47T5EtnDGjYjcIioqCrGxsRYfbdq0cfewiIic5tChQ/j1118tjk2ZMgUajcZNI3KthIQE/Otf/7IZtFWm1+vxySef4J577kFxcbHTxlBWVua0vkymTZtmMWMqiiJef/11p9+HqDLOuBHVY506dUJgYKDNc0lJSUhOTrY6HhMTY/dNQVRUlFPHVxezZ8/G7Nmz3T0MogYhNDQUYWFh1bZrKgFBQ/Hee+9ZHXv00UfdMBLXKysrw5gxY2zOdvn7+yM0NBRxcXFWe/02btyI1157DR988IFkY1MqlSgpKan19b6+vhg5ciRWrVplPrZhwwacPn0aN998szOGSGQTAzeiemzt2rV2z82ZMwdz5861Ov71118zyQdRI/PEE08wSUUDk5iYiF9++cXi2C233IK2bdu6aUSu9c0332Dfvn1Wx9944w28/vrrkMvlyM7OxsMPP4wNGzZYtPn4448xfvx4dOjQoc7jiIyMRGxsLLp164Zu3bohNjYWL7zwApYsWVKnfseOHWsRuImiiM8++wwLFiyo65CJ7OJSSaImorpMa//3f/+HMWPGIDIyEmq12irRwalTp7BkyRI899xzGDhwIDp06IDw8HB4enpCrVYjODgYXbt2xcSJE/Hbb79Z7OmwxdGsktWN+/Dhw5g8eTJatWoFT09P+Pr6onfv3vjvf/9bp7+oukJRUREWL16MsWPHok2bNvDz84NCoUBgYCA6duyISZMmYc2aNTAYDNX2pdfrsXLlSowdOxYdO3aEr68vFAoFNBoNWrZsiW7duuGBBx7A22+/je3bt9vMaGfyxx9/4JlnnkGPHj0QFBQEtVoNtVqN8PBwdO7cGcOHD8eMGTPw66+/Ii0trU6vwZw5c6y+ty1btgRg/Iv9t99+i9tuuw0hISFQq9Vo0aIFxo0bZ/MNoT2ZmZn45JNPMGrUKERFRUGr1ZoTIwwYMABvvvkmkpKSquyjrv9+3GnAgAF2ExVlZGTgrbfeQmxsLPz8/ODt7Y127drhxRdfxNWrVx2+x8mTJzFz5kz069cPYWFhUKvV8Pb2RvPmzTFkyBC8/fbbNeoPAC5evIg333wTd9xxByIjI6HVas0/A927d8fjjz+OZcuWITc3t0b9njp1Ck8//TRuuukmSX9nLF261GqZ3tixY53S9+LFi23+PALGfzcLFy7E4MGDERoaak7E4Wqff/651bHevXtj7ty5kMuN8wY6nQ7ff/89vLy8LNqVlZXhq6++cso4/vjjD/z888+YOXMmbr/9dvj7+zul32HDhsHPz8/i2MqVK1FUVOSU/olsEomoQZo9e7YIwOpjx44dNtvHx8fbbL9t2zZx0qRJ1fYVEBBgs429j5iYGHHfvn12xz9+/Hira/r371+jcb/44ouih4eH3TH06tVLzMrKquMrbXusAMT4+Pha97lixQoxODjY4ddy9+7ddvs6e/as2LZt2xp9f2bPnm3VT25urnjXXXfVqB9b37OasPVzHBkZKV65ckXs2rWr3fsKgiDOnDmzyr7LysrEefPmid7e3tU+D5VKJc6ePVssKyuz2Vdd//04aseOHQ5/vxzVv39/q/7Gjx8vbt++XWzWrJnd18THx0f8+eefq+z7+vXr4qhRoxz6WVEoFOKzzz4rFhUVVdlnWlqaOGbMmCr/bVf8WLRokcX19r5XO3bsEOfNmycqFArJf2eIoijecsstVv0fOXKkymsiIyMd+t4vWrTI5vivX78u9ujRw+Y5Vzp27JjNMXz22Wc22997771Wbf39/UWDwSDJ+Bz9/6c6tn5frlu3zvkDJirHpZJETdwrr7yCgwcPOr3fc+fOYciQIdizZw/atWvn9P6fffZZnDp1qso2e/fuxQsvvICFCxc6/f518frrr+Ptt992uP25c+fQv39//PDDDxg9erTFuZKSEtx1111OSaU9bdq0KpfnukpeXh4GDRqE8+fP220jiiLeeecdyGQyvPXWW1bny8rKcN9992HNmjUO3bO4uBhz587FyZMnsWrVKnh4OLYgRap/P1I7cuQIVq9ejYKCArtt8vLyMHr0aKxfvx5Dhw61On/p0iXceuutDs+klZaW4tNPP8X+/fuxbds2q1kWALhw4QL69+9f7QxobcyePRt//vlnlW2c9TsjJSUFR44csTjm5eXllKV/VRk+fLhDP49z587FunXrnHLPJ554Ak888YTFsb1799psGxsba/N4t27drJaVZmRk4MKFC2jdurVTximFnj17Wv3O/P333zFixAg3jYgaOwZuRE1cxf/kg4OD0axZM1y7dg3Xr1+3e41arUZYWBi8vb0hk8mQmZmJy5cvQxRFi3bZ2dmYPn261f4FZzAFbQqFAq1bt0ZqaipSU1Ot2n3//fd4++23ERoa6vQx1MaKFSvsBm1BQUEICQnBpUuXkJOTY3FOr9dj/PjxaNu2LTp37mw+/n//9382gzbTkjK1Wo3s7GxcvXq1yuxqWVlZWLZsmdVx09JFrVaL/Px8JCYmVrnM0hnS09ORnp4O4MZrEh8fj7y8PKu28+bNw8iRI9GjRw+L4y+99JLNoE0mkyEiIgKenp5ISEiwWtb0888/Y+7cuTb3j9pSm38/teHImMaPH4/Fixc71N/x48fNj1u2bAkvLy+cO3cOer3eop1er8djjz2Gf/75xyLxSWlpKUaMGGEzaJPJZIiJiUFJSQkuXrxodX7v3r147LHHsHLlSovjeXl5GDp0qN2gzcfHB5GRkSgrK8OlS5dq/HNoCtpc8Ttjz549VsdiY2PNSwSlUvHn0fR9vXLlitVy0vj4eBw6dMgp97T1/Tp27JjNti1atLB5PCIiwubxY8eO1fvArbK///7bDSOhpoJ73IgILVq0wLZt23Dt2jUcP34c165dw7FjxxATE2Nuc8cdd+C7777DhQsXUFBQgIsXL+L48eM4cuQIEhISkJ6ejn//+99Wff/+++9ISUmRZNy33XYbLl++jFOnTiE5ORlTpkyxaqPX67F161ZJ7l9TxcXFeOWVV6yOq9VqrFy50vz6p6Wl2QzubF1/+vRpq3YTJkxAeno6zp49i2PHjiEhIQEFBQU4ePAgPvzwQ/zrX/+CTCazuOb8+fNW+xI7d+6MxMRExMXF4ejRozh//jzy8vJw7tw5LFy4EPfff7/NWRNnUCgU+P777y1eE1tFbg0GA9555x2LY+fOncNnn31m1faxxx7D1atXkZCQgDNnzuD69et4/vnnrdq9//77NZrxceTfT30UERGB/fv3Iz4+HqdOncLVq1dx++23W7VLSkrCd999Z3Hs22+/xcmTJ63aDh06FFevXsXp06dx4cIFnDp1yuaM+48//mg1KzN//nybGQjDw8Px66+/IjMzEydPnsSZM2eQnZ2NrVu3YuTIkTXav+Wq3xm2Apf27dvXqU9HDRgwAOfOnTN/X7OysrBlyxaX3NvE3t5Xe/vLKha0dqSf+sLWDOqpU6es/gBC5DTuXqtJRLXjrD1uKpVKPHPmjFPGVFZWJvr5+Vndw9Y+mbrucdNoNGJmZqZF25KSEtHHx8eq7SuvvFKn5+WsPW7r1q2z2c8HH3xgs/3DDz9ss/3Vq1fNbd5//32r8ytWrKh2LHq93uLr/fv3W/Xz5JNP1rifmrL3c/zGG2/YbD9o0CCrtjKZTMzNzTW3eeWVV6za9O3b1+4YbO2le+eddyzauOLfjyja3+PmyMf48eNt9mlrjxsAcfv27VZts7KyRH9/f6u2PXv2tGgXGxtr1SYkJMTi+2Dyzz//2NyvNmnSJIt2YWFhVm10Op148eLFKl+zynvm6sPvjHHjxln1OWvWrGqvq+setzZt2oiFhYXV3sfe77TafNga39ChQ222tbeHdOvWrTbbV/536CzO2uNWUlJic9xxcXHOHzSRyD1uRE3e/fff73B66sTERKxatQo7d+7E2bNnce3aNeTn51ebQTIxMdEZQ7Uwfvx4+Pr6WhxTKBSIjo62WAYGGLMK1gfbt2+3OiYIAh5//HGb7SdNmmRz+eL27dsxbtw4AECXLl2szj/11FPYvXs3unTpgjZt2qBNmzYICgqyaFN5xq1du3ZWtY3+97//ITs7G3369DH306JFC4sZjsr9OIu912TChAlWr2NZWRkOHDiAgQMHAoDN2ZK4uDh069bNZp8JCQlWx7Zt24YZM2ZUO86a/PupC0fquNWkTmNUVJT59apIp9PhnnvusZphO3z4MIqLi6FSqZCVlWW1fwsAxowZAx8fH6vjbdq0Qb9+/fDHH39YHK/4fTx58qTNWc4pU6YgOjq6yueiUqmqPG/iyt8ZtmaK7M0qOdP06dOhVqurbbd48WKHl9U6k1hpOX11x+s7U+beyktR09PT61XdVGo8GLgRNXG23rxVJooi3nrrLcybNw/FxcU1vkdWVlYtRla1W265xeZxW28cazNmKVy+fNnqWIsWLaxSSptU3MtW0ZUrV8yPBw0ahM6dO1sszcrKyrJKxe3v749evXph2LBhGDt2rNWSJR8fHzzxxBMW1xkMBqxcudJiL5Knpye6du2K2267DePGjcNNN91UxTOuHV9fX7t7YTp27GjzeMXX5NKlS1bnk5OTbRast8dWH7Y48u/HGZxdx61Tp052z9l6jUtLS3Ht2jW0aNECV69etVmiwt7Pq+lc5cCt4v44e6/3oEGD7PZZU678nWHrelcUR3fVz2N1dDqdzeMlJSXw9PS0Om7v9a4caNdHWq3WKnCTeh8wNV3c40bUxNnbFF7RvHnzMHv27Fq/makqKUZthYeH2zwu9eb/usjOzrY6VtWbOXvnKgbCMpkMGzZsqLboekZGBn7//XdMmzYNrVq1spm446OPPsKUKVOqzKhYWFiI3bt3480330Tbtm3xxhtvVHnf2rD1RtrE3mtS8Y2TM/5QYEqOUh1H/v3UR7X5uTO9xrZ+jmvTZ0lJiTmrpb3vmbNqbgGu/Z1haxawcsIhKdSXn8fAwECbx+39u7J33F4/9Ymtfw+2glMiZ6i/73CIyCWqW2aUn5+PefPmWR3v0KED3n33XfTo0QOBgYHm5XMtWrSwmP2Qir1xu6PQrKNs/RW6quLB9s5V/it0eHg4duzYgQMHDmDt2rX4+++/8c8//yA5OdnmEqSsrCw89NBDOHfunMUbPYVCgQULFmDmzJn46aef8Oeff+LkyZO4dOmSzc32ZWVleOutt9C5c2fcd999dp9HTdnKHmli7zWpGBj4+vrWOamBo39scHSZXn1Tl9fY3mxKTX+WlUqlObmNvZmVjIwMu33WlCt/Z9haFunM52KPoz+PUpcDsLWEGzCuOrAVXNr7P8NeP/VFSUmJzX9LzvyDA1FFDNyIqEp79uyxWetp9erVVnt7iouLnZ4GvTGxtfzv8uXLyMzMtLlc0l5K7ebNm9s83r17d3Tv3t38dXFxMeLi4rBr1y688sorFvt2CgsLsWrVKrzwwgs2x/nCCy+Yz5WVleHq1as4fPgw5syZY7UfaMmSJU4N3LKysnDlyhWbz/PEiRM2r6nYNjIy0ipwmzp1qs1Mk01V5e9hRbZeY6VSiWbNmgEwzup4eHhYLZe09/Nq71zFN/AtW7a0ed327dsxZMgQu/3WV7b2Nzk6i+sKUpcDsJUmHwAOHTqEPn362DxeWUBAgCRLsZ3JVjAuk8ns/o4mqisulSSiKtkLxConuwCAhQsX1pv9ZPWRrf06oijaLfb77bffVttPUVGRzf1GgPGv7+3atcPkyZPx6KOPWp2/cOGCxdf5+fk2+5HJZIiMjMSoUaNs1hKr3I8zVE6OYWIroYJcLreo43bbbbdZtfnpp59s1uyyZfv27XaXAzYWcXFxVnvOAOOyr19//dXqeNeuXc2zOb6+vjb3i61cudLm7MPZs2fx119/WR2v+HPcvn17m8lXvv76a5vJYyqqXIuvPrC1h9BUe7Ip6NSpk83yBytWrLA6lpGRgc2bN1sdf+ihh2z23bJlSwiCYPHhzP2fNWGrJEb79u2hUCjcMBpqChi4EVGV7C2Leu2118xBmsFgwKJFi/Diiy+6cmgNzu23327zL7Gvv/46fvzxR/OyxtLSUsybN89mRskhQ4ZY7NXZu3cvWrRogenTp2PLli029wr9888/NougK5VKi69DQkIwfvx4/Pjjjzb/ip6RkYFFixZV248zmJ6/6TUx1bCzlZlz5MiR8Pb2Nn89ceJEq2yXKSkpGDx4MDZv3my1fDQ/Px+7du3CrFmz0KZNG9x22231JhOplMaNG2cx03Ht2jU8+OCDNp975TfRjz32mFWblJQUPPDAAxZ1G8+cOYN7773X5h8XKvdRebkdYJx9/de//oW1a9daLF/V6/X4888/MWrUKPz4449VPEv36N27t9Wxw4cPS7Lft7565plnrI7t2bMHs2fPNi+9zsrKwrhx46xWdchkMps19uqbffv2WR2zNaNI5CxcKklEVerduzcUCoVVyv+vvvoKy5cvR4sWLZCcnFyvlgG5yl133eVQ0LJ8+XLExMRApVLhnXfewSOPPGJxvqioCGPGjMGzzz6LkJAQXLp0yeaMj0qlwrvvvmt1PDExER9++CE+/PBDAMbZ0MDAQCiVSqSnp1tk76uocnr8vLw8fP/99/j+++8BGPc0hYSEwNvbG7m5uXb3utlLs18XJSUleOSRR/DCCy+gWbNmSEhIsLlPysPDwyptf9u2bTF16lR88sknFsePHz+OO+64A15eXggPD4dKpUJmZiaSkpLqfTryb775BuvXr6+23dixY20uf7XlypUr6NatG6KiouDp6Ylz587Z/P6GhYVh4sSJFscmTZqEL774wqoA/KZNm9C8eXPExMSgpKTE7mzsAw88YBXcvPjii/j++++tinBfuXIFd999NzQaDSIjI1FWVobLly+bZ4jvvvtuh56vK4WHh6Njx44Wy07z8/Nx6tSpKjN6uoorygE88cQTWLx4Mfbv329x/M0338Tnn3+OsLAwXLx40WYGxn//+99OK1j+5JNPWi3FtDWLe+jQIavfZbGxsfj666/t9m0rcBs2bFjtBkrkAAZuRFQlf39/PP3001ZvggFjlrSKS0VGjRqFQ4cO2Ux73xjZ229VWcW/Jj/88MM4efKkzQDs+vXrdpemymQyfPfdd3ZTmleUmppa7bLANm3aVLsvLTc3t8qEEwCgVqsdDhQc1axZMzRv3hwHDx6s8jUBgFdffdVimaTJ/PnzER8fj7Vr11qdKygowPnz5506Zqk5Ws7g1ltvdai/3r174+zZs8jIyEB8fLzddnK5HN99951VVkilUon169fj1ltvtZqd1ev1VgFdRd27d7c5c+vj44PNmzejf//+Nmd8c3NzbS5Nq68eeOABq98R27ZtqxeBmyvIZDL8+OOPGDRokNXPWEZGht1kLcOGDcNbb73ltHGcPXvWof18eXl5Vu2qynBbUlJitQRYp9Ph9ttvr91AiRzApZJEVK33338f99xzT5Vt7r77bvzwww/1OqtjffHOO+9g6dKl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EKf3T0RERGRSUFCAV199FQDQtm1bvP3222jVqhXkcjlkMpmbR0dkX6MJ3F5++WV8+OGHAID58+fj+eefr1U/YWFh5seJiYl2Z+wSK+z5qnhNY6JWBCJLBuRrvOGdm29cLilB4KZroUPSwSTOuBEREZHkDh48iOxs43uO+fPn484773TziNyvZcuWEEXR3cOgajSKpZIvvfQSPvjgAwDA+++/jxdffLHWfbVr1w4eHsaX5eTJk3bbmc6FhITYTUzS0HkrjSUBsrTl+/muXZPkPqzlRkRERK5S8Y/vMTExbhwJUc00+MBt+vTpmD9/PgBj0PbSSy/VqT8vLy/07dsXALBp0yabbURRxObNmwEAQ4YMqdP96jOt2ji7lqZRGg9IlKCEtdyIiIjIVSpm+1YoFG4cCVHNNOjAbfr06RbLI+satJmMHz8eALBjxw7s27fP6vzq1asRFxcHAHj00Uedcs/6yM/TOOOW4l3+YyJ14MZabkREROSAzMxMzJgxA23btoWnpyeCg4MxePBgrF692u41AwYMgCAImDhxovlYVFSUOZuiIAgWdYBNUlNT8eabb6Jv374IDg6GQqGAn58fevbsiZdffhnHjx+3uqakpATr1q3D1KlT0b17d/j5+UGhUCAgIAA9e/bEnDlzkJaW5pTXwmTXrl247777EBISArVajejoaEyZMgUXLlyweP4DBgywupZZJRsIsYF66aWXRAAiAPGjjz6q0bWLFi0yX7tjxw6r86WlpWLHjh1FAGJ4eLi4detWURRFsaysTFy1apWo1WpFAOKwYcNqPO7s7GwRgJidnV3ja13t7l++ETEH4uJ+zUUREMXXXpPkPokHEsU5mCN+GPahJP0TERFJobCwUDx9+rRYWFjo7qE0KadPnxbDwsLM7+Uqf0ycONHivV58fLwoiqLYv39/u9fYe1/4ww8/iN7e3lVeExkZaTXG8ePHV3uvgIAAcdeuXU55Td59911REASb99FoNOLmzZvNz79///5W18fHx5vbL1q0yCljampq+/ugJrFBg0xOcvnyZfOeNg8PD7z33nt477337LafPn06pk+f7nD/crkca9euxcCBA5GQkIDBgwfDy8sLBoMBRUXGWmO33HILli1bVrcnUs8Fextn3JI8S40HJNrjZppxy03ORVlJGWRKZnQiIiIiazk5ORg6dCiSkpIAAKNHj8b48eMRHByMc+fO4aOPPsKiRYts5ilYtGgR8vPzsWbNGrz22msAgM2bN1skmYuKijI/Xrp0qXlllVqtxuTJkzFs2DCEhIQgLy8Px48fx9q1a3H+/Hmre+n1ekRHR2PUqFHo0aMHWrRoAblcjkuXLmHr1q347rvvkJ6ejlGjRuHkyZMIDg6u9WuyatUqzJgxAwDg7++PV155Bf369QMA/PXXX3j33XcxZswYBAUF1foeVD80yMCtYq0Ng8GAa9UEFHl5eTW+R8uWLXH8+HHMnz8fv/zyC+Lj46FQKNC+fXs89NBDmDZtGpRKZY37bUjCNMZfIkme5YWxJVoq6RXkBZlKhrLiMuQk5sAvyk+S+xAREVHD9tZbb5lr4s6bNw8zZ840n4uNjcX9999vrs9WmSkoO3jwoPlYTEwMWrZsadU2OTkZU6ZMAQAEBwdj27Zt6NChg0Wbfv364ZlnnrFZo3fu3LmIjo6GIAgWx7t164b77rsPTz/9NPr06YPU1FR89tlneOuttxx8BSwVFxfj2WefBQAEBgZiz549uOmmm8zne/fujXvuuQe9e/fGuXPnanUPqj8aZOBW15SlEyZMwIQJE6ptp9FoMHfuXMydO7fW92rIIjSmGbd84wGJAjdBEKBroUPG+QxkX85m4EZERI2KKIooKLVfG7Yx8VJ4WQUrzlJSUoKFCxcCADp16mSeZapIoVBg4cKFiI6ORmlpaa3v9dlnn5lr9n7zzTdWQVtFzZs3tzrWqlWrKvvv2LEjJk2ahP/+97/47bffah24/fbbb+YJjDlz5lgEbSYxMTGYPXs2nnvuuVrdg+qPBhm4kWu01Bln3FK8yn/xSRS4AcYi3BnnM5ighIiIGp2C0gL4vOPj7mG4RN7MPHgrvSXp+9ChQ8jMzARgTCRnL0CMiIjAkCFDsGHDhlrfa/369QCA6Oho3HXXXbXuxyQzMxMZGRkoKioyTz74+voCAE6fPo3S0tJaZbjcunUrAOPWoYcffthuu0ceeQTPP/88a7U1cAzcyK4wbx9A8MR170LjAYn2uAGs5UZERERVO3HihPlx9+7dq2zbo0ePWgdupaWl5j1yt956a61nEE+cOIGPP/4YGzduREpKit12BoMBmZmZFvvcqqolHBUVBW9vb4t20dHR5kDQFn9/f0RHR+PixYs1fBZUnzBwI7sC1ALgEYjr3uVrt/PygIICwMvL6fdiLTciImqsvBReyJtZ8/32DZGXwvnvEUwyMjLMj6tL5tGsWbM63cc0MxUaGlqrPhYuXIgpU6ZAr9c71L6wsNDi644dO9ptu2PHDnNKf9MMpCOJR4KCghi4NXAM3MguP5UAwSMQOaorKFMqICspBVJTgchIp9+LgRsRETVWgiBItnywqZJqH50z/PPPP+agLTg4GC+99BIGDRqEli1bQqPRmJdEfvfdd3j88ccBgEsYySEM3MgupUyAXBaIUgHI89NAdy3DuM9NgsDNN9IXAItwExERkW1+fjeSl127dg0xMTF221aXcbwq/v7+8PDwgMFgQHJyco2vX7x4MfR6PWQyGf744w+0bdvWZruKM4iVORrImV6T1NTUats60obqNw93D4DqN7UiEACQrfU0HpC4llv25Wz+1YmIiIisVFw+eODAgSrbVne+KgqFwpxF8q+//qrx+5JTp04BADp37mw3aAMsyxLUVvv27QEAcXFx5mWTtmRkZCAuLq7O9yP3YuBGVfJWGQO3NJ/yTEcSZZbURhiTk5QWlKIwo7Ca1kRERNTUxMbGmmeYli5dajegSkxMtFnHrSZGjhwJAIiPj8eaNWtqdK1pX1t+fr7dNsnJyVi7dm3tB1jutttuA2BMcLJ8+XK77X744Qf+YbwRYOBGVdKoyksCeJf/qEgUuMnVcng3M67/5z43IiIiqkylUmHixIkAgKNHj+KDDz6waqPX6zF58mSUlJTU6V5Tp041Z2588sknq8zyePXqVYuvW7duDQA4f/48/v77b6v2BQUFGDt2rFVCktoYNWqUOVHLnDlzbCYfOX/+fJOtSdzYMHCjKvl5GrMUJXsZjAckruUGcJ8bERER2fbGG28gIiICAPDKK69g7Nix2LRpEw4fPoyVK1eiT58+2LhxI7p161an+4SEhGDBggUAgOvXr6NHjx547rnnsGnTJhw9ehS7du3CV199heHDh6N///4W144bNw6AcRbszjvvxLx58/Dnn39i//79WLBgAbp06YKdO3eib9++dRojAKjVavz3v/8FAKSlpaFnz5744IMPsHfvXuzduxfvv/8+evXqBYPBYA4o63NiF6oak5NQlQK9jEslE9Xl6WwlrOWma6FD4v5EzrgRERGRTTqdDps2bcLgwYORkpKCFStWYMWKFRZtJkyYgP79+5tn52pr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1w8fPrxN5ezOgjVt77zzTii0XXLJJc1e097PracK/n9yzz33NPkz98033wQAHDhwILTv73//e+h6PvfYYXDrIUwmEyZPngwA+Pzzz5s8RwiBpUuXAkDUZgYU3V133YWnn34agAxt8+bNa/Z8fibxwefePsHnsX379qjnhA/l3L9/fwB87u0RDF5AfQ1mU0pKSkLbwWZGfO4dY/DgwcjLywMQ/bnW1tbiu+++A9D4uU6ZMiU0mmS06/fv3x/6d8bPJZLf78fll1+Od999NxTaLr300uNe197PjdqGzz2G4jb1N3W6l19+WQAQiqKI1atXNzr+7rvvCgACgPjqq6/iUMKu68477ww9u6effrrF1/Ez6RgPPvhg6Lk1hc+97b799tvQs/noo48aHff7/WLUqFECgOjbt6/w+/2hY3zubeNwOITRaBQAxLhx44TX6210js/nE5MmTRIARGpqqvD5fKFjfO6tk5+fLwCIBx98sNnz7r//fgFAmEwmUVRU1Oj4E088IQAItVotdu7c2ej4nDlzBADRu3dvUVVV1ej4jTfeKACIpKQkUVFR0dYvp8to6XP3+XzikksuEQCERqMR77zzTqvep72fW3fT0ufenLlz5woAIj8/P+o5fO6xweDWg3i9XjFy5MjQL1TBH9B+v18sXrxYJCcnCwDi7LPPjnNJu5Z58+aFful55plnWnUtP5OOcbzgxufePrNnzxYARHp6unj//fdDQWL//v3i4osvDj37f//73xHX8bm33S233BJ6rjNnzhSbNm0Sfr9f+P1+sXHjRnHmmWeGji9YsCDiWj735lVUVIhjx46FltzcXAFAzJs3L2K/zWaLuK6qqkpkZ2cLAGLYsGFi3bp1Qggh3G63eP7554VOpxMAxI033tjk+xYWFgqz2SwAiKlTp4pdu3YJIYSw2+1iwYIFQlEUAUA88cQTHfsA4qQtz93n84lLL700FNoWL17c6vdt7+fW1bX1+705LQluPf25xwqDWw9TVFQk+vXrF/oBbzKZhMFgCL0eO3Zsj/jLXqzs378/9OxUKpXIyspqdnnqqaca3YOfSewdL7gJwefeHna7XZx66qmhZ6XX60VqamrodXN/veVzbxuHwyFmzpwZ8Yz1er3Q6/UR+y677LKI2rYgPvfogjUOx1vmzp3b6Np169aJ9PT00DlJSUlCq9WGXp955pnC5XJFfe8lS5YIk8kUOt9qtQq1Wh16fdVVV4lAINCBX338tOW5r1ixIrRfq9Ue92dutNq49n5uXVl7vt+jaUlwE6JnP/dYYR+3HqZfv37YtGkTHnjgAYwYMQKKokCr1eLEE0/E008/jdWrVyM1NTXexewyGs5rVVJS0uxit9sb3YOfSXzwubed2WzG8uXL8dJLL+HUU0+F2WyG3W5H3759cemll2LlypWYP39+k9fyubeN0WjEZ599hvfeew/nnXcecnJyQoPA5Obm4sILL8Snn36Kt956C2q1utH1fO4d48QTT8TWrVtx++23Y9CgQfB6vTCbzZgyZQpeeukl/O9//4Ner496/TnnnINNmzbh2muvRb9+/eByuZCamoozzjgD77//Pl555ZXQAD8U+TPX6/Ue92dutBE72/u5UdvwubefIkTY8F9ERERERESUcFjjRkRERERElOAY3IiIiIiIiBIcgxsREREREVGCY3AjIiIiIiJKcAxuRERERERECY7BjYiIiIiIKMExuBERERERESU4BjciIiIiIqIEx+BGRERERESU4BjciIiIiIiIEhyDGxERUTc3bdo0KIqCadOmxbsoRETURgxuRERERERECY7BjYiIiIiIKMExuBERERERESU4BjciIiIiIqIEx+BGRERERESU4BjciIioR1i+fDnmzp2LAQMGwGQyITk5GSNHjsS8efNw5MiRJq+ZP38+FEWBoigAgKqqKjz44IMYPnw4LBYL0tLSMH36dLz99tstKsO+fftw++23Y/jw4UhKSoLJZMKgQYNw/fXXY/PmzS26h81mw8KFC/GLX/wC2dnZ0Ol0SE5OxtixY3HLLbdg5cqVx73H4cOHcccdd2DgwIEwGo1IT0/HWWedhf/9738tKgMREXU+RQgh4l0IIiKijuJyuXDVVVfhnXfeiXqO2WzG22+/jVmzZkXsnz9/PhYsWAAAKCwsxBlnnIG9e/c2eY+LL74Yb775JjQaTZPHX3vtNVx33XVwu91NHler1XjooYdwzz33RC3nV199hcsuuwxlZWVRzwGAhj/ap02bhhUrVuC0007DI488gvPPPz/qPZ566incddddzd6fiIg6H2vciIio2xJCYPbs2aHQNmvWLLz++utYuXIlVq1ahb/85S/Iy8tDbW0tZs+ejXXr1kW91yWXXIKioiLccMMN+Oqrr7B27Vr885//xODBgwEAixcvxrx585q8dsmSJfjtb38Lt9sNi8WCBx98EN999x1WrVqFhQsXIiMjA36/H/feey/+8Y9/NHmP5cuX4+yzz0ZZWRnUajV++9vf4qOPPsL69euxcuVKvPTSS7jgggug1Wqjfg1Hjx7F+eefD5VKhccffxzff/891qxZg2eeeQYpKSkAgHvuuQdbt25tyeMlIqLOJIiIiLqpRYsWCQBCq9WK//3vf02eU1FRIYYPHy4AiMmTJ0cce/DBBwWA0PLWW281ur6mpkaMHj1aABAqlUps3rw54rjH4xF9+vQRAITFYhEbNmxodI99+/aJ3r17CwDCZDKJY8eORRx3Op2he5hMJrF8+fKoX/OBAwca7TvttNNCX0N+fr44dOhQo3O+++47oSiKACB+//vfR70/ERHFB2vciIioWxJC4IknngAA/P73v8fMmTObPC81NRVPPfUUAGDlypXYvXt3k+ede+65uOyyyxrtT0pKwqJFiwAAgUAAL7zwQsTxjz76KNSH7v7778eYMWMa3SM/Pz9UBofDgX/9618Rx1977bXQPR599FFMmzatyTICQG5ubtRjAPC3v/0Nffv2bbR/ypQpOPnkkwEA3333XbP3ICKizsfgRkRE3dK2bdtC/dFmz57d7LmnnnpqaHvVqlVNnnPVVVdFvX7ChAkYPnw4ANkPLVzwtaIouPrqq6Pe46KLLoLVam3yHp9++ikA2Rfv2muvjXqP40lJScEvf/nLqMdPPPFEALI/HxERJRYGNyIi6pbC+6tNnDgxNDpkU4vFYgmdW1xc3OT9xo8f3+z7TZgwAQCwa9cueDye0P4tW7YAAPr374/MzMyo1+t0OowdOzbimqANGzYAkMHKZDI1W47mDBo0CCpV9B/9aWlpAOTIlURElFgY3IiIqFsqLS1t03UOh6PJ/b169Wr2uqysLACyiWZlZWVof0VFRYuuB4Ds7OyIa4KCI0D27t37uPdozvFCXzDUBQKBdr0PERHFXtNjFhMREXVxfr8/tP3f//4X/fr1a9F10QJWcC63tmrv9URE1LMxuBERUbeUnp4e2k5JScGIESPadb+SkpJmB/4oKSkBIANaampqaH+w+WHweHOCzTSD1wRlZGTg0KFDOHr0aKvLTURE3QObShIRUbcU7C8GyNEi22vt2rUtOj5o0CDodLrQ/mBgLCoqwrFjx6Je7/V6Q33ZGobMcePGAZD99qI15SQiou6NwY2IiLqlcePGIScnBwCwaNEiuFyudt3v1VdfjXps7dq1oQFFZsyYEXEs+FoI0WiY/3Dvv/8+qqurm7zHrFmzAMj+d8GpB4iIqGdhcCMiom5JpVLh3nvvBSCHt7/yyivhdrujnl9TU4Pnnnsu6vFPPvkEixcvbrTfbrfj+uuvD71ncDvo/PPPR58+fQAAjzzyCDZv3tzoHgcPHsRdd90FQA4g0nDqgTlz5oTmXrvvvvuwYsWKqOU8dOhQ1GNERNR1sY8bERF1WzfccAO+/PJLfPTRR3jvvffw008/4frrr8eECRNgtVpRU1ODHTt24JtvvsEnn3wCg8GAm2++ucl7nXTSSbj88suxYsUKzJ49G8nJydi0aROeeOIJ7Ny5EwBw0003YdSoURHX6XQ6LFq0CLNmzUJNTQ0mT56MefPm4fTTT4darcYPP/yAxx9/PDQK5tNPP42MjIyIexgMBrz++us488wz4XA4MGPGDPzmN7/B+eefj5ycHLjdbuzYsQOfffYZPvnkk2YDKhERdU2KEELEuxBEREQdxev14tZbb8ULL7yA4/3I69+/f8Tk0/Pnz8eCBQsAyFq7008/HUVFRU1ee+GFF+Kdd96BRtP030RfffVVXH/99VFDlVqtxkMPPYR77rknavmWLl2Kyy67LGK6gaY0/DqnTZuGFStW4LTTTsM333wT9brwr5e/HhARJRY2lSQiom5Nq9Xi+eefx8aNG3HLLbdg5MiRsFqtUKvVsFqtGDNmDK655hq8//772L59e9T79O/fH+vXr8e9996LoUOHwmQywWq14tRTT8Ubb7yB999/P2poA4C5c+dix44duPXWWzF06FCYzWYYjUYUFBTg2muvxYYNG5oNbQBw1llnobCwEI8++igmTZqE9PR0qNVqJCcnY9y4cbjtttuwZs2aNj8rIiJKXKxxIyIiioI1UERElChY40ZERERERJTgGNyIiIiIiIgSHIMbERERERFRgmNwIyIiIiIiSnAMbkRERERERAmOo0oSERERERElONa4ERERERERJTgGNyIiIiIiogTH4EZERERERJTgGNyIiIiIiIgSHIMbERERERFRgmNwIyIiIiIiSnAMbkRERERERAmOwY2IiIiIiCjB/X9blIGMhEaD2QAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 1000x800 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA24AAALeCAYAAADS7EKmAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjMsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvZiW1igAAAAlwSFlzAAAPYQAAD2EBqD+naQAA96JJREFUeJzs3Xd4VFX+BvB3+mTSKyEJvfelCCggIKigYEPFXlgVe9dd111F3dW1rmUtP1cFESugYkFEQKyIoHSQHkoq6WX63PP74+ZOZjIzySRT0t7P89xnbu7cufekwbw553yPSgghQERERERERG2WurUbQERERERERI1jcCMiIiIiImrjGNyIiIiIiIjaOAY3IiIiIiKiNo7BjYiIiIiIqI1jcCMiIiIiImrjGNyIiIiIiIjaOAY3IiIiIiKiNo7BjYiIiIiIqI1jcCMiIiIKE5VK5bMtWrSo1drz6quverXFaDQiPz/f57wpU6b4tPuaa66JfoMpoOXLl3t9f7RaLbZv397azaIo0rZ2A4jasp49e+LIkSNhu97VV1/dqv+BB7J161Z8+umnPscXLFgQ0fs6nU5069YNhYWFfp9ftWoVzjzzzIi2gYhkubm56NWrV4tfv3DhQr7Rb2NKS0vx97//3evYtddei6ysrFZqUev4/fff8cEHH2Dt2rU4fvw4ysvLkZycjOzsbEybNg2XXHIJRo8eHfb7OhwO7Ny5E5s3b3ZvO3bsgMPh8DqvR48eyM3NbfJ6F1xwAQYNGoQ9e/YAAFwuF2699VZ8//33YW87tU0MbkSErVu34pFHHvE5HungtmrVqoChDQAWLVrE4EZE1EL/+te/UFZW5v5Yq9Xi/vvvb8UWRVdVVRVuueUWvPvuuxBCeD1XXFyM4uJibNmyBc8++ywuv/xyvPzyy0hISAjb/WfMmIF169aF7XoqlQoPPPAArrrqKvexH374AStWrMC5554btvtQ28WhkkTUaprqffz0009RWVkZncYQEXUgeXl5eOWVV7yOXXTRRSH1qrYnZWVlmDZtGpYsWeIT2hoSQmDJkiWYNm2aV9ANlcvlCtu1FJdeeim6devmdewf//hHk58jdQzscSNqxPDhw5GWlub3ufz8fBQUFPgc79+/P+Lj4/2+prP8hxmMsrIyfP75542eY7Va8cEHH2D+/PlRahURNZSamoqePXs2eV6gfyupdbzwwguw2Wxexzx7ajq6G264AZs3b/Y5Hh8fjx49euDo0aOoqqryem7z5s2YP38+li5dGrF2GQwGn+9Lc2i1Wlx66aV46qmn3Md27NiBVatWYebMmeFoIrVhDG5Ejfjss88CPrdgwQK/wwv/7//+D1OmTIlgqzqG9957D3a7vcnzFi1axOBG1IpmzZrVJufmUmBWqxX/+9//vI5lZGRg+vTprdSi6Prqq6+wfPlyn+N//vOf8eKLL8JkMsFiseD222/HG2+84XXOsmXL8NVXX4UlBGVmZuLss8/GmDFjMGbMGJx00kl49dVX/b53aI7LLrvMK7gBwIsvvsjg1glwqCRRKygvL8cLL7yA888/H7169UJCQgIMBgOysrIwZcoUPProo36rfvmzf/9+PPTQQ5gyZQqys7MRGxsLnU6HLl26YPDgwZg6dSpuvfVWLFq0CAcPHvR6rVKZ6tprr/V7bX/V0cI17+3tt9/2OXbKKaf4HPvll1+wb9++Zl27oKAATz/9NM4991z07t0bSUlJ0Ov1yM7OxqhRo3DFFVfgjTfeQElJSUSuk5ub6/drt379er/3Cbaa26JFi/xeF5CH5Lz55puYPn06unbtCq1W634OkAvBbNiwAS+//DL+/Oc/45RTTsGAAQOQkZEBvV6P2NhYZGVlYdKkSbjrrrvwyy+/NOtrXlFRgZdffhkXX3wx+vXrh5SUFOj1emRmZmLEiBG48MIL8eKLL+L48ePu1wwbNsznc/nnP//Z6H1uvPFGn9ecddZZzWqrorGvJwAsXboUs2bNQnZ2tvv3c86cOfj666+DvofZbMYbb7yBSy65BP369UNycjL0ej26dOmC8ePH44EHHsD+/fubvE5jlQp//fVX/PnPf0afPn1gMplavYqhp2uuucan3coftiwWC/7zn//glFNOQVpaGoxGI/r06YMbb7zRXXwhGLm5uXjkkUcwffp0dOvWDSaTCTExMcjOzsbkyZPx97//HXv37m1Wu8P1b0hDR48exf3334/BgwcjLi4OCQkJGDlyJB599FFUV1c361qN+fTTT1FRUeF17KKLLoJWG/rf69evX+/351EprrFs2TKcc845yMnJgV6v93ouWv773//6HOvRowdeeeUVmEwmAEBMTAxefvlldO/e3efcl19+OSzt+OCDD/DFF19gwYIFmDVrFrp06RKW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/Z77/vvve10zXL/7QgT+Xo0YMcKrfY8//rjf8/xdszn8fS4zZsxo8nWhDpUEIIYPH+7z8/vTTz+Jqqoq98eB/u9syeavfffff7/fc3fv3u338961a5ff8//yl780+TVriXANlRRCCKPR6HOtaA5LpehjcCNqoeYEt7/85S8+502YMCHgtUeNGuVz/hNPPOF1TsPgNnDgQCFJUqNtdjqdfo9HM7hddNFFPvfp37+/1zmPPvqozzkxMTEB56eMHz/e53ytVis2btzYaFsazikK13WiHdwGDBggLBZLo20M1u+//+73HiUlJV7nXXLJJX7Pa2q+mb95XP7e3P/tb3/zOmfp0qXN+h0KRqCv51VXXeX3/Hnz5vk93zM8vvrqqz7P9+zZU9jtdr/XvOCCC3zOnz9/vs95gd64rl27NqSvgadoBre33nrL51yHwyH69+/vc26XLl28zpszZ47POUaj0e/8sBMnTvgN0tOnT/c6L1y/+0L4/16p1Wq/Ydrf5zt37txG79mUf/zjHz7XvPzyy5t8XajBLS0tTRQXFzd5n0gHt/nz5/s91/MPJ54OHDjg93x/v4fhEM7glpWV5XOtdevWhbfB1KawqiRRFPibb3Do0CF3ieCGm79hiw3nPfzpT3/y+viPP/7A5MmT8eSTT+LTTz/Fnj17fMrtazSakD+XUJSXl/tdYuGSSy5p9GNAnk/10Ucf+RyvrKzEr7/+6nN8zpw5GDt2bKPtMRgMYb9Oa7j33nthNBqDOnfr1q34+9//junTp6Nnz55ISEiARqNxV4YbNWqU39c1rHL6zTff+Jwzbtw4XHDBBY3e39/X6q677vI59uabb8LhcLg/9jdM0t/cp3AIdF1/lT4BYMOGDe59f7/rVVVVOPnkk/3+rv/8888+5wc7x2nChAk47bTTgjo3FKmpqRg9enSj24ABA4K+XkxMDC677DKf41qtFldccYXP8aKiIhw+fNj98bp163zOmTFjht8hb2lpaTjvvPN8jv/444/un69o/O6fddZZ6Nevn8/xgQMH+hxrbHh7MPxVukxNTQ3pmsGYP38+0tPTmzxvwYIFEHLHQchbc6qnigALVAc63h74+742nAdMHQvnuBFFwZEjR3yOFRQUNGsuSsNr3H333T5v+n744QevCfAajQaDBg3CqaeeiksuuQSTJk1qZsvD6/333/e78Oil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Pufcf//90W8YUTv34IMPes2PdjqdePLJJ1uxRRQKIQT+/e9/ex2bNGkSzj333FZqEUUbgxsREbWqkpIS/Pbbb9i+fbvPeoWAvI7XxIkTW6FlRO1bWloa/vWvf3kde+utt/yuq0lt38cff+xVlESj0QRcr5U6JgY3IiJqs8aPH4/XXnuttZtB1G7ddNNNEPLyTxBCwGq1omvXrq3dLGqBOXPmeH0vnU5no9VZqeNhcCMiojYlLi4O48aNw/PPP4/vv//ep6w5ERFRZ8SqkkRERERERG1c4JVhKSIkSUJ+fj7i4+NZAYiIiIiIqBMTQqC6uhpZWVlQqxsfDMngFmX5+fno1q1bazeDiIiIiIjaiGPHjiEnJ6fRcxjcoiw+Ph6A/M3hvA0iIiIios6rqqoK3bp1c2eExjC4RZkyPDIhIYHBjYiIiIiIgppCxaqSREREREREbRyDGxERERERURvH4EZERERERNTGMbgRERERERG1cQxuREREREREbRyDGxERERERURvH4EZERERERNTGMbgRERERERG1cQxuREREREREbRyDGxERERERURvH4EZERERERNTGMbgRERERERG1cQxuREREREREbRyDGxERERERURvH4EZERERERNTGMbgRERERERG1cQxuREREREREbRyDGxERERERURvH4EZERERERNTGMbgRERERERG1cQxuREREREREbRyDGxERERERURvH4EZERERERNTGaVu7AURERERERMGShIBDgscmf+z0OOaU/J+jnAcA5/ZqX1GofbWWiIiIiIhCIgkBuwuwS3WbS9Q9ygFH2Zefrz/XoZznfr5hYBJwCvgEJmeAANUwYCnn2V0SHJKr7lqquudVcEgSHC4rJMkCwAYIC4SQHyGs7k1AOebxCAmAE0K4ADihU2tgvevJ1v1GNBODGxERERFRBDglAasLsLkAm0vA5gKsdYFH2VeOyx8L96PVJYcj5ZgSsByBQpXkP4w5PEKWzemE3WWDS9jqQo28CTgAYQdgB4TTY98OAWeA5xwQwgKImrqtFkKqAeAEhKPu0QnABcABCGfdtZwezzXYdx9zRfx741AZATC4ERERERFFnRByWLF5hiUJsDnrHuuOKWHKXve8Z4DyDEvya4TX9Txfa3UJWJwWWBw1sLtcsLtUsEkq2Fxq2CVAElZAqoEQZkDUyj1CkOo2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cCMiIiIqJ5IkQaPR+LsbRHQH4uYkREREREREAY6BGxERERERUYBj4EZERERERBTgGLgREREREREFOAZuREREREREAY6BGxERERERUYBj4EZERERERBTgGLgREREREREFOAZuREREREREAY6BGxERERERUYBT+bsDwUYIAQDIzs72c0+IiIiIiMif7DGBPUYoDgM3H8vJyQEA1K5d2889ISIiIiKiQJCTk4OoqKhiy0iiNOEdlRur1YpLly4hIiICkiT5tS/Z2dmoXbs2/vrrL0RGRvq1L8GE4+4fHHf/4Lj7B8fdPzju/sFx9w+Oe/kQQiAnJwc1atSAQlH8KjZm3HxMoVCgVq1a/u6Gg8jISP4P5wccd//guPsHx90/OO7+wXH3D467f3DcvVdSps2Om5MQEREREREFOAZuREREREREAY6BWxDTarWYPn06tFqtv7sSVDju/sFx9w+Ou39w3P2D4+4fHHf/4Lj7HjcnISIiIiIiCnDMuBEREREREQU4Bm5EREREREQBjoEbERERERFRgGPgRkREREREFOAYuAWhnJwcJCcno3nz5ggPD0dUVBTatGmD999/H0aj0d/dq3Ru3ryJlJQUDB06FPfccw/CwsKg1WpRq1Yt9O3bF6tXry7xGfxMys+sWbMgSZL8VRyOu3eys7Px7rvvon379qhatar8c9+5c2ckJycjMzPTZT2Ou+e+//57PPnkk6hbty5CQkIQGhqK+vXr46mnnsLOnTuLrctxd6bX67Fx40a89dZbePzxx1G3bl35z47k5ORSPePq1at4+eWXcddddyE0NBSxsbHo2LEj/vvf/6I0+7+dOXMGo0ePRmJiIkJCQlC1alV069YNX3/9tZfvLnB5M+4XL17EnDlzMGDAADRs2BChoaEIDQ1FYmIiBg8ejB9++KFUffD2c6uMyuPn/XYvvPCC/Ix69eqVWD4Yx71cCQoqaWlpol69egKAACB0Op3QarXy9y1atBDp6en+7malolKp5PEDIEJCQkRYWJjDte7du4u8vDyX9fmZlJ9Tp06JkJAQh7F3h+PunR9++EFUq1ZNHi+NRiOio6Mdxv7QoUNO9TjunrFarWL06NEO4xsaGipCQ0Mdrv3zn/90WZ/j7tr27dsdxq/o1/Tp00usv3//flGlShW5Tnh4uMPfCd26dRMGg8Ft/Q0bNgidTieXj4yMFAqFQv5+xIgRwmq1luM7Dgyejvv58+eFJEkO5XU6ndP/ByNHjhRms9ntc7z93Corb3/eb/fDDz84fB5169Yttnywjnt5YuAWREwmk2jevLkAIKpXry6+//57IYQQFotFrFixQkRERAgAokePHn7uaeUCQLRt21bMmTNHnDlzRr6empoqnn32WfkPpKFDhzrV5WdSfiwWi2jfvr0AIB588MFiAzeOu3d++ukn+Relxx9/XOzbt0/+5TIvL0/s3btXTJs2TZw9e9ahHsfdcwsXLpR/pvv37y/++OMP+d6pU6dEnz595PvffPONQ12Ou3vbt28XMTEx4tFHHxWTJk0Sy5cvFwkJCaX6RTYzM1Mu26RJE7Fv3z4hhBAGg0F8+umnQq1WCwBizJgxLuufPXtW/ke+Dh06iN9//10IIUROTo54/fXX5c/z3XffLdf3HAg8HffU1FQBQDz66KNi8eLF4uLFi0II28/y8ePHHf4/eO2111w+w9vPrTLz5uf9dnl5eaJBgwZCrVaL1q1blxi4BfO4lycGbkHkv//9r/wH2s8//+x0f9myZfL9rVu3+qGHldMPP/xQ7P2i/0p+/vx5h3v8TMrPRx99JACIp556SkyfPr3YwI3j7rm8vDxRv359AUCMHz++THU57p5LSkoSAETDhg2FyWRyum80GuXPZdCgQQ73OO7uucrK1K1bt1S/yL722mty5vP2f6QQQoiZM2cKAEKpVMpBWVFDhw4VAERCQoLIyMhwuv/888/LWbg7LRvq6bhnZmaKAwcOuL1vtVrFY489Jmdz8vPzncp4+7lVZt78vN9uwoQJAoCYNm2aGDZsWImBWzCPe3li4BZEOnbsKACIzp07u7xvtVpFYmKiACCeeeYZH/fuzrV37163/xLOz6R82P/lukqVKuLatWslBm4cd8/NmzdP/mXT1S9FxeG4e+6uu+4SAMQTTzzhtszjjz8uAIhevXo5XOe4l01pf5GtU6eOPJ3RlZycHBEeHi4AiNdff93hXm5urpy1njFjhsv69uwSALFw4UKP3ktl4mkAcbuVK1fK43bw4EGn+958bnciT8Z9z549QqFQiMaNG4v8/PxSBW4c9/LBzUmChF6vx+7duwEA3bt3d1lGkiQ89thjAIAtW7b4rG93upCQEPm1xWKRX/MzKT+jRo1CXl4ePvjgA1StWrXYshx373zxxRcAgAEDBjj8bJeE4+6d+vXrAwB+++03mM1mp/smkwmHDx8GALRu3Vq+znGvGL///jvOnz8PwP24hoeHo2PHjgCcx/Wnn35Cfn5+sfXr1auHu+++22V9cs/d37mA958bAQaDASNHjoQQAvPnzy/V3wMc9/LDwC1InDx5ElarFQDQrFkzt+Xs965cuYL09HSf9O1Ot2PHDvl18+bN5df8TMrH559/jm3btqFLly545plnSizPcfecwWDA/v37AQCtWrXC+fPn8fzzz6N27drQaDSoVq0aevfujQ0bNjjV5bh7Z8yYMQCAP//8E4MHD8aff/4p3/v999/x5JNP4uzZs2jQoAH++c9/yvc47hXj2LFj8uvSjOuJEye8qn/8+HGP+hmM7H/najQaNG7c2OGet58bAW+88QZOnjyJZ599Fp06dSpVHY57+WHgFiQuXbokv65Zs6bbckXvFa1DnsnMzMQ777wDAOjYsSPuuusu+R4/E+9dvHgRkyZNQmhoKD777LNS1eG4ey4tLU3eNv7s2bNo1qwZPv/8c1y7dg1hYWG4du0a1q9fj169emHUqFEOWztz3L3Tu3dvfPjhh9BoNPjqq6/QqFEj6HQ66HQ6NGnSBDt27MCYMWOwd+9eREZGyvU47hWjrOOanZ2N3Nxcp/oxMTEIDQ0tsT4/k9JJTU3FvHnzAAADBw50+H8B8P5zC3aHDh3Cv/71L1SrVg3vvfdeqetx3MsPA7cgkZOTI7/W6XRuyxW9V7QOlZ3VasXTTz+Ny5cvIyQkBJ9++qnDfX4m3hs9ejSysrKQnJwsTyUrCcfdcxkZGfLrt956C2q1GqtWrUJubi4yMjJw7tw5DBgwAADw3//+Fx9++KFcnuPuvQkTJuCbb75BfHw8ACA/P1+ebmc0GpGbm4usrCyHOhz3iuHtuNpfF1e36H1+JiXLz8/HgAEDoNfrERcXh1mzZjmV4f8PnjObzRg5ciTMZjM+/vhjREdHl7oux738MHAjqiAvvvgi1q9fDwD4z3/+g3vvvdfPPbqzfPnll9iwYQPuv/9+vPTSS/7uTlCwT7mzv16wYAH69+8PtVoNAKhTpw5WrFiB++67DwAwc+ZMl+uxqOz0ej0GDhyIXr16oU6dOtiyZQuuX7+O69evY8uWLbjnnnuwZMkStG3bFkeOHPF3d4l8ymw2Y8iQIThw4ADUajWWLl2KGjVq+Ltbd5RZs2bh8OHD6NWrF5588kl/dydoMXALEhEREfJrvV7vtlzRe0XrUNlMnDhRzrB9+OGHGDlypFMZfiaeu3r1KiZMmAClUonPP/8cKpWq1HU57p4rOg6NGjVC3759ncooFApMnDgRAHDz5k0cOHDAqS7HvewmTZqElStX4q677sKuXbvwt7/9DXFxcYiLi8Pf/vY3/Pjjj2jcuDFu3LiBsWPHyvU47hXD23G1vy6ubtH7/Ezcs1gseOqpp/Dtt99CpVJh2bJl6Nq1q8uy/P/BMydOnMCbb76J8PBwzJkzp8z1Oe7lh4FbkCj6L08XL150W67oPf5rlWcmT56M999/HwAwe/ZsTJgwwWU5fiaee/XVV3Hz5k08//zzaNKkCXJzcx2+7OuwADhd47h7rujahCZNmrgtd88998ivz507B4Dj7o2cnBzMnz8fADB27FiXu7iFhoZi3LhxAGw7Fl67dg0Ax72ilHVcIyMjER4e7lQ/IyNDnu5aXH1+Jq5ZLBYMHToUK1euhFKpxJdffon+/fu7Le/t5xasxo4dC6PRiGnTpiEmJsbp71z7zAohhHzNZDLJ9Tnu5YeBW5C4++67oVDYPu6iu/vczn4vISEBsbGxPunbnWTSpEnygt1//etfePnll92W5WfiudTUVADA3LlzERER4fRl3xAGgHxt8uTJADju3oiNjS12Ybld0U1JJEkCwHH3xh9//CH/YtSgQQO35Ro1aiS/tv8/wnGvGEV3xivNuBb9xwxP6jdt2tSjft7J7Jm2FStWyEHbwIEDi63j7ecWrOx/nkyZMsXl37lLly4FAJw/f16+9p///Eeuz3EvPwzcgoROp0OHDh0AAJs2bXJZRgiBzZs3A4DbaQbk3sSJEzF79mwAtqBt0qRJxZbnZ+IfHHfv2Mfj5MmTbssU3co5MTERAMfdG/bAC7iVwXTl6tWr8mv7NCOOe8Vo3Lgx6tSpA8D9uObl5WHXrl0AnMf1oYcekneTdFf/3Llz8v9n/FwcWSwWDBkyBP/73//koG3QoEEl1vP2cyPPcNzLkd+O/iaf++9//ysACEmSxC+//OJ0/3//+58AIACIrVu3+qGHldfLL78sj93s2bNLXY+fScWYPn26PG6ucNw99+OPP8pjs3r1aqf7FotF3HvvvQKAqFmzprBYLPI9jrtn9Hq9CA0NFQBEy5YthclkcipjNptF+/btBQARExMjzGazfI/jXjZ169YVAMT06dOLLffaa68JAEKn04nU1FSn+++++64AIJRKpfj999+d7g8dOlQAENWrVxeZmZlO98eMGSMAiIiICJGenu7p26k0SjvuZrNZDBw4UAAQKpVKrFixokztePu53WlKO+7FGTZsmAAg6tat67YMx718MHALIiaTSTRv3lz+hcr+F7TFYhErV64UkZGRAoDo3r27n3tauUyaNEn+peeDDz4oU11+JhWjpMCN4+6d/v37CwCiSpUq4quvvpIDiXPnzoknn3xSHvtFixY51OO4e278+PHyuD722GPiyJEjwmKxCIvFIn777TfRtWtX+f6MGTMc6nLci5eeni6uX78uf9WuXVsAEJMmTXK4npOT41AvMzNTJCQkCADinnvuEfv37xdCCGEwGMScOXOERqMRAMSYMWNctnv27FkRFhYmAIiOHTuKP/74QwghRG5urpgxY4aQJEkAEO+++27FDoCfeDLuZrNZDBo0SA7aVq5cWeZ2vf3cKjtPf96LU5rALdjHvbwwcAsyqampol69evJf8DqdToSEhMjft2jRIij+Za+8nDt3Th47hUIhqlWrVuzXe++95/QMfiblr6TATQiOuzdyc3PFww8/LI+VVqsVMTEx8vfF/estx90zer1ePPbYYw5jrNVqhVardbg2ePBgh2ybHcfdPXvGoaSvYcOGOdXdv3+/qFKlilwmIiJCqNVq+fuuXbuKgoICt21v2LBB6HQ6uXxUVJRQKpXy9yNGjBBWq7UC373/eDLuO3fulK+r1eoS/851l43z9nOrzLz5eXenNIGbEME97uWFa9yCTL169XDkyBG8/vrraNasGSRJglqtRqtWrTB79mz88ssviImJ8Xc3K43bz7W6evVqsV+5ublOz+Bn4h8cd8+FhYVh+/bt+Pzzz/Hwww8jLCwMubm5qFmzJgYNGoTdu3cjOTnZZV2Ou2dCQ0Px3XffYdWqVejTpw9q1aolbwJTu3ZtPPHEE1i/fj2WLVsGpVLpVJ/jXjFatWqF48eP45///CcaNWoEk8mEsLAwPPTQQ/j888+xceNGaLVat/V79OiBI0eOYNSoUahXrx4KCgoQExODv/3tb/jqq6+wcOFCeYMfcvw712Qylfh3rrsdO7393MgzHHfvSUIU2f6LiIiIiIiIAg4z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P//8M2bNmiXvgjl79mzExcU5PCMkJARLlixB165dodfr0aVLFzz99NPo27cvatWqBYPBgFOnTuG7777D2rVriw1QiYiocpKEEMLfnSAiIqooJpMJL774IubNm4eS/spLTEx0OHw6OTkZM2bMAGDL2j366KNITU11WfeJJ57AihUroFK5/jfRxYsXY/To0W6DKqVSiTfffBNTpkxx27/Nmzdj8ODBDscNuHL7+0xKSsLOnTvRqVMn7Nixw229ou+Xvx4QEQUWTpUkIqI7mlqtxpw5c/Dbb79h/PjxaN68OaKioqBUKhEVFYX7778fzz77LL766iucPHnS7XMSExNx4MABTJ06FXfffTd0Oh2ioqLw8MMP48svv8RXX33lNmgDgGHDhuHUqVN48cUXcffddyMsLAyhoaFo0KABRo0ahUOHDhUbtAFAt27dcPbsWcycORPt27dHlSpVoFQqERkZiZYtW2LChAnYu3evx2NFRESBixk3IiIiN5iBIiKiQMGMGxERERERUYBj4EZERERERBTgGLgREREREREFOAZuREREREREAY6BGxERERERUYDjrpJEREREREQBjhk3IiIiIiKiAMfAjYiIiIiIKMAxcCMiIiIiIgpwDNyIiIiIiIgCHAM3IiIiIiKiAMfAjYiIiIiIKMAxcCMiIiIiIgpwDNyIiIiIiIgC3P8H8mbDYsn5RroAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 1000x800 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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3377bU2ePFmSFBgYqGnTpumaa65RVFSU8vLytGPHDi1fvlw//vhjlbHKysrUrl07jRw5Updddpni4uLk6+urAwcO6OOPP9Ybb7yhY8eOaeTIkfr+++/VokWLBv17AgAAgGsQ3FAvKUkpWjxmsXTGRoI5mTlaPGaxxi4d69Xh7S9/+YsyMjIkSU899ZQeffRR+7XevXtrzJgxuv766/Xhhx9WubcilG3ZssX+WseOHRUfH1+lbVZWlu6++25JUosWLbR+/Xp17dq1UpuEhARNnz7dXs/pZs+erXbt2skwjEqvX3rppRo9erTuvfdeXXnllfrll1/073//W3/5y19q+TcAAAAAT0JwO8+YpqnSglKnjmGz2rTmd2uqhLbyAiQZ0poZa9R2aFunLpv0C/arElgaQklJiV5//XVJUvfu3fXII49UHdvPT6+//rratWun0tL6/33/+9//VkFBgSTp1VdfrRLaTte6desqr7Vv3/6s/Xfr1k133HGHnn/+eb3//vsENwAAAC9FcDvPlBaU6unQp91bhCnlHszV3yP+7tRhHs17VP4h/g3e79atW3XixAlJ0pQpU2oMh7Gxsbr66qu1atWqeo+1cuVKSVK7du10ww031LufCidOnNDx48dVVFRkP1etSZMmkqTdu3ertLSUHS4BAAC8EMENOMPOnTvtn/fp0+esbS+77LJ6B7fS0lL7M3L9+/ev9+zhzp079dxzz2nNmjU6fPhwje1sNptOnDhR6Tm36p7Rq9C2bVuFhITUqyYAAAA0LILbecYv2E+P5j167oYOOPDZAb1z7TvnbDdx9US1uaqN0+rwC3bOzNHx48ftn59rM4+WLVs6NE7FrFh0dHS9+nj99dd19913q6ysrFbtCwsLK33drVu3Gttu2LBBAwcOrFddAAAAaFgEt/OMYRhOWT54uvZXt1d4bLhyMnOqf87NKN9dsv3V7b3+aABnPEPXUH744Qd7aGvRooUefPBBDR48WPHx8QoLC7MviXzjjTd0++23S5I9KAIAAMC7ENxQZxYfixLnJpbvKmmocng7lXMSn0/02tDWtGlT++dHjhxRx44da2x75MiReo8TGRkpi8Uim82mrKysOt//1ltvqaysTD4+Pvr000/VuXPnatudPoN4JoIcAACAd/DOd9Zwuy6jumjs0rEKjwmv9Hp4bLjXHwVw+vLBb7755qxtz3X9bPz8/Oy7SCYnJ9c5RO3atUuSdMkll9QY2qTKxxIAAADAO3l9cMvNzdWsWbPUrVs3hYaGKiIiQn369NGzzz6rkpKSevWZmZmpl156STfddJMuvPBCBQUFKSgoSG3bttWECRP0ySefNPB34Z26jOqiGWkzNGXDFI16Z5SmbJiiGakzvDq0SeXntFXMur399ts1BqrMzMxqz3Gri+HDh0uSUlNT9cEHH9Tp3orn2vLz82tsk5WVpeXLl9e/QAAAAHgErw5uBw4cUPfu3TV79mx9//33Mk1TxcXF2rJlix544AFdccUV9m3daysjI0OtW7fW9OnTtXTpUu3bt08Wi0WGYSgtLU2LFi3SkCFDdPvtt8tqtTrpO/MeFh+L4gfGq9uEboofGO+1yyNPFxAQoFtvvVWStH37dj3zzDNV2pSVlWnatGn1/uVAhd/+9rf2nRvvuuuus+7yePDgwUpfd+jQQZL0448/6osvvqjSvqCgQBMnTqyyIQkAAAC8j9e+yy4rK9Pw4cOVlpam6OhoffTRR8rPz1dBQYEWLVqksLAwbdu2TZMmTapTv1arVaZpasiQIZo3b54yMzOVn5+vvLw87dq1SyNGjJBUvuHDrFmznPCdwRM8+eSTio2NlSQ9/PDDmjhxotauXatvv/1WixYt0pVXXqk1a9bo0ksvdWicqKgovfzyy5Kkn3/+WZdddplmzJihtWvXavv27dq0aZP+85//6Nprr9WAAQMq3XvLLbdIKt/m/7rrrtNTTz2lzz77TJs3b9bLL7+sHj16aOPGjerXr59DNQIAAMADmF7qtddeM1W+LYb5xRdfVLn+zjvv2K9//PHHte735MmT5tatW2u8brPZzMTERFOSGRoaahYWFtap7uzsbFOSmZ2dXaf7CgsLzd27d9d5PNTf999/b0ZFRdl/js78mDp1qvnmm2/av05NTa10/9munemtt94yg4KCahxLktmmTZsq982ePfus99x///11quNsBgwYYEoyBwwYUO31ijH+9Kc/1XsM1A7/HgAAcH6oSzbw2hm3efPmSZIGDRqkvn37Vrk+fvx4tW3bVpI0f/78WvcbERGhXr161XjdMAzddtttkqS8vDylpKTUpWx4kYsvvli7du3SQw89pA4dOiggIEDNmzfXoEGD9M477+jNN99ssLGmTJmiffv26fHHH1fv3r3VpEkT+fj4qGnTprriiiv02GOPae3atVXue/LJJ7Vq1SpdffXVatq0qfz9/RUbG6tRo0bpww8/1Jw5cxqsRgAAALiPYZretx94QUGBwsLCZLPZ9I9//EMPPvhgte3uvfdevfzyy4qKiqrXdus1WbFihW644QZJ5bsK1mW5XE5OjiIiIpSdna3w8PBz33BKUVGRUlNT1bZtWwUGBta5ZgDnD/49AADg/FCXbOCVM24pKSmy2WySZN9OvToV1w4fPnzWs6zqauPGjZIkf3//s57xBQAAAAANwSsP4D506JD985iYmBrbnX7t0KFDioyMdHjs1NRU/ec//5EkjRs37pzJuLi4WMXFxfavc3JyHK4BAAAAQOPilTNuubm59s+Dg4NrbHf6tdPvqa/CwkLddNNNKigoUPPmzfW3v/3tnPc8/fTTioiIsH+0bt3a4ToAAAAANC5eGdzcoaysTBMnTtTWrVvl5+enhQsXqlWrVue879FHH1V2drb9IyMjwwXVAgAAADifeOVSybCwMPvnBQUFNbY7/drp99SV1WrVzTffrPfff1++vr565513dPXVV9fq3oCAAAUEBNR7bAAAAADwyhm302e6MjMza2x3+rXazI5Vx2q1atKkSVq8eLF8fHy0YMECjRkzpl59AQAAAEB9eGVw69KliyyW8tK///77GttVXIuKiqrXxiQVM22LFi2yh7Zx48bVr2gAAAAAqCevDG7BwcHq16+fJFV7KLEkmaapdevWSVKtlzWezmq1auLEiXr33XftoW38+PH1LxoAAAAA6skrg5skTZkyRZK0YcMGff3111WuL1myRPv375ckTZ48uU59V8y0LV68WL6+vlq4cCGhDQAAAIDbeHVw69atm0zT1OjRo7V+/XpJks1m05IlSzRt2jRJ0jXXXKMhQ4ZUunfWrFkyDEOGYSgtLa3StYpn2t599137RiQsjwQAAADgTl65q6Qk+fr6avny5Ro0aJDS0tI0dOhQBQcHy2azqaioSJLUs2dPLVy4sE79fv7551q0aJEkyTAM3XfffbrvvvtqbD937lyCHQAAAACn8trgJknx8fHasWOH5syZo6SkJKWmpsrPz08XX3yxJkyYoPvuu0/+/v516tNms9k/Ly0t1ZEjR87avrCwsF61AwAAAEBtGaZpmu4uojHJyclRRESEsrOzFR4eXuv7ioqKlJqa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H0bnzp211lOdQXyYvomc8meSkZHxyLr61CEiIiKimjEzdABkmkZ0GYEdr+1AG7s2avtd7VxN/lUAqrcPnj59utq6jyqvjkwmE1eRPHLkSI1nwy5evAgAeOqpp3QmbYD6awlqy9PTEwBw48YN8bZJbbKysnDjxo06H4+IiIiI1DFxo1ob0WUEUmalID44HlEjohAfHI/kWckmnbQBVe9pU84wbdq0SWdClZqaqvU9bjUxdOhQAEBycjJ27dpVo7bK59oKCgp01rl37x6io6NrH+D/DBo0CEDVAidRUVE66/3000+8HZOIiIioATBxozqRmknh184PY7zHwK+dn8neHqnK0tISISEhAIBz585h+fLlGnXKy8sxZcoUlJaW1ulYb731lrhy49SpU6td5fHOnTtq33fs2BEAcPXqVRw/flyjfmFhIcaOHauxIEltvPzyy+JCLWFhYVoXH7l69SoWL15c52MRERERkSYmbkRafPjhh3B1dQUAvP/++xg7dixiYmJw5swZbN26FX369MH+/fvRo0ePOh3HxcUF3333HQDgn3/+ga+vL2bNmoWYmBicO3cOR48exZo1azBkyBD0799fre2ECRMAVM2Cvfjii1i6dCn++9//4tSpU/juu+/w9NNP49ChQ+jbt2+dYgQAKysrfPnllwCAzMxM9OrVC8uXL8fJkydx8uRJfP7553j22WdRWVkpJpTGvLALERERkanh4iREWtjb2yMmJgb+/v5IS0vDli1bsGXLFrU6kyZNQv/+/cXZudqaMGECKisrMX36dBQVFeHrr7/G119/rVHPzc1N7fuePXti8eLFCA0NxYMHD7Bw4UKNNu+99x68vLxw7NixOsUIAGPGjMGNGzfwf//3f7h//z7mzZunVi6Xy7F9+3Z89tlnuHr1KqysrOp8TCIiIiKqwhk3Ih08PT1x8eJFzJs3Dx07doSlpSWcnJwwYMAAREVFISIiot6OFRwcjOvXr2PhwoXw8fFBs2bNIJVK4eDggGeffRYLFixATEyMRrsPP/wQe/fuRUBAABwcHGBhYQFXV1eMGDECBw4cQHh4eL3FCAALFy7E4cOHMXz4cDg7O8PS0hJubm6YPHkyEhISMGTIEOTm5gKoSn6JiIiIqH5IBK4k8Fjl5ubC3t4eOTk5sLOz07tdcXExkpOT4e7uzpkMMlplZWWwt7dHUVER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",
      "text/plain": [
       "<Figure size 1000x800 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "r_ifca = {}\n",
    "r_dfca_gi = {}\n",
    "r_dfca_li = {}\n",
    "r_d_fedavg_m = {}\n",
    "\n",
    "r_d_fedavg_m['test_loss'] = []\n",
    "r_d_fedavg_m['test_acc'] = []\n",
    "r_d_fedavg_m['cl_acc'] = []\n",
    "r_d_fedavg_m['train_loss'] = []\n",
    "for i in range(len(learning_rates)):\n",
    "    r_d_fedavg_m['test_loss'].append(d_fedavg_m[i][0])\n",
    "    r_d_fedavg_m['test_acc'].append(d_fedavg_m[i][1])\n",
    "    r_d_fedavg_m['cl_acc'].append(d_fedavg_m[i][2])\n",
    "    r_d_fedavg_m['train_loss'].append(d_fedavg_m[i][3])\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",
    "r_d_fedavg_m_test_acc = [acc_list[-1] for acc_list in r_d_fedavg_m['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",
    "print(\"DFedAvgM Acc: \", d_fedavg_m_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",
    "print(\"DFedAvgM Avg Acc (%): \", r_d_fedavg_m_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",
    "print(\"DFedAvgM Std: \", d_fedavg_m_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.plot(r_d_fedavg_m['test_loss'][l], label='d-fedavg-m', color='red')\n",
    "    plt.xlabel('epoch', fontsize=20)\n",
    "    plt.ylabel('loss', fontsize=20)\n",
    "    plt.title(f'Test Loss per Epoch (lr={learning_rates[l]})', fontsize=22, fontweight='bold')\n",
    "    plt.tick_params(axis='both', which='major', labelsize=18)\n",
    "    plt.legend(fontsize=20)\n",
    "    plt.savefig(os.path.join('graphs', '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.plot(r_d_fedavg_m['train_loss'][l], label='d-fedavg-m', color='red')\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.plot(r_d_fedavg_m['test_acc'][l], label='d-fedavg-m', color='red')\n",
    "    plt.xlabel('epoch', fontsize=20)\n",
    "    plt.ylabel('test accuracy', fontsize=20)\n",
    "    plt.title(f'Test Accuracy per Epoch (lr={learning_rates[l]})', fontsize=22, fontweight='bold')\n",
    "    plt.tick_params(axis='both', which='major', labelsize=18)\n",
    "    plt.legend(fontsize=20)\n",
    "    plt.savefig(os.path.join('graphs', 'test_acc.png'))\n",
    "\n",
    "    plt.figure(figsize=(10,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.plot(r_d_fedavg_m['cl_acc'][l][:31], label='d-fedavg-m', color='red', marker='o')\n",
    "    plt.xlabel('epoch', fontsize=20)\n",
    "    plt.ylabel('cluster acc', fontsize=20)\n",
    "    plt.legend(fontsize=20)\n",
    "    plt.tick_params(axis='both', which='major', labelsize=18)\n",
    "    plt.savefig(os.path.join('graphs', 'cluster_acc.png'))"
   ]
  }
 ],
 "metadata": {
  "accelerator": "GPU",
  "colab": {
   "gpuType": "T4",
   "provenance": []
  },
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.11.11"
  },
  "widgets": {
   "application/vnd.jupyter.widget-state+json": {
    "state": {
     "1cdb0e996e3d487b8e962ece2d397411": {
      "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
      }
     },
     "232481b23cb44adba9acda17c344a382": {
      "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_9224d1ac7aaf4a9c9fab28f83f223231",
       "placeholder": "​",
       "style": "IPY_MODEL_2f7980491718421e857b279a93e58aeb",
       "tabbable": null,
       "tooltip": null,
       "value": "unknown: 100%"
      }
     },
     "2f54003fc4264895adb2d21e0af2f9b8": {
      "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
      }
     },
     "2f7980491718421e857b279a93e58aeb": {
      "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
      }
     },
     "39f5250c8fa041458d92a42b2a73a729": {
      "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
      }
     },
     "3a2b1fc5b79e42099489903bcfc6a16f": {
      "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_eefaae5f5fe24de287819e8857fc594c",
       "max": 4.0,
       "min": 0.0,
       "orientation": "horizontal",
       "style": "IPY_MODEL_5822055c708545bebec0d38711db9c12",
       "tabbable": null,
       "tooltip": null,
       "value": 4.0
      }
     },
     "3fb9b5f766c5486c860bcbaad84d5657": {
      "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
      }
     },
     "404a54008ac943ad9d7aa6f7909af256": {
      "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
      }
     },
     "525be0f7173f4c4d810586cbdf426c34": {
      "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
      }
     },
     "57271b119ad04718985c38de740ec479": {
      "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
      }
     },
     "5822055c708545bebec0d38711db9c12": {
      "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": ""
      }
     },
     "747ed79836834996917bd357c0b5a52f": {
      "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_9085822ec3f945dfbfdb754727340120",
       "placeholder": "​",
       "style": "IPY_MODEL_39f5250c8fa041458d92a42b2a73a729",
       "tabbable": null,
       "tooltip": null,
       "value": "100%"
      }
     },
     "7bba9005364d4750b45d56ce661f61c1": {
      "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_1cdb0e996e3d487b8e962ece2d397411",
       "placeholder": "​",
       "style": "IPY_MODEL_8ad87d0344de42f18c695beafbbbbf6c",
       "tabbable": null,
       "tooltip": null,
       "value": " 4/4 [00:05&lt;00:00,  5.48s/engine]"
      }
     },
     "81f9b7df3b344b4c992589a527667e42": {
      "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_232481b23cb44adba9acda17c344a382",
        "IPY_MODEL_3a2b1fc5b79e42099489903bcfc6a16f",
        "IPY_MODEL_8e6a0855a3104c058492b637236651ed"
       ],
       "layout": "IPY_MODEL_404a54008ac943ad9d7aa6f7909af256",
       "tabbable": null,
       "tooltip": null
      }
     },
     "8ad87d0344de42f18c695beafbbbbf6c": {
      "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
      }
     },
     "8e6a0855a3104c058492b637236651ed": {
      "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_2f54003fc4264895adb2d21e0af2f9b8",
       "placeholder": "​",
       "style": "IPY_MODEL_525be0f7173f4c4d810586cbdf426c34",
       "tabbable": null,
       "tooltip": null,
       "value": " 4/4 [1:20:27&lt;00:00, 233.39s/tasks]"
      }
     },
     "9085822ec3f945dfbfdb754727340120": {
      "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
      }
     },
     "9224d1ac7aaf4a9c9fab28f83f223231": {
      "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
      }
     },
     "ad34d9d81a9b4a3aa7e1f8ff4b0efdef": {
      "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": ""
      }
     },
     "baa228d53bbe4be4ad9ad664ca0c87ac": {
      "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_747ed79836834996917bd357c0b5a52f",
        "IPY_MODEL_d1ea583b74ec4935a2d848b28b8aa7ac",
        "IPY_MODEL_7bba9005364d4750b45d56ce661f61c1"
       ],
       "layout": "IPY_MODEL_57271b119ad04718985c38de740ec479",
       "tabbable": null,
       "tooltip": null
      }
     },
     "d1ea583b74ec4935a2d848b28b8aa7ac": {
      "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_3fb9b5f766c5486c860bcbaad84d5657",
       "max": 4.0,
       "min": 0.0,
       "orientation": "horizontal",
       "style": "IPY_MODEL_ad34d9d81a9b4a3aa7e1f8ff4b0efdef",
       "tabbable": null,
       "tooltip": null,
       "value": 4.0
      }
     },
     "eefaae5f5fe24de287819e8857fc594c": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {
       "_model_module": "@jupyter-widgets/base",
       "_model_module_version": "2.0.0",
       "_model_name": "LayoutModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "2.0.0",
       "_view_name": "LayoutView",
       "align_content": null,
       "align_items": null,
       "align_self": null,
       "border_bottom": null,
       "border_left": null,
       "border_right": null,
       "border_top": null,
       "bottom": null,
       "display": null,
       "flex": null,
       "flex_flow": null,
       "grid_area": null,
       "grid_auto_columns": null,
       "grid_auto_flow": null,
       "grid_auto_rows": null,
       "grid_column": null,
       "grid_gap": null,
       "grid_row": null,
       "grid_template_areas": null,
       "grid_template_columns": null,
       "grid_template_rows": null,
       "height": null,
       "justify_content": null,
       "justify_items": null,
       "left": null,
       "margin": null,
       "max_height": null,
       "max_width": null,
       "min_height": null,
       "min_width": null,
       "object_fit": null,
       "object_position": null,
       "order": null,
       "overflow": null,
       "padding": null,
       "right": null,
       "top": null,
       "visibility": null,
       "width": null
      }
     }
    },
    "version_major": 2,
    "version_minor": 0
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
