{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-19T01:42:12.535095Z",
     "iopub.status.busy": "2025-09-19T01:42:12.534518Z",
     "iopub.status.idle": "2025-09-19T01:42:17.170127Z",
     "shell.execute_reply": "2025-09-19T01:42:17.169387Z"
    },
    "id": "OHJWesKs-tqd"
   },
   "outputs": [],
   "source": [
    "import json\n",
    "import os\n",
    "import time\n",
    "import ipyparallel as ipp\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "import torch\n",
    "import dfca as DFCA\n",
    "import ifca as IFCA\n",
    "\n",
    "import numpy as np\n",
    "\n",
    "from util import *"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-19T01:42:17.173111Z",
     "iopub.status.busy": "2025-09-19T01:42:17.172831Z",
     "iopub.status.idle": "2025-09-19T01:42:24.122792Z",
     "shell.execute_reply": "2025-09-19T01:42:24.121701Z"
    }
   },
   "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": "c9d08d8972d944f5bf145660a4be587e",
       "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-19T01:42:24.126484Z",
     "iopub.status.busy": "2025-09-19T01:42:24.126039Z",
     "iopub.status.idle": "2025-09-19T01:42:24.131523Z",
     "shell.execute_reply": "2025-09-19T01:42:24.130590Z"
    }
   },
   "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-19T01:42:24.134762Z",
     "iopub.status.busy": "2025-09-19T01:42:24.134347Z",
     "iopub.status.idle": "2025-09-19T01:42:24.158014Z",
     "shell.execute_reply": "2025-09-19T01:42:24.156850Z"
    }
   },
   "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": "code",
   "execution_count": 5,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 1000
    },
    "execution": {
     "iopub.execute_input": "2025-09-19T01:42:24.161829Z",
     "iopub.status.busy": "2025-09-19T01:42:24.161326Z",
     "iopub.status.idle": "2025-09-19T01:42:24.173033Z",
     "shell.execute_reply": "2025-09-19T01:42:24.172126Z"
    },
    "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:3\" if torch.cuda.is_available() else \"cpu\")\n",
    "        print(f\"Using device: {device}\")\n",
    "\n",
    "        exp = DFCA.TrainEMNISTCluster(config, device)\n",
    "        exp.setup()\n",
    "        res = exp.run()\n",
    "        res_final.append([[r['test']['loss'] for r in res], [r['test']['acc'] for r in res], [r['test']['cl_acc'] for r in res], [r['train']['loss'] for r in res]])\n",
    "        del exp\n",
    "        duration = (time.time() - start_time)\n",
    "        print(\"---train cluster Ended in %0.2f hour (%.3f sec) \" % (duration/float(3600), duration))\n",
    "\n",
    "    res_mean = np.mean(res_final, axis=0).tolist()\n",
    "    last_accs = [run[1][-1] * 100 for run in res_final]\n",
    "    res_std = np.std(last_accs)\n",
    "    dfca_gi.append(res_mean)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-19T01:42:24.176359Z",
     "iopub.status.busy": "2025-09-19T01:42:24.175923Z",
     "iopub.status.idle": "2025-09-19T01:42:24.186283Z",
     "shell.execute_reply": "2025-09-19T01:42:24.185374Z"
    }
   },
   "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:3\" if torch.cuda.is_available() else \"cpu\")\n",
    "        print(f\"Using device: {device}\")\n",
    "\n",
    "        exp = DFCA.TrainEMNISTCluster(config, device)\n",
    "        exp.setup()\n",
    "        res = exp.run()\n",
    "        res_final.append([[r['test']['loss'] for r in res], [r['test']['acc'] for r in res], [r['test']['cl_acc'] for r in res], [r['train']['loss'] for r in res]])\n",
    "        del exp\n",
    "        duration = (time.time() - start_time)\n",
    "        print(\"---train cluster Ended in %0.2f hour (%.3f sec) \" % (duration/float(3600), duration))\n",
    "\n",
    "    res_mean = np.mean(res_final, axis=0).tolist()\n",
    "    last_accs = [run[1][-1] * 100 for run in res_final]\n",
    "    res_std = np.std(last_accs)\n",
    "    dfca_li.append(res_mean)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-19T01:42:24.189768Z",
     "iopub.status.busy": "2025-09-19T01:42:24.189349Z",
     "iopub.status.idle": "2025-09-19T01:42:24.200936Z",
     "shell.execute_reply": "2025-09-19T01:42:24.200038Z"
    }
   },
   "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:3\" if torch.cuda.is_available() else \"cpu\")\n",
    "        print(f\"Using device: {device}\")\n",
    "\n",
    "        exp = IFCA.TrainEMNISTCluster(config, device)\n",
    "        exp.setup()\n",
    "        res = exp.run()\n",
    "        res_final.append([[r['test']['loss'] for r in res], [r['test']['acc'] for r in res], [r['test']['cl_acc'] for r in res], [r['train']['loss'] for r in res]])\n",
    "        del exp\n",
    "        duration = (time.time() - start_time)\n",
    "        print(\"---train cluster Ended in %0.2f hour (%.3f sec) \" % (duration/float(3600), duration))\n",
    "\n",
    "    res_mean = np.mean(res_final, axis=0).tolist()\n",
    "    last_accs = [run[1][-1] * 100 for run in res_final]\n",
    "    res_std = np.std(last_accs)\n",
    "    ifca.append(res_mean)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-19T01:42:24.204668Z",
     "iopub.status.busy": "2025-09-19T01:42:24.204246Z",
     "iopub.status.idle": "2025-09-19T01:42:24.215550Z",
     "shell.execute_reply": "2025-09-19T01:42:24.214674Z"
    }
   },
   "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'] = 3\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:3\" if torch.cuda.is_available() else \"cpu\")\n",
    "        print(f\"Using device: {device}\")\n",
    "\n",
    "        exp = DFedAvgM.TrainEMNISTCluster(config, device)\n",
    "        exp.setup()\n",
    "        res = exp.run()\n",
    "        res_final.append([[r['test']['loss'] for r in res], [r['test']['acc'] for r in res], [r['test']['cl_acc'] for r in res], [r['train']['loss'] for r in res]])\n",
    "        del exp\n",
    "        duration = (time.time() - start_time)\n",
    "        print(\"---train cluster Ended in %0.2f hour (%.3f sec) \" % (duration/float(3600), duration))\n",
    "\n",
    "    res_mean = np.mean(res_final, axis=0).tolist()\n",
    "    last_accs = [run[1][-1] * 100 for run in res_final]\n",
    "    res_std = np.std(last_accs)\n",
    "    d_fedavg_m.append(res_mean)\n",
    "\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-19T01:42:24.218916Z",
     "iopub.status.busy": "2025-09-19T01:42:24.218518Z",
     "iopub.status.idle": "2025-09-19T06:26:17.147679Z",
     "shell.execute_reply": "2025-09-19T06:26:17.146355Z"
    }
   },
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "4ca9b84c6b8749c4b71d3c614fc3bf4f",
       "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': 100, 'm_test': 20, 'p': 2, 'n': 1500, 'uneven': True, 'local_model_init': False, 'Gp': 0.15, 'graph': 'er', 'agg': 'seq', 'h1': 512, 'num_epochs': 150, 'batch_size': 100, 'tau': 3, 'lr': 0.1, 'data_seed': 6003, 'train_seed': 6003, 'config_override': '', 'project_dir': 'output_dfca_gi'}\n",
      "Using device: cuda:3\n",
      "Epoch -1 tr: l 3.890 a 0.017 clct[np.int64(100), np.int64(0)] cl_acc 0.500  2.315sec\n",
      "Epoch -1 tst: l 3.885 a 0.016 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.436sec\n",
      "Epoch 0 tr: l 3.506 a 0.196 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.100000 11.525sec(train) 4.457sec(infer)\n",
      "Epoch 0 tst: l 3.573 a 0.159 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.819sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 1 tr: l 3.154 a 0.310 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.099500 12.092sec(train) 4.114sec(infer)\n",
      "Epoch 1 tst: l 3.246 a 0.259 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.850sec\n",
      "Epoch 2 tr: l 2.805 a 0.381 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.099003 12.685sec(train) 3.992sec(infer)\n",
      "Epoch 2 tst: l 2.916 a 0.322 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.854sec\n",
      "Epoch 3 tr: l 2.501 a 0.437 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.098507 12.228sec(train) 4.660sec(infer)\n",
      "Epoch 3 tst: l 2.626 a 0.375 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.984sec\n",
      "Epoch 4 tr: l 2.256 a 0.480 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.098015 12.520sec(train) 3.871sec(infer)\n",
      "Epoch 4 tst: l 2.390 a 0.418 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.969sec\n",
      "Epoch 5 tr: l 2.063 a 0.512 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.097525 13.301sec(train) 3.576sec(infer)\n",
      "Epoch 5 tst: l 2.201 a 0.451 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.667sec\n",
      "Epoch 6 tr: l 1.909 a 0.536 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.097037 13.136sec(train) 4.453sec(infer)\n",
      "Epoch 6 tst: l 2.050 a 0.479 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.833sec\n",
      "Epoch 7 tr: l 1.784 a 0.557 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.096552 11.431sec(train) 4.698sec(infer)\n",
      "Epoch 7 tst: l 1.925 a 0.500 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.979sec\n",
      "Epoch 8 tr: l 1.683 a 0.573 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.096069 12.239sec(train) 3.992sec(infer)\n",
      "Epoch 8 tst: l 1.825 a 0.521 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.865sec\n",
      "Epoch 9 tr: l 1.620 a 0.573 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.095589 13.474sec(train) 4.045sec(infer)\n",
      "Epoch 9 tst: l 1.762 a 0.520 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.828sec\n",
      "Epoch 10 tr: l 1.594 a 0.565 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.095111 12.507sec(train) 4.003sec(infer)\n",
      "Epoch 10 tst: l 1.735 a 0.520 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.967sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 11 tr: l 1.538 a 0.568 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.094635 12.441sec(train) 4.088sec(infer)\n",
      "Epoch 11 tst: l 1.681 a 0.520 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.818sec\n",
      "Epoch 12 tr: l 1.457 a 0.596 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.094162 13.362sec(train) 3.659sec(infer)\n",
      "Epoch 12 tst: l 1.599 a 0.551 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.699sec\n",
      "Epoch 13 tr: l 1.392 a 0.609 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.093691 12.390sec(train) 4.662sec(infer)\n",
      "Epoch 13 tst: l 1.534 a 0.563 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.984sec\n",
      "Epoch 14 tr: l 1.344 a 0.625 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.093223 11.173sec(train) 4.697sec(infer)\n",
      "Epoch 14 tst: l 1.490 a 0.578 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.987sec\n",
      "Epoch 15 tr: l 1.297 a 0.632 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.092757 13.526sec(train) 3.432sec(infer)\n",
      "Epoch 15 tst: l 1.441 a 0.586 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.870sec\n",
      "Epoch 16 tr: l 1.255 a 0.645 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.092293 13.759sec(train) 3.814sec(infer)\n",
      "Epoch 16 tst: l 1.402 a 0.598 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.677sec\n",
      "Epoch 17 tr: l 1.224 a 0.649 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.091832 11.893sec(train) 4.574sec(infer)\n",
      "Epoch 17 tst: l 1.371 a 0.603 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.919sec\n",
      "Epoch 18 tr: l 1.189 a 0.659 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.091372 12.150sec(train) 4.248sec(infer)\n",
      "Epoch 18 tst: l 1.337 a 0.612 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.986sec\n",
      "Epoch 19 tr: l 1.160 a 0.662 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.090916 13.025sec(train) 3.997sec(infer)\n",
      "Epoch 19 tst: l 1.310 a 0.616 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.697sec\n",
      "Epoch 20 tr: l 1.137 a 0.669 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.090461 12.303sec(train) 4.658sec(infer)\n",
      "Epoch 20 tst: l 1.287 a 0.623 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.997sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 21 tr: l 1.112 a 0.674 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.090009 12.001sec(train) 4.107sec(infer)\n",
      "Epoch 21 tst: l 1.265 a 0.626 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.967sec\n",
      "Epoch 22 tr: l 1.096 a 0.676 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.089559 13.868sec(train) 2.954sec(infer)\n",
      "Epoch 22 tst: l 1.247 a 0.632 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.629sec\n",
      "Epoch 23 tr: l 1.099 a 0.674 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.089111 13.365sec(train) 4.659sec(infer)\n",
      "Epoch 23 tst: l 1.259 a 0.625 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.906sec\n",
      "Epoch 24 tr: l 1.083 a 0.675 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.088665 10.904sec(train) 4.667sec(infer)\n",
      "Epoch 24 tst: l 1.238 a 0.630 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.981sec\n",
      "Epoch 25 tr: l 1.045 a 0.690 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.088222 12.487sec(train) 3.840sec(infer)\n",
      "Epoch 25 tst: l 1.202 a 0.643 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.889sec\n",
      "Epoch 26 tr: l 1.013 a 0.697 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.087781 13.446sec(train) 4.024sec(infer)\n",
      "Epoch 26 tst: l 1.170 a 0.649 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.827sec\n",
      "Epoch 27 tr: l 0.995 a 0.704 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.087342 12.406sec(train) 3.957sec(infer)\n",
      "Epoch 27 tst: l 1.153 a 0.656 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.890sec\n",
      "Epoch 28 tr: l 0.980 a 0.705 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.086905 12.555sec(train) 4.074sec(infer)\n",
      "Epoch 28 tst: l 1.143 a 0.656 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.827sec\n",
      "Epoch 29 tr: l 0.964 a 0.711 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.086471 13.398sec(train) 3.978sec(infer)\n",
      "Epoch 29 tst: l 1.126 a 0.665 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.814sec\n",
      "Epoch 30 tr: l 0.951 a 0.711 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.086038 12.172sec(train) 4.646sec(infer)\n",
      "Epoch 30 tst: l 1.118 a 0.660 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.842sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 31 tr: l 0.939 a 0.717 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.085608 11.689sec(train) 4.493sec(infer)\n",
      "Epoch 31 tst: l 1.105 a 0.668 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.983sec\n",
      "Epoch 32 tr: l 0.931 a 0.715 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.085180 13.207sec(train) 3.760sec(infer)\n",
      "Epoch 32 tst: l 1.102 a 0.663 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.842sec\n",
      "Epoch 33 tr: l 0.918 a 0.722 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.084754 13.470sec(train) 3.540sec(infer)\n",
      "Epoch 33 tst: l 1.089 a 0.672 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.697sec\n",
      "Epoch 34 tr: l 0.907 a 0.722 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.084331 12.634sec(train) 4.636sec(infer)\n",
      "Epoch 34 tst: l 1.080 a 0.670 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.983sec\n",
      "Epoch 35 tr: l 0.891 a 0.728 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.083909 12.039sec(train) 4.013sec(infer)\n",
      "Epoch 35 tst: l 1.064 a 0.677 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.842sec\n",
      "Epoch 36 tr: l 0.882 a 0.729 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.083489 12.532sec(train) 4.229sec(infer)\n",
      "Epoch 36 tst: l 1.056 a 0.676 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.977sec\n",
      "Epoch 37 tr: l 0.870 a 0.733 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.083072 12.480sec(train) 4.380sec(infer)\n",
      "Epoch 37 tst: l 1.046 a 0.682 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.847sec\n",
      "Epoch 38 tr: l 0.863 a 0.734 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.082657 13.248sec(train) 3.319sec(infer)\n",
      "Epoch 38 tst: l 1.041 a 0.679 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.967sec\n",
      "Epoch 39 tr: l 0.850 a 0.738 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.082243 13.288sec(train) 4.451sec(infer)\n",
      "Epoch 39 tst: l 1.027 a 0.687 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.734sec\n",
      "Epoch 40 tr: l 0.845 a 0.738 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.081832 12.309sec(train) 4.051sec(infer)\n",
      "Epoch 40 tst: l 1.025 a 0.683 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.833sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 41 tr: l 0.834 a 0.741 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.081423 12.555sec(train) 4.279sec(infer)\n",
      "Epoch 41 tst: l 1.009 a 0.691 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.970sec\n",
      "Epoch 42 tr: l 0.831 a 0.740 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.081016 12.099sec(train) 4.498sec(infer)\n",
      "Epoch 42 tst: l 1.012 a 0.686 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.837sec\n",
      "Epoch 43 tr: l 0.821 a 0.745 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.080611 12.533sec(train) 4.107sec(infer)\n",
      "Epoch 43 tst: l 0.994 a 0.694 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.967sec\n",
      "Epoch 44 tr: l 0.823 a 0.742 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.080208 13.150sec(train) 3.595sec(infer)\n",
      "Epoch 44 tst: l 1.010 a 0.686 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.708sec\n",
      "Epoch 45 tr: l 0.810 a 0.746 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.079807 13.336sec(train) 4.036sec(infer)\n",
      "Epoch 45 tst: l 0.984 a 0.696 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.793sec\n",
      "Epoch 46 tr: l 0.814 a 0.743 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.079408 11.748sec(train) 4.715sec(infer)\n",
      "Epoch 46 tst: l 1.006 a 0.687 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.968sec\n",
      "Epoch 47 tr: l 0.804 a 0.746 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.079010 11.968sec(train) 4.082sec(infer)\n",
      "Epoch 47 tst: l 0.976 a 0.697 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.853sec\n",
      "Epoch 48 tr: l 0.805 a 0.744 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.078615 13.329sec(train) 3.942sec(infer)\n",
      "Epoch 48 tst: l 1.001 a 0.687 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.805sec\n",
      "Epoch 49 tr: l 0.790 a 0.750 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.078222 12.751sec(train) 3.968sec(infer)\n",
      "Epoch 49 tst: l 0.968 a 0.700 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.986sec\n",
      "Epoch 50 tr: l 0.789 a 0.749 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.077831 12.551sec(train) 4.206sec(infer)\n",
      "Epoch 50 tst: l 0.984 a 0.692 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.826sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 51 tr: l 0.776 a 0.755 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.077442 13.234sec(train) 3.642sec(infer)\n",
      "Epoch 51 tst: l 0.951 a 0.705 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.814sec\n",
      "Epoch 52 tr: l 0.778 a 0.752 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.077055 12.658sec(train) 4.666sec(infer)\n",
      "Epoch 52 tst: l 0.976 a 0.694 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.874sec\n",
      "Epoch 53 tr: l 0.766 a 0.758 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.076670 11.136sec(train) 4.663sec(infer)\n",
      "Epoch 53 tst: l 0.941 a 0.708 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.978sec\n",
      "Epoch 54 tr: l 0.768 a 0.754 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.076286 13.226sec(train) 3.876sec(infer)\n",
      "Epoch 54 tst: l 0.965 a 0.696 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.981sec\n",
      "Epoch 55 tr: l 0.756 a 0.761 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.075905 13.830sec(train) 3.383sec(infer)\n",
      "Epoch 55 tst: l 0.934 a 0.711 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.594sec\n",
      "Epoch 56 tr: l 0.759 a 0.756 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.075525 12.412sec(train) 4.647sec(infer)\n",
      "Epoch 56 tst: l 0.960 a 0.698 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.836sec\n",
      "Epoch 57 tr: l 0.749 a 0.762 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.075148 11.852sec(train) 4.515sec(infer)\n",
      "Epoch 57 tst: l 0.927 a 0.713 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.984sec\n",
      "Epoch 58 tr: l 0.752 a 0.757 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.074772 12.980sec(train) 3.600sec(infer)\n",
      "Epoch 58 tst: l 0.953 a 0.698 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.715sec\n",
      "Epoch 59 tr: l 0.743 a 0.763 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.074398 12.490sec(train) 4.728sec(infer)\n",
      "Epoch 59 tst: l 0.923 a 0.714 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.975sec\n",
      "Epoch 60 tr: l 0.745 a 0.758 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.074026 12.062sec(train) 4.138sec(infer)\n",
      "Epoch 60 tst: l 0.950 a 0.699 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.992sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 61 tr: l 0.736 a 0.765 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.073656 13.860sec(train) 2.992sec(infer)\n",
      "Epoch 61 tst: l 0.916 a 0.715 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.764sec\n",
      "Epoch 62 tr: l 0.738 a 0.760 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.073288 13.739sec(train) 4.607sec(infer)\n",
      "Epoch 62 tst: l 0.943 a 0.701 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.854sec\n",
      "Epoch 63 tr: l 0.728 a 0.767 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.072921 11.131sec(train) 4.720sec(infer)\n",
      "Epoch 63 tst: l 0.908 a 0.716 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.990sec\n",
      "Epoch 64 tr: l 0.729 a 0.762 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.072557 12.123sec(train) 4.167sec(infer)\n",
      "Epoch 64 tst: l 0.936 a 0.703 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.989sec\n",
      "Epoch 65 tr: l 0.720 a 0.770 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.072194 13.507sec(train) 3.811sec(infer)\n",
      "Epoch 65 tst: l 0.900 a 0.718 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.696sec\n",
      "Epoch 66 tr: l 0.721 a 0.765 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.071833 12.796sec(train) 3.915sec(infer)\n",
      "Epoch 66 tst: l 0.928 a 0.706 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.892sec\n",
      "Epoch 67 tr: l 0.712 a 0.772 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.071474 12.431sec(train) 4.330sec(infer)\n",
      "Epoch 67 tst: l 0.893 a 0.721 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.814sec\n",
      "Epoch 68 tr: l 0.714 a 0.767 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.071116 13.121sec(train) 3.909sec(infer)\n",
      "Epoch 68 tst: l 0.921 a 0.708 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.826sec\n",
      "Epoch 69 tr: l 0.705 a 0.773 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.070761 12.355sec(train) 4.574sec(infer)\n",
      "Epoch 69 tst: l 0.887 a 0.722 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.853sec\n",
      "Epoch 70 tr: l 0.707 a 0.769 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.070407 11.768sec(train) 4.694sec(infer)\n",
      "Epoch 70 tst: l 0.914 a 0.711 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.981sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 71 tr: l 0.698 a 0.775 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.070055 13.194sec(train) 3.606sec(infer)\n",
      "Epoch 71 tst: l 0.881 a 0.724 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.828sec\n",
      "Epoch 72 tr: l 0.700 a 0.771 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.069705 13.555sec(train) 3.599sec(infer)\n",
      "Epoch 72 tst: l 0.908 a 0.712 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.670sec\n",
      "Epoch 73 tr: l 0.692 a 0.777 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.069356 12.531sec(train) 4.676sec(infer)\n",
      "Epoch 73 tst: l 0.875 a 0.726 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.988sec\n",
      "Epoch 74 tr: l 0.694 a 0.773 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.069009 12.125sec(train) 4.006sec(infer)\n",
      "Epoch 74 tst: l 0.902 a 0.713 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.837sec\n",
      "Epoch 75 tr: l 0.686 a 0.778 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.068664 12.629sec(train) 4.440sec(infer)\n",
      "Epoch 75 tst: l 0.870 a 0.728 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.984sec\n",
      "Epoch 76 tr: l 0.689 a 0.774 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.068321 12.478sec(train) 4.168sec(infer)\n",
      "Epoch 76 tst: l 0.897 a 0.715 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.859sec\n",
      "Epoch 77 tr: l 0.681 a 0.780 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.067979 13.238sec(train) 3.469sec(infer)\n",
      "Epoch 77 tst: l 0.864 a 0.729 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.952sec\n",
      "Epoch 78 tr: l 0.683 a 0.776 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.067639 12.985sec(train) 4.441sec(infer)\n",
      "Epoch 78 tst: l 0.893 a 0.716 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.676sec\n",
      "Epoch 79 tr: l 0.676 a 0.781 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.067301 12.368sec(train) 4.068sec(infer)\n",
      "Epoch 79 tst: l 0.859 a 0.730 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.944sec\n",
      "Epoch 80 tr: l 0.678 a 0.777 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.066965 12.511sec(train) 4.434sec(infer)\n",
      "Epoch 80 tst: l 0.889 a 0.717 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.858sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 81 tr: l 0.671 a 0.782 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.066630 12.373sec(train) 4.368sec(infer)\n",
      "Epoch 81 tst: l 0.854 a 0.731 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.840sec\n",
      "Epoch 82 tr: l 0.673 a 0.779 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.066297 12.843sec(train) 4.362sec(infer)\n",
      "Epoch 82 tst: l 0.885 a 0.718 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.991sec\n",
      "Epoch 83 tr: l 0.666 a 0.783 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.065965 12.933sec(train) 3.496sec(infer)\n",
      "Epoch 83 tst: l 0.850 a 0.733 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.697sec\n",
      "Epoch 84 tr: l 0.669 a 0.780 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.065635 13.655sec(train) 3.939sec(infer)\n",
      "Epoch 84 tst: l 0.881 a 0.719 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.750sec\n",
      "Epoch 85 tr: l 0.662 a 0.784 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.065307 11.952sec(train) 4.703sec(infer)\n",
      "Epoch 85 tst: l 0.845 a 0.734 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.878sec\n",
      "Epoch 86 tr: l 0.664 a 0.781 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.064981 11.802sec(train) 4.167sec(infer)\n",
      "Epoch 86 tst: l 0.877 a 0.720 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.981sec\n",
      "Epoch 87 tr: l 0.658 a 0.785 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.064656 13.525sec(train) 3.779sec(infer)\n",
      "Epoch 87 tst: l 0.841 a 0.734 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.840sec\n",
      "Epoch 88 tr: l 0.660 a 0.782 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.064333 13.244sec(train) 3.984sec(infer)\n",
      "Epoch 88 tst: l 0.874 a 0.720 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.953sec\n",
      "Epoch 89 tr: l 0.655 a 0.786 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.064011 12.073sec(train) 4.485sec(infer)\n",
      "Epoch 89 tst: l 0.837 a 0.736 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.825sec\n",
      "Epoch 90 tr: l 0.657 a 0.782 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.063691 13.032sec(train) 3.691sec(infer)\n",
      "Epoch 90 tst: l 0.871 a 0.720 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.836sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 91 tr: l 0.653 a 0.785 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.063372 12.848sec(train) 4.513sec(infer)\n",
      "Epoch 91 tst: l 0.834 a 0.736 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.839sec\n",
      "Epoch 92 tr: l 0.654 a 0.783 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.063056 11.651sec(train) 4.713sec(infer)\n",
      "Epoch 92 tst: l 0.868 a 0.721 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.963sec\n",
      "Epoch 93 tr: l 0.649 a 0.786 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.062740 12.914sec(train) 4.121sec(infer)\n",
      "Epoch 93 tst: l 0.831 a 0.737 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.984sec\n",
      "Epoch 94 tr: l 0.650 a 0.784 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.062427 13.870sec(train) 3.048sec(infer)\n",
      "Epoch 94 tst: l 0.864 a 0.722 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.542sec\n",
      "Epoch 95 tr: l 0.645 a 0.787 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.062114 12.870sec(train) 4.661sec(infer)\n",
      "Epoch 95 tst: l 0.827 a 0.738 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.908sec\n",
      "Epoch 96 tr: l 0.646 a 0.785 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.061804 11.250sec(train) 4.717sec(infer)\n",
      "Epoch 96 tst: l 0.859 a 0.723 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.969sec\n",
      "Epoch 97 tr: l 0.640 a 0.789 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.061495 13.027sec(train) 3.347sec(infer)\n",
      "Epoch 97 tst: l 0.823 a 0.739 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.717sec\n",
      "Epoch 98 tr: l 0.642 a 0.787 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.061187 13.176sec(train) 4.612sec(infer)\n",
      "Epoch 98 tst: l 0.855 a 0.724 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.999sec\n",
      "Epoch 99 tr: l 0.636 a 0.790 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.060881 11.753sec(train) 3.937sec(infer)\n",
      "Epoch 99 tst: l 0.821 a 0.740 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.958sec\n",
      "Epoch 100 tr: l 0.667 a 0.782 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.006058 13.538sec(train) 3.525sec(infer)\n",
      "Epoch 100 tst: l 0.802 a 0.753 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.812sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 101 tr: l 0.669 a 0.783 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.006027 13.467sec(train) 4.411sec(infer)\n",
      "Epoch 101 tst: l 0.799 a 0.755 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.704sec\n",
      "Epoch 102 tr: l 0.669 a 0.783 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005997 11.326sec(train) 4.684sec(infer)\n",
      "Epoch 102 tst: l 0.798 a 0.755 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.993sec\n",
      "Epoch 103 tr: l 0.668 a 0.784 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005967 12.066sec(train) 4.405sec(infer)\n",
      "Epoch 103 tst: l 0.798 a 0.753 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.979sec\n",
      "Epoch 104 tr: l 0.666 a 0.784 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005937 13.656sec(train) 3.493sec(infer)\n",
      "Epoch 104 tst: l 0.798 a 0.753 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.768sec\n",
      "Epoch 105 tr: l 0.665 a 0.785 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005908 13.193sec(train) 4.020sec(infer)\n",
      "Epoch 105 tst: l 0.798 a 0.752 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.775sec\n",
      "Epoch 106 tr: l 0.665 a 0.785 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005878 12.044sec(train) 4.625sec(infer)\n",
      "Epoch 106 tst: l 0.798 a 0.752 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.834sec\n",
      "Epoch 107 tr: l 0.664 a 0.785 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005849 12.763sec(train) 3.862sec(infer)\n",
      "Epoch 107 tst: l 0.798 a 0.752 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.851sec\n",
      "Epoch 108 tr: l 0.664 a 0.786 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005820 12.565sec(train) 4.334sec(infer)\n",
      "Epoch 108 tst: l 0.797 a 0.753 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.847sec\n",
      "Epoch 109 tr: l 0.663 a 0.786 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005790 11.805sec(train) 4.693sec(infer)\n",
      "Epoch 109 tst: l 0.797 a 0.753 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.984sec\n",
      "Epoch 110 tr: l 0.663 a 0.786 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005762 12.851sec(train) 3.409sec(infer)\n",
      "Epoch 110 tst: l 0.797 a 0.753 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.844sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 111 tr: l 0.662 a 0.786 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005733 13.685sec(train) 3.723sec(infer)\n",
      "Epoch 111 tst: l 0.796 a 0.753 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.802sec\n",
      "Epoch 112 tr: l 0.662 a 0.786 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005704 12.407sec(train) 4.598sec(infer)\n",
      "Epoch 112 tst: l 0.796 a 0.753 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.882sec\n",
      "Epoch 113 tr: l 0.662 a 0.787 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005676 12.274sec(train) 4.057sec(infer)\n",
      "Epoch 113 tst: l 0.796 a 0.753 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.985sec\n",
      "Epoch 114 tr: l 0.661 a 0.787 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005647 12.469sec(train) 4.614sec(infer)\n",
      "Epoch 114 tst: l 0.796 a 0.753 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.926sec\n",
      "Epoch 115 tr: l 0.661 a 0.787 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005619 12.546sec(train) 3.882sec(infer)\n",
      "Epoch 115 tst: l 0.795 a 0.753 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.852sec\n",
      "Epoch 116 tr: l 0.661 a 0.787 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005591 13.141sec(train) 3.669sec(infer)\n",
      "Epoch 116 tst: l 0.795 a 0.753 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.807sec\n",
      "Epoch 117 tr: l 0.660 a 0.787 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005563 12.906sec(train) 4.508sec(infer)\n",
      "Epoch 117 tst: l 0.795 a 0.753 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.731sec\n",
      "Epoch 118 tr: l 0.660 a 0.787 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005535 12.196sec(train) 4.130sec(infer)\n",
      "Epoch 118 tst: l 0.795 a 0.753 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.980sec\n",
      "Epoch 119 tr: l 0.660 a 0.787 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005507 12.363sec(train) 4.489sec(infer)\n",
      "Epoch 119 tst: l 0.795 a 0.753 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.852sec\n",
      "Epoch 120 tr: l 0.659 a 0.787 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005480 12.690sec(train) 4.231sec(infer)\n",
      "Epoch 120 tst: l 0.795 a 0.753 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.846sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 121 tr: l 0.659 a 0.787 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005452 12.716sec(train) 4.057sec(infer)\n",
      "Epoch 121 tst: l 0.794 a 0.753 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.986sec\n",
      "Epoch 122 tr: l 0.659 a 0.787 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005425 12.887sec(train) 3.766sec(infer)\n",
      "Epoch 122 tst: l 0.794 a 0.753 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.694sec\n",
      "Epoch 123 tr: l 0.658 a 0.787 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005398 13.257sec(train) 4.001sec(infer)\n",
      "Epoch 123 tst: l 0.794 a 0.753 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.808sec\n",
      "Epoch 124 tr: l 0.658 a 0.787 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005371 11.978sec(train) 4.716sec(infer)\n",
      "Epoch 124 tst: l 0.794 a 0.753 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.968sec\n",
      "Epoch 125 tr: l 0.658 a 0.788 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005344 11.753sec(train) 4.216sec(infer)\n",
      "Epoch 125 tst: l 0.794 a 0.753 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.985sec\n",
      "Epoch 126 tr: l 0.658 a 0.788 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005318 13.673sec(train) 3.432sec(infer)\n",
      "Epoch 126 tst: l 0.793 a 0.753 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.824sec\n",
      "Epoch 127 tr: l 0.657 a 0.788 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005291 13.116sec(train) 4.218sec(infer)\n",
      "Epoch 127 tst: l 0.793 a 0.753 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.781sec\n",
      "Epoch 128 tr: l 0.657 a 0.788 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005264 11.811sec(train) 4.698sec(infer)\n",
      "Epoch 128 tst: l 0.793 a 0.753 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.984sec\n",
      "Epoch 129 tr: l 0.657 a 0.788 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005238 12.695sec(train) 3.652sec(infer)\n",
      "Epoch 129 tst: l 0.793 a 0.753 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.838sec\n",
      "Epoch 130 tr: l 0.657 a 0.788 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005212 12.812sec(train) 4.581sec(infer)\n",
      "Epoch 130 tst: l 0.793 a 0.753 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.839sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 131 tr: l 0.657 a 0.788 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005186 11.653sec(train) 4.559sec(infer)\n",
      "Epoch 131 tst: l 0.793 a 0.753 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.985sec\n",
      "Epoch 132 tr: l 0.656 a 0.788 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005160 13.014sec(train) 3.600sec(infer)\n",
      "Epoch 132 tst: l 0.792 a 0.753 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.983sec\n",
      "Epoch 133 tr: l 0.656 a 0.788 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005134 13.955sec(train) 3.792sec(infer)\n",
      "Epoch 133 tst: l 0.792 a 0.753 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.562sec\n",
      "Epoch 134 tr: l 0.656 a 0.788 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005108 12.268sec(train) 4.709sec(infer)\n",
      "Epoch 134 tst: l 0.792 a 0.753 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.973sec\n",
      "Epoch 135 tr: l 0.656 a 0.788 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005083 11.295sec(train) 4.684sec(infer)\n",
      "Epoch 135 tst: l 0.792 a 0.753 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.986sec\n",
      "Epoch 136 tr: l 0.655 a 0.788 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005058 13.065sec(train) 3.367sec(infer)\n",
      "Epoch 136 tst: l 0.792 a 0.753 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.718sec\n",
      "Epoch 137 tr: l 0.655 a 0.789 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005032 13.530sec(train) 4.238sec(infer)\n",
      "Epoch 137 tst: l 0.792 a 0.754 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.959sec\n",
      "Epoch 138 tr: l 0.655 a 0.789 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005007 11.921sec(train) 4.205sec(infer)\n",
      "Epoch 138 tst: l 0.792 a 0.754 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.816sec\n",
      "Epoch 139 tr: l 0.655 a 0.789 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.004982 13.338sec(train) 3.533sec(infer)\n",
      "Epoch 139 tst: l 0.791 a 0.754 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.911sec\n",
      "Epoch 140 tr: l 0.655 a 0.789 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.004957 13.003sec(train) 4.425sec(infer)\n",
      "Epoch 140 tst: l 0.791 a 0.754 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.864sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 141 tr: l 0.654 a 0.789 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.004932 11.307sec(train) 4.707sec(infer)\n",
      "Epoch 141 tst: l 0.791 a 0.754 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.971sec\n",
      "Epoch 142 tr: l 0.654 a 0.789 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.004908 12.559sec(train) 4.144sec(infer)\n",
      "Epoch 142 tst: l 0.791 a 0.754 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.982sec\n",
      "Epoch 143 tr: l 0.654 a 0.789 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.004883 13.897sec(train) 3.110sec(infer)\n",
      "Epoch 143 tst: l 0.791 a 0.754 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.769sec\n",
      "Epoch 144 tr: l 0.654 a 0.789 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.004859 13.221sec(train) 4.479sec(infer)\n",
      "Epoch 144 tst: l 0.791 a 0.754 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.724sec\n",
      "Epoch 145 tr: l 0.654 a 0.789 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.004834 11.954sec(train) 4.485sec(infer)\n",
      "Epoch 145 tst: l 0.790 a 0.754 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.967sec\n",
      "Epoch 146 tr: l 0.653 a 0.789 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.004810 12.514sec(train) 4.173sec(infer)\n",
      "Epoch 146 tst: l 0.790 a 0.754 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.838sec\n",
      "Epoch 147 tr: l 0.653 a 0.789 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.004786 12.603sec(train) 4.215sec(infer)\n",
      "Epoch 147 tst: l 0.790 a 0.754 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.837sec\n",
      "Epoch 148 tr: l 0.653 a 0.789 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.004762 12.653sec(train) 4.271sec(infer)\n",
      "Epoch 148 tst: l 0.790 a 0.754 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.959sec\n",
      "Epoch 149 tr: l 0.653 a 0.789 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.004738 13.006sec(train) 3.569sec(infer)\n",
      "Epoch 149 tst: l 0.790 a 0.754 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.669sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "---train cluster Ended in 0.74 hour (2652.658 sec) \n",
      "---------------------------------DFedAvgM, lr: 0.1, seed: 7293---------------------------------\n",
      "config: {'m': 100, 'm_test': 20, 'p': 2, 'n': 1500, 'uneven': True, 'local_model_init': False, 'Gp': 0.15, 'graph': 'er', 'agg': 'seq', 'h1': 512, 'num_epochs': 150, 'batch_size': 100, 'tau': 3, 'lr': 0.1, 'data_seed': 7293, 'train_seed': 7293, 'config_override': '', 'project_dir': 'output_dfca_gi'}\n",
      "Using device: cuda:3\n",
      "Epoch -1 tr: l 3.884 a 0.018 clct[np.int64(100), np.int64(0)] cl_acc 0.500  4.409sec\n",
      "Epoch -1 tst: l 3.880 a 0.018 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.951sec\n",
      "Epoch 0 tr: l 3.510 a 0.215 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.100000 12.937sec(train) 3.528sec(infer)\n",
      "Epoch 0 tst: l 3.599 a 0.162 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.736sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 1 tr: l 3.164 a 0.323 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.099500 13.185sec(train) 3.928sec(infer)\n",
      "Epoch 1 tst: l 3.286 a 0.252 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.698sec\n",
      "Epoch 2 tr: l 2.812 a 0.387 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.099003 12.440sec(train) 4.601sec(infer)\n",
      "Epoch 2 tst: l 2.959 a 0.311 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.957sec\n",
      "Epoch 3 tr: l 2.505 a 0.439 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.098507 12.201sec(train) 4.095sec(infer)\n",
      "Epoch 3 tst: l 2.671 a 0.359 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.804sec\n",
      "Epoch 4 tr: l 2.261 a 0.481 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.098015 12.423sec(train) 4.474sec(infer)\n",
      "Epoch 4 tst: l 2.436 a 0.400 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.937sec\n",
      "Epoch 5 tr: l 2.067 a 0.514 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.097525 12.731sec(train) 3.669sec(infer)\n",
      "Epoch 5 tst: l 2.249 a 0.433 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.807sec\n",
      "Epoch 6 tr: l 1.906 a 0.544 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.097037 13.363sec(train) 3.712sec(infer)\n",
      "Epoch 6 tst: l 2.094 a 0.460 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.630sec\n",
      "Epoch 7 tr: l 1.779 a 0.564 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.096552 12.277sec(train) 4.664sec(infer)\n",
      "Epoch 7 tst: l 1.972 a 0.483 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.918sec\n",
      "Epoch 8 tr: l 1.676 a 0.582 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.096069 11.832sec(train) 4.038sec(infer)\n",
      "Epoch 8 tst: l 1.871 a 0.502 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.831sec\n",
      "Epoch 9 tr: l 1.621 a 0.572 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.095589 13.059sec(train) 3.916sec(infer)\n",
      "Epoch 9 tst: l 1.815 a 0.494 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.794sec\n",
      "Epoch 10 tr: l 1.598 a 0.568 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.095111 12.751sec(train) 4.124sec(infer)\n",
      "Epoch 10 tst: l 1.806 a 0.494 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.937sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 11 tr: l 1.514 a 0.585 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.094635 12.322sec(train) 3.943sec(infer)\n",
      "Epoch 11 tst: l 1.702 a 0.514 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.806sec\n",
      "Epoch 12 tr: l 1.475 a 0.590 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.094162 13.359sec(train) 3.679sec(infer)\n",
      "Epoch 12 tst: l 1.688 a 0.515 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.823sec\n",
      "Epoch 13 tr: l 1.451 a 0.601 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.093691 12.537sec(train) 4.648sec(infer)\n",
      "Epoch 13 tst: l 1.637 a 0.526 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.923sec\n",
      "Epoch 14 tr: l 1.376 a 0.615 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.093223 11.013sec(train) 4.650sec(infer)\n",
      "Epoch 14 tst: l 1.581 a 0.544 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.956sec\n",
      "Epoch 15 tr: l 1.298 a 0.644 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.092757 13.376sec(train) 3.594sec(infer)\n",
      "Epoch 15 tst: l 1.494 a 0.568 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.829sec\n",
      "Epoch 16 tr: l 1.260 a 0.647 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.092293 13.661sec(train) 3.754sec(infer)\n",
      "Epoch 16 tst: l 1.467 a 0.574 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.658sec\n",
      "Epoch 17 tr: l 1.232 a 0.657 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.091832 11.968sec(train) 4.638sec(infer)\n",
      "Epoch 17 tst: l 1.430 a 0.581 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.865sec\n",
      "Epoch 18 tr: l 1.209 a 0.655 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.091372 12.233sec(train) 4.094sec(infer)\n",
      "Epoch 18 tst: l 1.418 a 0.584 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.945sec\n",
      "Epoch 19 tr: l 1.184 a 0.666 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.090916 12.991sec(train) 4.112sec(infer)\n",
      "Epoch 19 tst: l 1.381 a 0.591 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.678sec\n",
      "Epoch 20 tr: l 1.147 a 0.670 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.090461 12.044sec(train) 4.525sec(infer)\n",
      "Epoch 20 tst: l 1.362 a 0.596 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.938sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 21 tr: l 1.114 a 0.683 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.090009 12.295sec(train) 3.906sec(infer)\n",
      "Epoch 21 tst: l 1.326 a 0.604 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.898sec\n",
      "Epoch 22 tr: l 1.090 a 0.686 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.089559 13.837sec(train) 3.258sec(infer)\n",
      "Epoch 22 tst: l 1.310 a 0.608 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.532sec\n",
      "Epoch 23 tr: l 1.068 a 0.693 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.089111 12.592sec(train) 4.639sec(infer)\n",
      "Epoch 23 tst: l 1.285 a 0.612 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.939sec\n",
      "Epoch 24 tr: l 1.047 a 0.696 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.088665 11.208sec(train) 4.613sec(infer)\n",
      "Epoch 24 tst: l 1.274 a 0.615 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.955sec\n",
      "Epoch 25 tr: l 1.031 a 0.701 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.088222 13.147sec(train) 3.497sec(infer)\n",
      "Epoch 25 tst: l 1.257 a 0.619 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.789sec\n",
      "Epoch 26 tr: l 1.024 a 0.699 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.087781 13.516sec(train) 3.896sec(infer)\n",
      "Epoch 26 tst: l 1.260 a 0.615 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.808sec\n",
      "Epoch 27 tr: l 1.010 a 0.702 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.087342 12.046sec(train) 4.341sec(infer)\n",
      "Epoch 27 tst: l 1.246 a 0.619 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.802sec\n",
      "Epoch 28 tr: l 1.014 a 0.699 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.086905 12.701sec(train) 3.935sec(infer)\n",
      "Epoch 28 tst: l 1.264 a 0.609 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.801sec\n",
      "Epoch 29 tr: l 0.990 a 0.704 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.086471 12.890sec(train) 4.073sec(infer)\n",
      "Epoch 29 tst: l 1.232 a 0.619 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.817sec\n",
      "Epoch 30 tr: l 0.978 a 0.708 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.086038 11.671sec(train) 4.650sec(infer)\n",
      "Epoch 30 tst: l 1.234 a 0.618 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.832sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 31 tr: l 0.957 a 0.713 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.085608 12.795sec(train) 3.569sec(infer)\n",
      "Epoch 31 tst: l 1.200 a 0.629 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.933sec\n",
      "Epoch 32 tr: l 0.945 a 0.716 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.085180 13.673sec(train) 3.653sec(infer)\n",
      "Epoch 32 tst: l 1.210 a 0.625 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.695sec\n",
      "Epoch 33 tr: l 0.928 a 0.721 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.084754 11.462sec(train) 4.637sec(infer)\n",
      "Epoch 33 tst: l 1.175 a 0.635 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.798sec\n",
      "Epoch 34 tr: l 0.922 a 0.722 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.084331 12.233sec(train) 4.255sec(infer)\n",
      "Epoch 34 tst: l 1.193 a 0.628 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.949sec\n",
      "Epoch 35 tr: l 0.906 a 0.727 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.083909 13.068sec(train) 4.082sec(infer)\n",
      "Epoch 35 tst: l 1.160 a 0.638 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.811sec\n",
      "Epoch 36 tr: l 0.900 a 0.727 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.083489 13.020sec(train) 3.566sec(infer)\n",
      "Epoch 36 tst: l 1.185 a 0.629 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.666sec\n",
      "Epoch 37 tr: l 0.891 a 0.731 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.083072 12.761sec(train) 4.504sec(infer)\n",
      "Epoch 37 tst: l 1.146 a 0.642 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.934sec\n",
      "Epoch 38 tr: l 0.890 a 0.727 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.082657 12.039sec(train) 4.295sec(infer)\n",
      "Epoch 38 tst: l 1.185 a 0.627 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.798sec\n",
      "Epoch 39 tr: l 0.882 a 0.733 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.082243 12.223sec(train) 4.094sec(infer)\n",
      "Epoch 39 tst: l 1.140 a 0.643 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.929sec\n",
      "Epoch 40 tr: l 0.871 a 0.733 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.081832 12.761sec(train) 4.402sec(infer)\n",
      "Epoch 40 tst: l 1.172 a 0.632 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.819sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 41 tr: l 0.858 a 0.739 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.081423 13.076sec(train) 3.366sec(infer)\n",
      "Epoch 41 tst: l 1.121 a 0.649 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.661sec\n",
      "Epoch 42 tr: l 0.850 a 0.739 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.081016 12.847sec(train) 4.533sec(infer)\n",
      "Epoch 42 tst: l 1.153 a 0.638 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.790sec\n",
      "Epoch 43 tr: l 0.843 a 0.743 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.080611 12.138sec(train) 4.103sec(infer)\n",
      "Epoch 43 tst: l 1.107 a 0.652 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.798sec\n",
      "Epoch 44 tr: l 0.836 a 0.742 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.080208 12.626sec(train) 3.981sec(infer)\n",
      "Epoch 44 tst: l 1.139 a 0.643 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.798sec\n",
      "Epoch 45 tr: l 0.827 a 0.747 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.079807 12.393sec(train) 4.626sec(infer)\n",
      "Epoch 45 tst: l 1.096 a 0.653 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.924sec\n",
      "Epoch 46 tr: l 0.824 a 0.745 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.079408 12.638sec(train) 3.423sec(infer)\n",
      "Epoch 46 tst: l 1.129 a 0.644 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.949sec\n",
      "Epoch 47 tr: l 0.818 a 0.749 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.079010 13.816sec(train) 3.618sec(infer)\n",
      "Epoch 47 tst: l 1.088 a 0.654 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.594sec\n",
      "Epoch 48 tr: l 0.818 a 0.745 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.078615 12.544sec(train) 4.623sec(infer)\n",
      "Epoch 48 tst: l 1.128 a 0.643 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.946sec\n",
      "Epoch 49 tr: l 0.814 a 0.748 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.078222 11.382sec(train) 4.426sec(infer)\n",
      "Epoch 49 tst: l 1.085 a 0.655 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.937sec\n",
      "Epoch 50 tr: l 0.819 a 0.745 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.077831 12.887sec(train) 3.681sec(infer)\n",
      "Epoch 50 tst: l 1.135 a 0.642 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.805sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 51 tr: l 0.812 a 0.748 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.077442 13.238sec(train) 4.245sec(infer)\n",
      "Epoch 51 tst: l 1.092 a 0.653 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.826sec\n",
      "Epoch 52 tr: l 0.809 a 0.747 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.077055 11.883sec(train) 4.175sec(infer)\n",
      "Epoch 52 tst: l 1.125 a 0.646 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.793sec\n",
      "Epoch 53 tr: l 0.793 a 0.754 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.076670 13.137sec(train) 3.754sec(infer)\n",
      "Epoch 53 tst: l 1.069 a 0.660 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.785sec\n",
      "Epoch 54 tr: l 0.785 a 0.756 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.076286 13.039sec(train) 4.352sec(infer)\n",
      "Epoch 54 tst: l 1.105 a 0.651 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.780sec\n",
      "Epoch 55 tr: l 0.779 a 0.759 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.075905 11.271sec(train) 4.658sec(infer)\n",
      "Epoch 55 tst: l 1.065 a 0.661 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.945sec\n",
      "Epoch 56 tr: l 0.783 a 0.754 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.075525 12.662sec(train) 4.504sec(infer)\n",
      "Epoch 56 tst: l 1.108 a 0.649 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.961sec\n",
      "Epoch 57 tr: l 0.774 a 0.759 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.075148 13.750sec(train) 2.842sec(infer)\n",
      "Epoch 57 tst: l 1.049 a 0.664 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.660sec\n",
      "Epoch 58 tr: l 0.767 a 0.760 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.074772 12.991sec(train) 4.393sec(infer)\n",
      "Epoch 58 tst: l 1.098 a 0.652 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.787sec\n",
      "Epoch 59 tr: l 0.765 a 0.762 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.074398 11.496sec(train) 3.448sec(infer)\n",
      "Epoch 59 tst: l 1.046 a 0.665 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.696sec\n",
      "Epoch 60 tr: l 0.769 a 0.757 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.074026 10.279sec(train) 2.727sec(infer)\n",
      "Epoch 60 tst: l 1.105 a 0.650 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.604sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 61 tr: l 0.766 a 0.760 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.073656 12.196sec(train) 4.656sec(infer)\n",
      "Epoch 61 tst: l 1.038 a 0.667 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.937sec\n",
      "Epoch 62 tr: l 0.756 a 0.762 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.073288 12.039sec(train) 4.364sec(infer)\n",
      "Epoch 62 tst: l 1.094 a 0.654 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.947sec\n",
      "Epoch 63 tr: l 0.755 a 0.764 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.072921 13.583sec(train) 2.902sec(infer)\n",
      "Epoch 63 tst: l 1.037 a 0.669 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.679sec\n",
      "Epoch 64 tr: l 0.757 a 0.760 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.072557 13.576sec(train) 4.682sec(infer)\n",
      "Epoch 64 tst: l 1.100 a 0.652 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.728sec\n",
      "Epoch 65 tr: l 0.754 a 0.764 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.072194 11.375sec(train) 4.664sec(infer)\n",
      "Epoch 65 tst: l 1.022 a 0.670 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.939sec\n",
      "Epoch 66 tr: l 0.737 a 0.768 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.071833 12.635sec(train) 3.281sec(infer)\n",
      "Epoch 66 tst: l 1.073 a 0.661 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.774sec\n",
      "Epoch 67 tr: l 0.736 a 0.770 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.071474 12.556sec(train) 4.613sec(infer)\n",
      "Epoch 67 tst: l 1.022 a 0.672 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.866sec\n",
      "Epoch 68 tr: l 0.744 a 0.764 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.071116 12.298sec(train) 3.959sec(infer)\n",
      "Epoch 68 tst: l 1.089 a 0.655 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.923sec\n",
      "Epoch 69 tr: l 0.742 a 0.767 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.070761 13.188sec(train) 3.860sec(infer)\n",
      "Epoch 69 tst: l 1.006 a 0.674 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.656sec\n",
      "Epoch 70 tr: l 0.722 a 0.772 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.070407 12.952sec(train) 4.137sec(infer)\n",
      "Epoch 70 tst: l 1.056 a 0.667 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.801sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 71 tr: l 0.721 a 0.774 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.070055 11.693sec(train) 4.643sec(infer)\n",
      "Epoch 71 tst: l 1.012 a 0.675 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.944sec\n",
      "Epoch 72 tr: l 0.728 a 0.768 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.069705 12.275sec(train) 3.990sec(infer)\n",
      "Epoch 72 tst: l 1.075 a 0.660 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.809sec\n",
      "Epoch 73 tr: l 0.731 a 0.770 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.069356 13.485sec(train) 3.701sec(infer)\n",
      "Epoch 73 tst: l 0.995 a 0.677 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.949sec\n",
      "Epoch 74 tr: l 0.712 a 0.775 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.069009 12.837sec(train) 4.170sec(infer)\n",
      "Epoch 74 tst: l 1.051 a 0.669 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.656sec\n",
      "Epoch 75 tr: l 0.711 a 0.777 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.068664 12.940sec(train) 3.974sec(infer)\n",
      "Epoch 75 tst: l 0.999 a 0.680 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.912sec\n",
      "Epoch 76 tr: l 0.714 a 0.772 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.068321 12.329sec(train) 4.654sec(infer)\n",
      "Epoch 76 tst: l 1.063 a 0.663 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.917sec\n",
      "Epoch 77 tr: l 0.720 a 0.772 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.067979 12.013sec(train) 4.125sec(infer)\n",
      "Epoch 77 tst: l 0.989 a 0.680 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.806sec\n",
      "Epoch 78 tr: l 0.706 a 0.774 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.067639 13.127sec(train) 4.135sec(infer)\n",
      "Epoch 78 tst: l 1.048 a 0.667 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.964sec\n",
      "Epoch 79 tr: l 0.707 a 0.776 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.067301 13.005sec(train) 3.838sec(infer)\n",
      "Epoch 79 tst: l 0.992 a 0.681 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.657sec\n",
      "Epoch 80 tr: l 0.710 a 0.771 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.066965 12.733sec(train) 4.304sec(infer)\n",
      "Epoch 80 tst: l 1.061 a 0.662 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.838sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 81 tr: l 0.714 a 0.773 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.066630 12.546sec(train) 4.305sec(infer)\n",
      "Epoch 81 tst: l 0.980 a 0.681 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.801sec\n",
      "Epoch 82 tr: l 0.693 a 0.778 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.066297 12.445sec(train) 4.315sec(infer)\n",
      "Epoch 82 tst: l 1.033 a 0.671 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.797sec\n",
      "Epoch 83 tr: l 0.694 a 0.780 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.065965 12.086sec(train) 4.568sec(infer)\n",
      "Epoch 83 tst: l 0.980 a 0.686 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.963sec\n",
      "Epoch 84 tr: l 0.696 a 0.776 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.065635 12.948sec(train) 3.330sec(infer)\n",
      "Epoch 84 tst: l 1.049 a 0.666 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.823sec\n",
      "Epoch 85 tr: l 0.700 a 0.776 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.065307 13.810sec(train) 3.833sec(infer)\n",
      "Epoch 85 tst: l 0.969 a 0.686 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.663sec\n",
      "Epoch 86 tr: l 0.681 a 0.782 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.064981 12.287sec(train) 4.657sec(infer)\n",
      "Epoch 86 tst: l 1.024 a 0.675 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.950sec\n",
      "Epoch 87 tr: l 0.687 a 0.782 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.064656 11.728sec(train) 4.338sec(infer)\n",
      "Epoch 87 tst: l 0.974 a 0.687 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.946sec\n",
      "Epoch 88 tr: l 0.694 a 0.775 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.064333 13.261sec(train) 3.677sec(infer)\n",
      "Epoch 88 tst: l 1.055 a 0.664 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.698sec\n",
      "Epoch 89 tr: l 0.698 a 0.776 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.064011 13.342sec(train) 4.176sec(infer)\n",
      "Epoch 89 tst: l 0.958 a 0.687 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.936sec\n",
      "Epoch 90 tr: l 0.671 a 0.785 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.063691 11.951sec(train) 4.341sec(infer)\n",
      "Epoch 90 tst: l 1.007 a 0.681 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.792sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 91 tr: l 0.673 a 0.786 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.063372 13.277sec(train) 3.635sec(infer)\n",
      "Epoch 91 tst: l 0.965 a 0.691 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.843sec\n",
      "Epoch 92 tr: l 0.675 a 0.782 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.063056 12.971sec(train) 4.548sec(infer)\n",
      "Epoch 92 tst: l 1.029 a 0.672 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.804sec\n",
      "Epoch 93 tr: l 0.681 a 0.782 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.062740 11.208sec(train) 4.648sec(infer)\n",
      "Epoch 93 tst: l 0.954 a 0.691 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.931sec\n",
      "Epoch 94 tr: l 0.667 a 0.786 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.062427 12.808sec(train) 4.355sec(infer)\n",
      "Epoch 94 tst: l 1.022 a 0.676 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.941sec\n",
      "Epoch 95 tr: l 0.674 a 0.784 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.062114 13.816sec(train) 2.982sec(infer)\n",
      "Epoch 95 tst: l 0.958 a 0.691 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.519sec\n",
      "Epoch 96 tr: l 0.676 a 0.781 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.061804 13.068sec(train) 4.658sec(infer)\n",
      "Epoch 96 tst: l 1.038 a 0.670 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.814sec\n",
      "Epoch 97 tr: l 0.676 a 0.783 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.061495 11.354sec(train) 4.688sec(infer)\n",
      "Epoch 97 tst: l 0.941 a 0.692 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.948sec\n",
      "Epoch 98 tr: l 0.653 a 0.792 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.061187 13.071sec(train) 3.373sec(infer)\n",
      "Epoch 98 tst: l 0.992 a 0.686 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.709sec\n",
      "Epoch 99 tr: l 0.654 a 0.792 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.060881 13.161sec(train) 4.575sec(infer)\n",
      "Epoch 99 tst: l 0.951 a 0.694 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.952sec\n",
      "Epoch 100 tr: l 0.693 a 0.779 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.006058 11.831sec(train) 3.936sec(infer)\n",
      "Epoch 100 tst: l 0.861 a 0.723 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.930sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 101 tr: l 0.691 a 0.781 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.006027 13.474sec(train) 3.574sec(infer)\n",
      "Epoch 101 tst: l 0.846 a 0.727 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.697sec\n",
      "Epoch 102 tr: l 0.688 a 0.783 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005997 13.406sec(train) 4.329sec(infer)\n",
      "Epoch 102 tst: l 0.849 a 0.725 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.818sec\n",
      "Epoch 103 tr: l 0.686 a 0.784 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005967 11.552sec(train) 4.627sec(infer)\n",
      "Epoch 103 tst: l 0.853 a 0.723 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.943sec\n",
      "Epoch 104 tr: l 0.685 a 0.784 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005937 12.133sec(train) 4.155sec(infer)\n",
      "Epoch 104 tst: l 0.855 a 0.723 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.923sec\n",
      "Epoch 105 tr: l 0.684 a 0.785 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005908 13.751sec(train) 3.617sec(infer)\n",
      "Epoch 105 tst: l 0.855 a 0.723 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.786sec\n",
      "Epoch 106 tr: l 0.683 a 0.785 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005878 13.205sec(train) 4.150sec(infer)\n",
      "Epoch 106 tst: l 0.854 a 0.723 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.692sec\n",
      "Epoch 107 tr: l 0.682 a 0.786 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005849 12.238sec(train) 4.504sec(infer)\n",
      "Epoch 107 tst: l 0.854 a 0.723 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.937sec\n",
      "Epoch 108 tr: l 0.682 a 0.786 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005820 12.502sec(train) 4.162sec(infer)\n",
      "Epoch 108 tst: l 0.854 a 0.723 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.793sec\n",
      "Epoch 109 tr: l 0.681 a 0.786 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005790 12.354sec(train) 4.263sec(infer)\n",
      "Epoch 109 tst: l 0.853 a 0.723 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.822sec\n",
      "Epoch 110 tr: l 0.680 a 0.786 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005762 12.458sec(train) 4.481sec(infer)\n",
      "Epoch 110 tst: l 0.853 a 0.723 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.947sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 111 tr: l 0.680 a 0.786 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005733 12.956sec(train) 3.408sec(infer)\n",
      "Epoch 111 tst: l 0.853 a 0.724 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.652sec\n",
      "Epoch 112 tr: l 0.679 a 0.787 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005704 13.499sec(train) 4.108sec(infer)\n",
      "Epoch 112 tst: l 0.853 a 0.724 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.835sec\n",
      "Epoch 113 tr: l 0.679 a 0.787 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005676 12.022sec(train) 4.627sec(infer)\n",
      "Epoch 113 tst: l 0.853 a 0.724 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.881sec\n",
      "Epoch 114 tr: l 0.678 a 0.787 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005647 12.227sec(train) 3.976sec(infer)\n",
      "Epoch 114 tst: l 0.853 a 0.724 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.830sec\n",
      "Epoch 115 tr: l 0.678 a 0.787 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005619 12.923sec(train) 4.570sec(infer)\n",
      "Epoch 115 tst: l 0.853 a 0.724 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.942sec\n",
      "Epoch 116 tr: l 0.678 a 0.787 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005591 12.985sec(train) 3.402sec(infer)\n",
      "Epoch 116 tst: l 0.853 a 0.723 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.810sec\n",
      "Epoch 117 tr: l 0.677 a 0.788 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005563 13.296sec(train) 3.974sec(infer)\n",
      "Epoch 117 tst: l 0.853 a 0.724 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.795sec\n",
      "Epoch 118 tr: l 0.677 a 0.788 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005535 12.498sec(train) 4.618sec(infer)\n",
      "Epoch 118 tst: l 0.853 a 0.723 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.806sec\n",
      "Epoch 119 tr: l 0.676 a 0.788 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005507 12.030sec(train) 4.157sec(infer)\n",
      "Epoch 119 tst: l 0.853 a 0.723 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.933sec\n",
      "Epoch 120 tr: l 0.676 a 0.788 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005480 12.599sec(train) 4.400sec(infer)\n",
      "Epoch 120 tst: l 0.853 a 0.723 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.829sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 121 tr: l 0.676 a 0.788 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005452 13.045sec(train) 3.865sec(infer)\n",
      "Epoch 121 tst: l 0.853 a 0.724 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.803sec\n",
      "Epoch 122 tr: l 0.675 a 0.788 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005425 12.442sec(train) 4.275sec(infer)\n",
      "Epoch 122 tst: l 0.853 a 0.723 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.794sec\n",
      "Epoch 123 tr: l 0.675 a 0.788 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005398 12.707sec(train) 4.048sec(infer)\n",
      "Epoch 123 tst: l 0.853 a 0.724 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.819sec\n",
      "Epoch 124 tr: l 0.675 a 0.788 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005371 12.791sec(train) 4.086sec(infer)\n",
      "Epoch 124 tst: l 0.853 a 0.723 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.810sec\n",
      "Epoch 125 tr: l 0.674 a 0.788 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005344 11.796sec(train) 4.660sec(infer)\n",
      "Epoch 125 tst: l 0.853 a 0.723 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.948sec\n",
      "Epoch 126 tr: l 0.674 a 0.789 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005318 12.609sec(train) 3.942sec(infer)\n",
      "Epoch 126 tst: l 0.853 a 0.723 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.953sec\n",
      "Epoch 127 tr: l 0.674 a 0.789 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005291 13.868sec(train) 3.175sec(infer)\n",
      "Epoch 127 tst: l 0.853 a 0.723 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.574sec\n",
      "Epoch 128 tr: l 0.673 a 0.789 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005264 13.191sec(train) 4.646sec(infer)\n",
      "Epoch 128 tst: l 0.853 a 0.723 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.930sec\n",
      "Epoch 129 tr: l 0.673 a 0.789 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005238 11.263sec(train) 4.646sec(infer)\n",
      "Epoch 129 tst: l 0.853 a 0.723 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.942sec\n",
      "Epoch 130 tr: l 0.673 a 0.789 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005212 12.902sec(train) 3.477sec(infer)\n",
      "Epoch 130 tst: l 0.853 a 0.723 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.822sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 131 tr: l 0.672 a 0.789 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005186 13.169sec(train) 4.568sec(infer)\n",
      "Epoch 131 tst: l 0.853 a 0.723 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.828sec\n",
      "Epoch 132 tr: l 0.672 a 0.790 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005160 11.887sec(train) 3.927sec(infer)\n",
      "Epoch 132 tst: l 0.853 a 0.723 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.846sec\n",
      "Epoch 133 tr: l 0.672 a 0.790 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005134 13.216sec(train) 3.916sec(infer)\n",
      "Epoch 133 tst: l 0.853 a 0.723 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.799sec\n",
      "Epoch 134 tr: l 0.672 a 0.790 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005108 13.297sec(train) 4.218sec(infer)\n",
      "Epoch 134 tst: l 0.853 a 0.723 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.681sec\n",
      "Epoch 135 tr: l 0.671 a 0.790 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005083 11.713sec(train) 4.634sec(infer)\n",
      "Epoch 135 tst: l 0.853 a 0.723 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.949sec\n",
      "Epoch 136 tr: l 0.671 a 0.790 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005058 11.920sec(train) 4.706sec(infer)\n",
      "Epoch 136 tst: l 0.853 a 0.723 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.952sec\n",
      "Epoch 137 tr: l 0.671 a 0.790 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005032 13.961sec(train) 2.840sec(infer)\n",
      "Epoch 137 tst: l 0.853 a 0.723 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.712sec\n",
      "Epoch 138 tr: l 0.671 a 0.790 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005007 13.457sec(train) 4.266sec(infer)\n",
      "Epoch 138 tst: l 0.853 a 0.723 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.790sec\n",
      "Epoch 139 tr: l 0.670 a 0.790 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.004982 11.618sec(train) 4.676sec(infer)\n",
      "Epoch 139 tst: l 0.853 a 0.723 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.949sec\n",
      "Epoch 140 tr: l 0.670 a 0.790 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.004957 12.803sec(train) 3.609sec(infer)\n",
      "Epoch 140 tst: l 0.853 a 0.723 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.826sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 141 tr: l 0.670 a 0.790 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.004932 12.938sec(train) 4.481sec(infer)\n",
      "Epoch 141 tst: l 0.853 a 0.723 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.826sec\n",
      "Epoch 142 tr: l 0.670 a 0.790 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.004908 12.060sec(train) 4.309sec(infer)\n",
      "Epoch 142 tst: l 0.853 a 0.723 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.937sec\n",
      "Epoch 143 tr: l 0.669 a 0.791 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.004883 13.062sec(train) 3.430sec(infer)\n",
      "Epoch 143 tst: l 0.853 a 0.723 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.802sec\n",
      "Epoch 144 tr: l 0.669 a 0.791 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.004859 13.732sec(train) 4.058sec(infer)\n",
      "Epoch 144 tst: l 0.853 a 0.723 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.775sec\n",
      "Epoch 145 tr: l 0.669 a 0.791 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.004834 11.865sec(train) 4.640sec(infer)\n",
      "Epoch 145 tst: l 0.853 a 0.723 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.937sec\n",
      "Epoch 146 tr: l 0.669 a 0.791 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.004810 11.799sec(train) 4.214sec(infer)\n",
      "Epoch 146 tst: l 0.853 a 0.723 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.939sec\n",
      "Epoch 147 tr: l 0.668 a 0.791 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.004786 13.280sec(train) 4.131sec(infer)\n",
      "Epoch 147 tst: l 0.853 a 0.723 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.822sec\n",
      "Epoch 148 tr: l 0.668 a 0.791 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.004762 13.224sec(train) 3.656sec(infer)\n",
      "Epoch 148 tst: l 0.853 a 0.723 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.656sec\n",
      "Epoch 149 tr: l 0.668 a 0.791 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.004738 12.728sec(train) 4.527sec(infer)\n",
      "Epoch 149 tst: l 0.853 a 0.723 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.796sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "---train cluster Ended in 0.73 hour (2641.525 sec) \n",
      "---------------------------------DFedAvgM, lr: 0.1, seed: 7383---------------------------------\n",
      "config: {'m': 100, 'm_test': 20, 'p': 2, 'n': 1500, 'uneven': True, 'local_model_init': False, 'Gp': 0.15, 'graph': 'er', 'agg': 'seq', 'h1': 512, 'num_epochs': 150, 'batch_size': 100, 'tau': 3, 'lr': 0.1, 'data_seed': 7383, 'train_seed': 7383, 'config_override': '', 'project_dir': 'output_dfca_gi'}\n",
      "Using device: cuda:3\n",
      "Epoch -1 tr: l 3.883 a 0.026 clct[np.int64(100), np.int64(0)] cl_acc 0.500  3.927sec\n",
      "Epoch -1 tst: l 3.885 a 0.026 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.828sec\n",
      "Epoch 0 tr: l 3.523 a 0.191 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.100000 13.074sec(train) 3.912sec(infer)\n",
      "Epoch 0 tst: l 3.601 a 0.150 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.794sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 1 tr: l 3.182 a 0.296 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.099500 12.941sec(train) 4.465sec(infer)\n",
      "Epoch 1 tst: l 3.291 a 0.234 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.819sec\n",
      "Epoch 2 tr: l 2.830 a 0.371 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.099003 12.417sec(train) 3.999sec(infer)\n",
      "Epoch 2 tst: l 2.962 a 0.300 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.838sec\n",
      "Epoch 3 tr: l 2.516 a 0.433 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.098507 12.348sec(train) 4.604sec(infer)\n",
      "Epoch 3 tst: l 2.665 a 0.353 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.934sec\n",
      "Epoch 4 tr: l 2.260 a 0.479 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.098015 12.852sec(train) 3.906sec(infer)\n",
      "Epoch 4 tst: l 2.420 a 0.398 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.821sec\n",
      "Epoch 5 tr: l 2.059 a 0.513 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.097525 13.202sec(train) 3.736sec(infer)\n",
      "Epoch 5 tst: l 2.226 a 0.434 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.822sec\n",
      "Epoch 6 tr: l 1.902 a 0.539 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.097037 13.317sec(train) 4.236sec(infer)\n",
      "Epoch 6 tst: l 2.073 a 0.461 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.680sec\n",
      "Epoch 7 tr: l 1.773 a 0.560 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.096552 12.990sec(train) 3.944sec(infer)\n",
      "Epoch 7 tst: l 1.946 a 0.484 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.812sec\n",
      "Epoch 8 tr: l 1.681 a 0.571 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.096069 12.148sec(train) 4.655sec(infer)\n",
      "Epoch 8 tst: l 1.860 a 0.495 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.941sec\n",
      "Epoch 9 tr: l 1.620 a 0.570 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.095589 12.368sec(train) 4.086sec(infer)\n",
      "Epoch 9 tst: l 1.788 a 0.503 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.945sec\n",
      "Epoch 10 tr: l 1.598 a 0.555 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.095111 13.846sec(train) 3.590sec(infer)\n",
      "Epoch 10 tst: l 1.766 a 0.494 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.832sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 11 tr: l 1.538 a 0.576 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.094635 13.309sec(train) 4.200sec(infer)\n",
      "Epoch 11 tst: l 1.696 a 0.518 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.665sec\n",
      "Epoch 12 tr: l 1.498 a 0.568 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.094162 12.127sec(train) 4.634sec(infer)\n",
      "Epoch 12 tst: l 1.665 a 0.510 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.949sec\n",
      "Epoch 13 tr: l 1.414 a 0.609 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.093691 12.679sec(train) 3.839sec(infer)\n",
      "Epoch 13 tst: l 1.574 a 0.549 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.831sec\n",
      "Epoch 14 tr: l 1.363 a 0.609 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.093223 13.046sec(train) 4.396sec(infer)\n",
      "Epoch 14 tst: l 1.526 a 0.552 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.798sec\n",
      "Epoch 15 tr: l 1.311 a 0.634 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.092757 12.162sec(train) 4.425sec(infer)\n",
      "Epoch 15 tst: l 1.477 a 0.574 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.953sec\n",
      "Epoch 16 tr: l 1.274 a 0.632 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.092293 13.006sec(train) 3.622sec(infer)\n",
      "Epoch 16 tst: l 1.437 a 0.577 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.840sec\n",
      "Epoch 17 tr: l 1.230 a 0.652 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.091832 14.181sec(train) 3.716sec(infer)\n",
      "Epoch 17 tst: l 1.400 a 0.592 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.538sec\n",
      "Epoch 18 tr: l 1.205 a 0.649 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.091372 12.568sec(train) 4.654sec(infer)\n",
      "Epoch 18 tst: l 1.368 a 0.593 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.951sec\n",
      "Epoch 19 tr: l 1.166 a 0.667 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.090916 11.211sec(train) 4.658sec(infer)\n",
      "Epoch 19 tst: l 1.337 a 0.606 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.946sec\n",
      "Epoch 20 tr: l 1.146 a 0.665 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.090461 13.465sec(train) 3.375sec(infer)\n",
      "Epoch 20 tst: l 1.310 a 0.610 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.792sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 21 tr: l 1.118 a 0.676 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.090009 13.982sec(train) 4.196sec(infer)\n",
      "Epoch 21 tst: l 1.288 a 0.618 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.949sec\n",
      "Epoch 22 tr: l 1.107 a 0.678 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.089559 11.963sec(train) 4.327sec(infer)\n",
      "Epoch 22 tst: l 1.279 a 0.619 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.796sec\n",
      "Epoch 23 tr: l 1.115 a 0.672 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.089111 12.936sec(train) 4.182sec(infer)\n",
      "Epoch 23 tst: l 1.280 a 0.617 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.946sec\n",
      "Epoch 24 tr: l 1.085 a 0.682 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.088665 13.180sec(train) 4.056sec(infer)\n",
      "Epoch 24 tst: l 1.267 a 0.621 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.686sec\n",
      "Epoch 25 tr: l 1.060 a 0.685 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.088222 11.919sec(train) 4.612sec(infer)\n",
      "Epoch 25 tst: l 1.223 a 0.630 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.924sec\n",
      "Epoch 26 tr: l 1.034 a 0.693 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.087781 12.267sec(train) 4.477sec(infer)\n",
      "Epoch 26 tst: l 1.208 a 0.636 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.944sec\n",
      "Epoch 27 tr: l 1.020 a 0.695 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.087342 14.144sec(train) 2.804sec(infer)\n",
      "Epoch 27 tst: l 1.185 a 0.640 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.792sec\n",
      "Epoch 28 tr: l 0.999 a 0.701 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.086905 13.647sec(train) 4.441sec(infer)\n",
      "Epoch 28 tst: l 1.173 a 0.644 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.700sec\n",
      "Epoch 29 tr: l 0.987 a 0.703 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.086471 11.760sec(train) 4.632sec(infer)\n",
      "Epoch 29 tst: l 1.155 a 0.647 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.949sec\n",
      "Epoch 30 tr: l 0.969 a 0.709 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.086038 12.565sec(train) 3.956sec(infer)\n",
      "Epoch 30 tst: l 1.144 a 0.652 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.810sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 31 tr: l 0.959 a 0.711 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.085608 13.215sec(train) 4.054sec(infer)\n",
      "Epoch 31 tst: l 1.131 a 0.653 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.819sec\n",
      "Epoch 32 tr: l 0.946 a 0.715 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.085180 12.812sec(train) 4.113sec(infer)\n",
      "Epoch 32 tst: l 1.122 a 0.659 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.943sec\n",
      "Epoch 33 tr: l 0.940 a 0.714 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.084754 13.044sec(train) 3.565sec(infer)\n",
      "Epoch 33 tst: l 1.114 a 0.657 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.771sec\n",
      "Epoch 34 tr: l 0.935 a 0.715 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.084331 13.369sec(train) 4.358sec(infer)\n",
      "Epoch 34 tst: l 1.110 a 0.659 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.907sec\n",
      "Epoch 35 tr: l 0.927 a 0.715 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.083909 12.163sec(train) 4.405sec(infer)\n",
      "Epoch 35 tst: l 1.105 a 0.656 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.823sec\n",
      "Epoch 36 tr: l 0.911 a 0.722 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.083489 12.269sec(train) 4.311sec(infer)\n",
      "Epoch 36 tst: l 1.088 a 0.664 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.938sec\n",
      "Epoch 37 tr: l 0.899 a 0.725 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.083072 13.117sec(train) 4.259sec(infer)\n",
      "Epoch 37 tst: l 1.078 a 0.666 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.796sec\n",
      "Epoch 38 tr: l 0.887 a 0.729 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.082657 13.353sec(train) 3.336sec(infer)\n",
      "Epoch 38 tst: l 1.068 a 0.668 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.834sec\n",
      "Epoch 39 tr: l 0.876 a 0.731 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.082243 13.186sec(train) 4.541sec(infer)\n",
      "Epoch 39 tst: l 1.060 a 0.670 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.733sec\n",
      "Epoch 40 tr: l 0.866 a 0.735 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.081832 12.561sec(train) 3.994sec(infer)\n",
      "Epoch 40 tst: l 1.052 a 0.673 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.811sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 41 tr: l 0.857 a 0.736 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.081423 12.380sec(train) 4.519sec(infer)\n",
      "Epoch 41 tst: l 1.041 a 0.676 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.952sec\n",
      "Epoch 42 tr: l 0.850 a 0.739 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.081016 12.380sec(train) 4.207sec(infer)\n",
      "Epoch 42 tst: l 1.040 a 0.675 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.828sec\n",
      "Epoch 43 tr: l 0.844 a 0.739 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.080611 13.579sec(train) 3.482sec(infer)\n",
      "Epoch 43 tst: l 1.031 a 0.677 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.865sec\n",
      "Epoch 44 tr: l 0.838 a 0.742 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.080208 13.066sec(train) 4.259sec(infer)\n",
      "Epoch 44 tst: l 1.035 a 0.677 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.782sec\n",
      "Epoch 45 tr: l 0.835 a 0.741 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.079807 12.533sec(train) 4.189sec(infer)\n",
      "Epoch 45 tst: l 1.019 a 0.680 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.945sec\n",
      "Epoch 46 tr: l 0.827 a 0.744 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.079408 12.911sec(train) 4.080sec(infer)\n",
      "Epoch 46 tst: l 1.029 a 0.678 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.840sec\n",
      "Epoch 47 tr: l 0.821 a 0.744 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.079010 12.687sec(train) 4.537sec(infer)\n",
      "Epoch 47 tst: l 1.009 a 0.683 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.795sec\n",
      "Epoch 48 tr: l 0.810 a 0.748 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.078615 12.168sec(train) 4.494sec(infer)\n",
      "Epoch 48 tst: l 1.014 a 0.681 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.953sec\n",
      "Epoch 49 tr: l 0.803 a 0.750 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.078222 13.309sec(train) 3.305sec(infer)\n",
      "Epoch 49 tst: l 0.993 a 0.688 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.797sec\n",
      "Epoch 50 tr: l 0.795 a 0.752 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.077831 13.960sec(train) 4.001sec(infer)\n",
      "Epoch 50 tst: l 1.001 a 0.685 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.665sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 51 tr: l 0.790 a 0.754 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.077442 12.031sec(train) 4.621sec(infer)\n",
      "Epoch 51 tst: l 0.984 a 0.691 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.940sec\n",
      "Epoch 52 tr: l 0.784 a 0.755 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.077055 11.818sec(train) 4.344sec(infer)\n",
      "Epoch 52 tst: l 0.990 a 0.688 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.953sec\n",
      "Epoch 53 tr: l 0.778 a 0.757 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.076670 13.300sec(train) 3.655sec(infer)\n",
      "Epoch 53 tst: l 0.976 a 0.693 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.697sec\n",
      "Epoch 54 tr: l 0.773 a 0.758 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.076286 13.410sec(train) 4.199sec(infer)\n",
      "Epoch 54 tst: l 0.981 a 0.690 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.952sec\n",
      "Epoch 55 tr: l 0.768 a 0.760 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.075905 12.042sec(train) 4.252sec(infer)\n",
      "Epoch 55 tst: l 0.971 a 0.694 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.782sec\n",
      "Epoch 56 tr: l 0.764 a 0.760 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.075525 13.595sec(train) 3.558sec(infer)\n",
      "Epoch 56 tst: l 0.973 a 0.692 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.890sec\n",
      "Epoch 57 tr: l 0.759 a 0.762 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.075148 13.182sec(train) 4.618sec(infer)\n",
      "Epoch 57 tst: l 0.965 a 0.696 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.793sec\n",
      "Epoch 58 tr: l 0.756 a 0.762 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.074772 11.493sec(train) 4.647sec(infer)\n",
      "Epoch 58 tst: l 0.965 a 0.694 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.926sec\n",
      "Epoch 59 tr: l 0.752 a 0.764 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.074398 12.705sec(train) 4.592sec(infer)\n",
      "Epoch 59 tst: l 0.962 a 0.695 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.955sec\n",
      "Epoch 60 tr: l 0.749 a 0.763 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.074026 13.907sec(train) 2.854sec(infer)\n",
      "Epoch 60 tst: l 0.959 a 0.696 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.666sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 61 tr: l 0.745 a 0.766 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.073656 13.230sec(train) 4.412sec(infer)\n",
      "Epoch 61 tst: l 0.962 a 0.693 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.804sec\n",
      "Epoch 62 tr: l 0.743 a 0.765 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.073288 11.652sec(train) 4.661sec(infer)\n",
      "Epoch 62 tst: l 0.952 a 0.698 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.946sec\n",
      "Epoch 63 tr: l 0.737 a 0.767 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.072921 12.948sec(train) 3.546sec(infer)\n",
      "Epoch 63 tst: l 0.957 a 0.694 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.797sec\n",
      "Epoch 64 tr: l 0.733 a 0.767 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.072557 13.060sec(train) 4.473sec(infer)\n",
      "Epoch 64 tst: l 0.944 a 0.700 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.835sec\n",
      "Epoch 65 tr: l 0.728 a 0.770 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.072194 12.200sec(train) 4.263sec(infer)\n",
      "Epoch 65 tst: l 0.950 a 0.696 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.958sec\n",
      "Epoch 66 tr: l 0.724 a 0.770 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.071833 13.174sec(train) 3.447sec(infer)\n",
      "Epoch 66 tst: l 0.938 a 0.702 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.775sec\n",
      "Epoch 67 tr: l 0.720 a 0.772 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.071474 12.827sec(train) 4.032sec(infer)\n",
      "Epoch 67 tst: l 0.943 a 0.699 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.795sec\n",
      "Epoch 68 tr: l 0.716 a 0.772 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.071116 12.252sec(train) 4.671sec(infer)\n",
      "Epoch 68 tst: l 0.933 a 0.703 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.942sec\n",
      "Epoch 69 tr: l 0.713 a 0.774 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.070761 12.568sec(train) 4.146sec(infer)\n",
      "Epoch 69 tst: l 0.936 a 0.700 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.943sec\n",
      "Epoch 70 tr: l 0.709 a 0.773 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.070407 13.398sec(train) 3.559sec(infer)\n",
      "Epoch 70 tst: l 0.928 a 0.704 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.659sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 71 tr: l 0.706 a 0.776 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.070055 13.258sec(train) 4.164sec(infer)\n",
      "Epoch 71 tst: l 0.931 a 0.701 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.698sec\n",
      "Epoch 72 tr: l 0.703 a 0.775 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.069705 12.210sec(train) 4.579sec(infer)\n",
      "Epoch 72 tst: l 0.925 a 0.704 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.951sec\n",
      "Epoch 73 tr: l 0.700 a 0.777 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.069356 12.273sec(train) 4.122sec(infer)\n",
      "Epoch 73 tst: l 0.925 a 0.702 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.808sec\n",
      "Epoch 74 tr: l 0.698 a 0.776 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.069009 13.194sec(train) 4.146sec(infer)\n",
      "Epoch 74 tst: l 0.923 a 0.704 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.962sec\n",
      "Epoch 75 tr: l 0.696 a 0.778 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.068664 12.976sec(train) 3.815sec(infer)\n",
      "Epoch 75 tst: l 0.920 a 0.703 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.764sec\n",
      "Epoch 76 tr: l 0.693 a 0.777 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.068321 13.357sec(train) 3.861sec(infer)\n",
      "Epoch 76 tst: l 0.922 a 0.704 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.687sec\n",
      "Epoch 77 tr: l 0.691 a 0.779 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.067979 12.661sec(train) 4.693sec(infer)\n",
      "Epoch 77 tst: l 0.914 a 0.705 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.950sec\n",
      "Epoch 78 tr: l 0.688 a 0.779 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.067639 12.139sec(train) 4.048sec(infer)\n",
      "Epoch 78 tst: l 0.920 a 0.704 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.831sec\n",
      "Epoch 79 tr: l 0.685 a 0.781 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.067301 13.305sec(train) 4.186sec(infer)\n",
      "Epoch 79 tst: l 0.907 a 0.707 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.944sec\n",
      "Epoch 80 tr: l 0.682 a 0.780 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.066965 13.213sec(train) 4.025sec(infer)\n",
      "Epoch 80 tst: l 0.919 a 0.704 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.815sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 81 tr: l 0.680 a 0.782 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.066630 12.836sec(train) 4.000sec(infer)\n",
      "Epoch 81 tst: l 0.898 a 0.710 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.792sec\n",
      "Epoch 82 tr: l 0.678 a 0.781 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.066297 13.054sec(train) 4.230sec(infer)\n",
      "Epoch 82 tst: l 0.921 a 0.703 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.826sec\n",
      "Epoch 83 tr: l 0.677 a 0.782 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.065965 12.719sec(train) 4.220sec(infer)\n",
      "Epoch 83 tst: l 0.889 a 0.714 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.788sec\n",
      "Epoch 84 tr: l 0.677 a 0.781 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.065635 11.801sec(train) 4.640sec(infer)\n",
      "Epoch 84 tst: l 0.928 a 0.701 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.944sec\n",
      "Epoch 85 tr: l 0.677 a 0.781 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.065307 12.925sec(train) 3.858sec(infer)\n",
      "Epoch 85 tst: l 0.883 a 0.716 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.899sec\n",
      "Epoch 86 tr: l 0.678 a 0.779 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.064981 13.991sec(train) 3.308sec(infer)\n",
      "Epoch 86 tst: l 0.935 a 0.699 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.580sec\n",
      "Epoch 87 tr: l 0.676 a 0.781 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.064656 12.795sec(train) 4.629sec(infer)\n",
      "Epoch 87 tst: l 0.880 a 0.717 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.886sec\n",
      "Epoch 88 tr: l 0.675 a 0.780 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.064333 11.831sec(train) 4.533sec(infer)\n",
      "Epoch 88 tst: l 0.934 a 0.699 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.938sec\n",
      "Epoch 89 tr: l 0.671 a 0.782 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.064011 12.977sec(train) 3.601sec(infer)\n",
      "Epoch 89 tst: l 0.875 a 0.719 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.829sec\n",
      "Epoch 90 tr: l 0.669 a 0.782 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.063691 13.187sec(train) 4.617sec(infer)\n",
      "Epoch 90 tst: l 0.927 a 0.701 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.830sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 91 tr: l 0.665 a 0.784 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.063372 12.196sec(train) 3.948sec(infer)\n",
      "Epoch 91 tst: l 0.871 a 0.721 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.938sec\n",
      "Epoch 92 tr: l 0.663 a 0.784 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.063056 13.366sec(train) 3.747sec(infer)\n",
      "Epoch 92 tst: l 0.919 a 0.704 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.799sec\n",
      "Epoch 93 tr: l 0.660 a 0.786 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.062740 13.572sec(train) 4.195sec(infer)\n",
      "Epoch 93 tst: l 0.867 a 0.722 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.678sec\n",
      "Epoch 94 tr: l 0.658 a 0.786 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.062427 11.877sec(train) 4.628sec(infer)\n",
      "Epoch 94 tst: l 0.913 a 0.706 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.960sec\n",
      "Epoch 95 tr: l 0.655 a 0.787 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.062114 11.892sec(train) 4.687sec(infer)\n",
      "Epoch 95 tst: l 0.863 a 0.723 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.928sec\n",
      "Epoch 96 tr: l 0.654 a 0.787 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.061804 13.990sec(train) 3.054sec(infer)\n",
      "Epoch 96 tst: l 0.909 a 0.708 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.684sec\n",
      "Epoch 97 tr: l 0.651 a 0.788 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.061495 13.780sec(train) 4.088sec(infer)\n",
      "Epoch 97 tst: l 0.860 a 0.724 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.784sec\n",
      "Epoch 98 tr: l 0.650 a 0.788 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.061187 11.873sec(train) 4.673sec(infer)\n",
      "Epoch 98 tst: l 0.905 a 0.709 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.941sec\n",
      "Epoch 99 tr: l 0.647 a 0.789 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.060881 12.982sec(train) 3.935sec(infer)\n",
      "Epoch 99 tst: l 0.857 a 0.725 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.954sec\n",
      "Epoch 100 tr: l 0.676 a 0.783 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.006058 13.151sec(train) 4.273sec(infer)\n",
      "Epoch 100 tst: l 0.824 a 0.740 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.730sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 101 tr: l 0.678 a 0.783 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.006027 12.190sec(train) 4.586sec(infer)\n",
      "Epoch 101 tst: l 0.818 a 0.744 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.955sec\n",
      "Epoch 102 tr: l 0.677 a 0.783 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005997 12.725sec(train) 3.705sec(infer)\n",
      "Epoch 102 tst: l 0.817 a 0.746 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.964sec\n",
      "Epoch 103 tr: l 0.677 a 0.783 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005967 13.836sec(train) 3.678sec(infer)\n",
      "Epoch 103 tst: l 0.816 a 0.746 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.647sec\n",
      "Epoch 104 tr: l 0.676 a 0.784 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005937 12.885sec(train) 4.542sec(infer)\n",
      "Epoch 104 tst: l 0.816 a 0.746 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.833sec\n",
      "Epoch 105 tr: l 0.676 a 0.784 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005908 11.633sec(train) 4.632sec(infer)\n",
      "Epoch 105 tst: l 0.816 a 0.745 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.943sec\n",
      "Epoch 106 tr: l 0.675 a 0.784 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005878 12.654sec(train) 4.057sec(infer)\n",
      "Epoch 106 tst: l 0.815 a 0.745 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.801sec\n",
      "Epoch 107 tr: l 0.675 a 0.785 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005849 13.677sec(train) 3.572sec(infer)\n",
      "Epoch 107 tst: l 0.815 a 0.745 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.856sec\n",
      "Epoch 108 tr: l 0.674 a 0.785 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005820 13.085sec(train) 4.193sec(infer)\n",
      "Epoch 108 tst: l 0.815 a 0.744 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.802sec\n",
      "Epoch 109 tr: l 0.674 a 0.785 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005790 12.859sec(train) 3.963sec(infer)\n",
      "Epoch 109 tst: l 0.815 a 0.745 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.837sec\n",
      "Epoch 110 tr: l 0.674 a 0.785 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005762 12.770sec(train) 4.399sec(infer)\n",
      "Epoch 110 tst: l 0.815 a 0.745 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.956sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 111 tr: l 0.673 a 0.785 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005733 12.020sec(train) 4.315sec(infer)\n",
      "Epoch 111 tst: l 0.815 a 0.745 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.814sec\n",
      "Epoch 112 tr: l 0.673 a 0.785 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005704 13.045sec(train) 4.180sec(infer)\n",
      "Epoch 112 tst: l 0.815 a 0.745 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.956sec\n",
      "Epoch 113 tr: l 0.673 a 0.786 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005676 13.200sec(train) 3.724sec(infer)\n",
      "Epoch 113 tst: l 0.815 a 0.745 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.677sec\n",
      "Epoch 114 tr: l 0.672 a 0.786 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005647 13.257sec(train) 4.054sec(infer)\n",
      "Epoch 114 tst: l 0.815 a 0.745 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.799sec\n",
      "Epoch 115 tr: l 0.672 a 0.786 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005619 12.658sec(train) 4.612sec(infer)\n",
      "Epoch 115 tst: l 0.815 a 0.745 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.835sec\n",
      "Epoch 116 tr: l 0.672 a 0.786 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005591 12.463sec(train) 4.165sec(infer)\n",
      "Epoch 116 tst: l 0.814 a 0.745 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.805sec\n",
      "Epoch 117 tr: l 0.672 a 0.786 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005563 12.534sec(train) 4.666sec(infer)\n",
      "Epoch 117 tst: l 0.814 a 0.745 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.945sec\n",
      "Epoch 118 tr: l 0.671 a 0.786 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005535 13.023sec(train) 3.457sec(infer)\n",
      "Epoch 118 tst: l 0.814 a 0.745 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.816sec\n",
      "Epoch 119 tr: l 0.671 a 0.786 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005507 11.749sec(train) 2.231sec(infer)\n",
      "Epoch 119 tst: l 0.814 a 0.745 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.491sec\n",
      "Epoch 120 tr: l 0.671 a 0.786 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005480 11.399sec(train) 4.411sec(infer)\n",
      "Epoch 120 tst: l 0.814 a 0.745 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.901sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 121 tr: l 0.671 a 0.786 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005452 12.080sec(train) 4.373sec(infer)\n",
      "Epoch 121 tst: l 0.814 a 0.745 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.837sec\n",
      "Epoch 122 tr: l 0.670 a 0.786 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005425 12.399sec(train) 4.272sec(infer)\n",
      "Epoch 122 tst: l 0.814 a 0.745 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.844sec\n",
      "Epoch 123 tr: l 0.670 a 0.786 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005398 12.801sec(train) 4.236sec(infer)\n",
      "Epoch 123 tst: l 0.814 a 0.745 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.809sec\n",
      "Epoch 124 tr: l 0.670 a 0.786 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005371 13.256sec(train) 3.326sec(infer)\n",
      "Epoch 124 tst: l 0.814 a 0.745 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.792sec\n",
      "Epoch 125 tr: l 0.670 a 0.786 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005344 13.247sec(train) 4.540sec(infer)\n",
      "Epoch 125 tst: l 0.814 a 0.745 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.692sec\n",
      "Epoch 126 tr: l 0.669 a 0.786 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005318 12.550sec(train) 4.091sec(infer)\n",
      "Epoch 126 tst: l 0.814 a 0.745 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.811sec\n",
      "Epoch 127 tr: l 0.669 a 0.787 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005291 12.208sec(train) 4.534sec(infer)\n",
      "Epoch 127 tst: l 0.814 a 0.745 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.954sec\n",
      "Epoch 128 tr: l 0.669 a 0.787 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005264 12.503sec(train) 4.175sec(infer)\n",
      "Epoch 128 tst: l 0.814 a 0.745 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.811sec\n",
      "Epoch 129 tr: l 0.669 a 0.787 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005238 13.949sec(train) 3.375sec(infer)\n",
      "Epoch 129 tst: l 0.813 a 0.745 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.871sec\n",
      "Epoch 130 tr: l 0.669 a 0.787 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005212 13.086sec(train) 4.379sec(infer)\n",
      "Epoch 130 tst: l 0.813 a 0.745 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.796sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 131 tr: l 0.668 a 0.787 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005186 12.324sec(train) 4.263sec(infer)\n",
      "Epoch 131 tst: l 0.813 a 0.745 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.967sec\n",
      "Epoch 132 tr: l 0.668 a 0.787 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005160 12.870sec(train) 3.631sec(infer)\n",
      "Epoch 132 tst: l 0.813 a 0.745 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.683sec\n",
      "Epoch 133 tr: l 0.668 a 0.787 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005134 11.879sec(train) 4.669sec(infer)\n",
      "Epoch 133 tst: l 0.813 a 0.745 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.927sec\n",
      "Epoch 134 tr: l 0.668 a 0.787 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005108 12.531sec(train) 4.366sec(infer)\n",
      "Epoch 134 tst: l 0.813 a 0.745 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.949sec\n",
      "Epoch 135 tr: l 0.668 a 0.787 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005083 14.033sec(train) 2.851sec(infer)\n",
      "Epoch 135 tst: l 0.813 a 0.745 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.560sec\n",
      "Epoch 136 tr: l 0.668 a 0.787 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005058 13.447sec(train) 4.679sec(infer)\n",
      "Epoch 136 tst: l 0.813 a 0.745 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.914sec\n",
      "Epoch 137 tr: l 0.667 a 0.788 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005032 11.288sec(train) 4.673sec(infer)\n",
      "Epoch 137 tst: l 0.813 a 0.745 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.975sec\n",
      "Epoch 138 tr: l 0.667 a 0.788 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005007 12.953sec(train) 3.813sec(infer)\n",
      "Epoch 138 tst: l 0.813 a 0.745 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.822sec\n",
      "Epoch 139 tr: l 0.667 a 0.788 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.004982 13.401sec(train) 4.163sec(infer)\n",
      "Epoch 139 tst: l 0.812 a 0.745 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.830sec\n",
      "Epoch 140 tr: l 0.667 a 0.788 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.004957 12.635sec(train) 3.937sec(infer)\n",
      "Epoch 140 tst: l 0.812 a 0.745 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.906sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 141 tr: l 0.667 a 0.788 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.004932 13.110sec(train) 3.824sec(infer)\n",
      "Epoch 141 tst: l 0.812 a 0.746 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.742sec\n",
      "Epoch 142 tr: l 0.666 a 0.788 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.004908 13.404sec(train) 4.162sec(infer)\n",
      "Epoch 142 tst: l 0.812 a 0.746 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.927sec\n",
      "Epoch 143 tr: l 0.666 a 0.788 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.004883 12.156sec(train) 4.660sec(infer)\n",
      "Epoch 143 tst: l 0.812 a 0.746 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.821sec\n",
      "Epoch 144 tr: l 0.666 a 0.788 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.004859 12.316sec(train) 4.323sec(infer)\n",
      "Epoch 144 tst: l 0.812 a 0.746 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.957sec\n",
      "Epoch 145 tr: l 0.666 a 0.788 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.004834 13.288sec(train) 3.939sec(infer)\n",
      "Epoch 145 tst: l 0.812 a 0.746 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.805sec\n",
      "Epoch 146 tr: l 0.666 a 0.788 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.004810 13.477sec(train) 3.565sec(infer)\n",
      "Epoch 146 tst: l 0.812 a 0.746 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.701sec\n",
      "Epoch 147 tr: l 0.666 a 0.788 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.004786 12.922sec(train) 4.681sec(infer)\n",
      "Epoch 147 tst: l 0.812 a 0.746 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.963sec\n",
      "Epoch 148 tr: l 0.665 a 0.788 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.004762 12.264sec(train) 4.103sec(infer)\n",
      "Epoch 148 tst: l 0.812 a 0.746 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.810sec\n",
      "Epoch 149 tr: l 0.665 a 0.788 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.004738 12.660sec(train) 4.426sec(infer)\n",
      "Epoch 149 tst: l 0.812 a 0.746 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.947sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "---train cluster Ended in 0.74 hour (2670.645 sec) \n",
      "---------------------------------DFedAvgM, lr: 0.1, seed: 6930---------------------------------\n",
      "config: {'m': 100, 'm_test': 20, 'p': 2, 'n': 1500, 'uneven': True, 'local_model_init': False, 'Gp': 0.15, 'graph': 'er', 'agg': 'seq', 'h1': 512, 'num_epochs': 150, 'batch_size': 100, 'tau': 3, 'lr': 0.1, 'data_seed': 6930, 'train_seed': 6930, 'config_override': '', 'project_dir': 'output_dfca_gi'}\n",
      "Using device: cuda:3\n",
      "Epoch -1 tr: l 3.891 a 0.022 clct[np.int64(100), np.int64(0)] cl_acc 0.500  4.438sec\n",
      "Epoch -1 tst: l 3.890 a 0.021 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.797sec\n",
      "Epoch 0 tr: l 3.491 a 0.184 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.100000 12.389sec(train) 4.432sec(infer)\n",
      "Epoch 0 tst: l 3.593 a 0.151 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.930sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 1 tr: l 3.172 a 0.286 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.099500 12.543sec(train) 4.471sec(infer)\n",
      "Epoch 1 tst: l 3.284 a 0.246 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.813sec\n",
      "Epoch 2 tr: l 2.834 a 0.340 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.099003 13.520sec(train) 3.543sec(infer)\n",
      "Epoch 2 tst: l 2.966 a 0.291 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.801sec\n",
      "Epoch 3 tr: l 2.552 a 0.400 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.098507 12.901sec(train) 4.335sec(infer)\n",
      "Epoch 3 tst: l 2.681 a 0.357 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.785sec\n",
      "Epoch 4 tr: l 2.321 a 0.435 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.098015 12.565sec(train) 4.158sec(infer)\n",
      "Epoch 4 tst: l 2.457 a 0.381 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.842sec\n",
      "Epoch 5 tr: l 2.131 a 0.476 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.097525 13.119sec(train) 4.111sec(infer)\n",
      "Epoch 5 tst: l 2.262 a 0.427 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.847sec\n",
      "Epoch 6 tr: l 1.987 a 0.493 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.097037 12.255sec(train) 4.710sec(infer)\n",
      "Epoch 6 tst: l 2.120 a 0.445 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.903sec\n",
      "Epoch 7 tr: l 1.874 a 0.513 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.096552 12.394sec(train) 4.490sec(infer)\n",
      "Epoch 7 tst: l 2.000 a 0.466 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.939sec\n",
      "Epoch 8 tr: l 1.795 a 0.509 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.096069 13.496sec(train) 3.194sec(infer)\n",
      "Epoch 8 tst: l 1.920 a 0.463 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.778sec\n",
      "Epoch 9 tr: l 1.716 a 0.527 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.095589 13.698sec(train) 4.321sec(infer)\n",
      "Epoch 9 tst: l 1.842 a 0.487 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.638sec\n",
      "Epoch 10 tr: l 1.649 a 0.532 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.095111 11.793sec(train) 4.740sec(infer)\n",
      "Epoch 10 tst: l 1.772 a 0.493 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.928sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 11 tr: l 1.568 a 0.563 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.094635 12.187sec(train) 4.292sec(infer)\n",
      "Epoch 11 tst: l 1.689 a 0.520 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.859sec\n",
      "Epoch 12 tr: l 1.512 a 0.564 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.094162 13.382sec(train) 3.960sec(infer)\n",
      "Epoch 12 tst: l 1.635 a 0.526 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.668sec\n",
      "Epoch 13 tr: l 1.444 a 0.593 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.093691 13.080sec(train) 4.203sec(infer)\n",
      "Epoch 13 tst: l 1.565 a 0.553 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.938sec\n",
      "Epoch 14 tr: l 1.401 a 0.592 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.093223 12.249sec(train) 4.384sec(infer)\n",
      "Epoch 14 tst: l 1.521 a 0.557 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.800sec\n",
      "Epoch 15 tr: l 1.354 a 0.614 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.092757 13.662sec(train) 3.494sec(infer)\n",
      "Epoch 15 tst: l 1.477 a 0.573 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.783sec\n",
      "Epoch 16 tr: l 1.317 a 0.611 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.092293 13.011sec(train) 4.727sec(infer)\n",
      "Epoch 16 tst: l 1.438 a 0.574 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.907sec\n",
      "Epoch 17 tr: l 1.277 a 0.628 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.091832 11.286sec(train) 4.751sec(infer)\n",
      "Epoch 17 tst: l 1.401 a 0.591 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.923sec\n",
      "Epoch 18 tr: l 1.277 a 0.621 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.091372 13.135sec(train) 4.300sec(infer)\n",
      "Epoch 18 tst: l 1.399 a 0.584 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.941sec\n",
      "Epoch 19 tr: l 1.281 a 0.607 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.090916 14.044sec(train) 3.187sec(infer)\n",
      "Epoch 19 tst: l 1.398 a 0.575 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.622sec\n",
      "Epoch 20 tr: l 1.220 a 0.633 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.090461 12.938sec(train) 4.657sec(infer)\n",
      "Epoch 20 tst: l 1.342 a 0.595 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.785sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 21 tr: l 1.163 a 0.650 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.090009 11.731sec(train) 4.705sec(infer)\n",
      "Epoch 21 tst: l 1.282 a 0.615 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.951sec\n",
      "Epoch 22 tr: l 1.137 a 0.657 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.089559 13.054sec(train) 3.581sec(infer)\n",
      "Epoch 22 tst: l 1.262 a 0.619 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.795sec\n",
      "Epoch 23 tr: l 1.115 a 0.663 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.089111 12.884sec(train) 4.733sec(infer)\n",
      "Epoch 23 tst: l 1.234 a 0.627 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.802sec\n",
      "Epoch 24 tr: l 1.093 a 0.667 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.088665 12.183sec(train) 4.247sec(infer)\n",
      "Epoch 24 tst: l 1.220 a 0.629 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.929sec\n",
      "Epoch 25 tr: l 1.077 a 0.672 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.088222 13.355sec(train) 3.586sec(infer)\n",
      "Epoch 25 tst: l 1.197 a 0.637 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.684sec\n",
      "Epoch 26 tr: l 1.052 a 0.677 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.087781 13.864sec(train) 4.039sec(infer)\n",
      "Epoch 26 tst: l 1.181 a 0.640 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.833sec\n",
      "Epoch 27 tr: l 1.038 a 0.681 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.087342 11.924sec(train) 4.774sec(infer)\n",
      "Epoch 27 tst: l 1.159 a 0.646 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.924sec\n",
      "Epoch 28 tr: l 1.017 a 0.686 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.086905 12.086sec(train) 4.158sec(infer)\n",
      "Epoch 28 tst: l 1.148 a 0.647 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.924sec\n",
      "Epoch 29 tr: l 1.006 a 0.690 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.086471 13.457sec(train) 4.323sec(infer)\n",
      "Epoch 29 tst: l 1.129 a 0.654 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.791sec\n",
      "Epoch 30 tr: l 0.986 a 0.694 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.086038 13.197sec(train) 3.598sec(infer)\n",
      "Epoch 30 tst: l 1.119 a 0.656 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.707sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 31 tr: l 0.975 a 0.697 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.085608 13.013sec(train) 4.445sec(infer)\n",
      "Epoch 31 tst: l 1.100 a 0.661 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.789sec\n",
      "Epoch 32 tr: l 0.960 a 0.701 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.085180 12.399sec(train) 4.360sec(infer)\n",
      "Epoch 32 tst: l 1.095 a 0.663 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.790sec\n",
      "Epoch 33 tr: l 0.951 a 0.702 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.084754 12.568sec(train) 4.127sec(infer)\n",
      "Epoch 33 tst: l 1.077 a 0.665 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.861sec\n",
      "Epoch 34 tr: l 0.939 a 0.706 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.084331 12.470sec(train) 4.713sec(infer)\n",
      "Epoch 34 tst: l 1.076 a 0.668 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.860sec\n",
      "Epoch 35 tr: l 0.932 a 0.706 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.083909 13.150sec(train) 3.576sec(infer)\n",
      "Epoch 35 tst: l 1.057 a 0.671 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.811sec\n",
      "Epoch 36 tr: l 0.919 a 0.710 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.083489 13.166sec(train) 4.240sec(infer)\n",
      "Epoch 36 tst: l 1.059 a 0.674 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.798sec\n",
      "Epoch 37 tr: l 0.908 a 0.711 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.083072 12.826sec(train) 4.185sec(infer)\n",
      "Epoch 37 tst: l 1.037 a 0.676 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.810sec\n",
      "Epoch 38 tr: l 0.900 a 0.715 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.082657 12.899sec(train) 4.106sec(infer)\n",
      "Epoch 38 tst: l 1.042 a 0.677 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.939sec\n",
      "Epoch 39 tr: l 0.889 a 0.717 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.082243 12.218sec(train) 4.759sec(infer)\n",
      "Epoch 39 tst: l 1.020 a 0.682 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.915sec\n",
      "Epoch 40 tr: l 0.878 a 0.720 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.081832 12.352sec(train) 4.231sec(infer)\n",
      "Epoch 40 tst: l 1.022 a 0.682 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.924sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 41 tr: l 0.869 a 0.723 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.081423 13.540sec(train) 3.411sec(infer)\n",
      "Epoch 41 tst: l 1.003 a 0.686 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.714sec\n",
      "Epoch 42 tr: l 0.861 a 0.724 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.081016 13.537sec(train) 4.416sec(infer)\n",
      "Epoch 42 tst: l 1.006 a 0.684 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.643sec\n",
      "Epoch 43 tr: l 0.854 a 0.727 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.080611 11.820sec(train) 4.752sec(infer)\n",
      "Epoch 43 tst: l 0.992 a 0.688 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.922sec\n",
      "Epoch 44 tr: l 0.846 a 0.727 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.080208 12.373sec(train) 4.149sec(infer)\n",
      "Epoch 44 tst: l 0.991 a 0.688 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.833sec\n",
      "Epoch 45 tr: l 0.844 a 0.729 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.079807 13.308sec(train) 4.125sec(infer)\n",
      "Epoch 45 tst: l 0.988 a 0.689 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.754sec\n",
      "Epoch 46 tr: l 0.849 a 0.724 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.079408 12.785sec(train) 4.227sec(infer)\n",
      "Epoch 46 tst: l 0.989 a 0.687 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.922sec\n",
      "Epoch 47 tr: l 0.843 a 0.728 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.079010 12.700sec(train) 4.143sec(infer)\n",
      "Epoch 47 tst: l 0.991 a 0.686 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.795sec\n",
      "Epoch 48 tr: l 0.834 a 0.726 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.078615 13.720sec(train) 3.566sec(infer)\n",
      "Epoch 48 tst: l 0.970 a 0.690 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.739sec\n",
      "Epoch 49 tr: l 0.823 a 0.734 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.078222 12.790sec(train) 4.741sec(infer)\n",
      "Epoch 49 tst: l 0.976 a 0.691 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.935sec\n",
      "Epoch 50 tr: l 0.818 a 0.731 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.077831 11.187sec(train) 4.727sec(infer)\n",
      "Epoch 50 tst: l 0.957 a 0.694 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.926sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 51 tr: l 0.811 a 0.738 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.077442 13.438sec(train) 4.046sec(infer)\n",
      "Epoch 51 tst: l 0.966 a 0.694 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.925sec\n",
      "Epoch 52 tr: l 0.803 a 0.736 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.077055 13.937sec(train) 3.504sec(infer)\n",
      "Epoch 52 tst: l 0.943 a 0.697 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.551sec\n",
      "Epoch 53 tr: l 0.797 a 0.742 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.076670 12.553sec(train) 4.687sec(infer)\n",
      "Epoch 53 tst: l 0.953 a 0.697 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.765sec\n",
      "Epoch 54 tr: l 0.789 a 0.740 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.076286 11.986sec(train) 4.747sec(infer)\n",
      "Epoch 54 tst: l 0.931 a 0.700 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.931sec\n",
      "Epoch 55 tr: l 0.784 a 0.745 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.075905 13.147sec(train) 3.555sec(infer)\n",
      "Epoch 55 tst: l 0.943 a 0.700 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.677sec\n",
      "Epoch 56 tr: l 0.776 a 0.744 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.075525 12.872sec(train) 4.772sec(infer)\n",
      "Epoch 56 tst: l 0.921 a 0.703 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.932sec\n",
      "Epoch 57 tr: l 0.773 a 0.748 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.075148 12.111sec(train) 4.145sec(infer)\n",
      "Epoch 57 tst: l 0.933 a 0.703 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.930sec\n",
      "Epoch 58 tr: l 0.766 a 0.747 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.074772 13.893sec(train) 3.426sec(infer)\n",
      "Epoch 58 tst: l 0.912 a 0.706 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.688sec\n",
      "Epoch 59 tr: l 0.764 a 0.750 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.074398 13.786sec(train) 4.442sec(infer)\n",
      "Epoch 59 tst: l 0.926 a 0.705 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.814sec\n",
      "Epoch 60 tr: l 0.757 a 0.749 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.074026 11.607sec(train) 4.790sec(infer)\n",
      "Epoch 60 tst: l 0.903 a 0.708 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.915sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 61 tr: l 0.755 a 0.753 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.073656 12.076sec(train) 4.130sec(infer)\n",
      "Epoch 61 tst: l 0.919 a 0.706 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.930sec\n",
      "Epoch 62 tr: l 0.748 a 0.751 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.073288 13.777sec(train) 3.971sec(infer)\n",
      "Epoch 62 tst: l 0.896 a 0.710 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.830sec\n",
      "Epoch 63 tr: l 0.748 a 0.754 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.072921 13.104sec(train) 3.984sec(infer)\n",
      "Epoch 63 tst: l 0.913 a 0.708 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.691sec\n",
      "Epoch 64 tr: l 0.741 a 0.753 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.072557 12.743sec(train) 4.509sec(infer)\n",
      "Epoch 64 tst: l 0.890 a 0.712 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.781sec\n",
      "Epoch 65 tr: l 0.742 a 0.755 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.072194 12.669sec(train) 4.373sec(infer)\n",
      "Epoch 65 tst: l 0.908 a 0.710 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.792sec\n",
      "Epoch 66 tr: l 0.736 a 0.754 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.071833 12.608sec(train) 4.218sec(infer)\n",
      "Epoch 66 tst: l 0.886 a 0.713 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.813sec\n",
      "Epoch 67 tr: l 0.736 a 0.756 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.071474 12.422sec(train) 4.769sec(infer)\n",
      "Epoch 67 tst: l 0.903 a 0.711 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.937sec\n",
      "Epoch 68 tr: l 0.730 a 0.756 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.071116 13.311sec(train) 3.448sec(infer)\n",
      "Epoch 68 tst: l 0.882 a 0.714 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.798sec\n",
      "Epoch 69 tr: l 0.729 a 0.758 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.070761 13.482sec(train) 4.065sec(infer)\n",
      "Epoch 69 tst: l 0.896 a 0.713 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.784sec\n",
      "Epoch 70 tr: l 0.721 a 0.758 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.070407 12.568sec(train) 4.538sec(infer)\n",
      "Epoch 70 tst: l 0.876 a 0.716 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.813sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 71 tr: l 0.721 a 0.761 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.070055 12.549sec(train) 4.108sec(infer)\n",
      "Epoch 71 tst: l 0.890 a 0.715 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.860sec\n",
      "Epoch 72 tr: l 0.714 a 0.760 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.069705 12.424sec(train) 4.764sec(infer)\n",
      "Epoch 72 tst: l 0.869 a 0.718 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.928sec\n",
      "Epoch 73 tr: l 0.714 a 0.762 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.069356 12.781sec(train) 3.846sec(infer)\n",
      "Epoch 73 tst: l 0.886 a 0.715 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.871sec\n",
      "Epoch 74 tr: l 0.708 a 0.761 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.069009 13.630sec(train) 3.787sec(infer)\n",
      "Epoch 74 tst: l 0.862 a 0.719 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.711sec\n",
      "Epoch 75 tr: l 0.710 a 0.763 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.068664 13.075sec(train) 4.603sec(infer)\n",
      "Epoch 75 tst: l 0.885 a 0.715 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.701sec\n",
      "Epoch 76 tr: l 0.704 a 0.762 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.068321 12.057sec(train) 4.584sec(infer)\n",
      "Epoch 76 tst: l 0.855 a 0.721 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.932sec\n",
      "Epoch 77 tr: l 0.707 a 0.763 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.067979 12.443sec(train) 4.241sec(infer)\n",
      "Epoch 77 tst: l 0.885 a 0.714 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.817sec\n",
      "Epoch 78 tr: l 0.701 a 0.763 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.067639 13.163sec(train) 4.100sec(infer)\n",
      "Epoch 78 tst: l 0.847 a 0.722 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.803sec\n",
      "Epoch 79 tr: l 0.704 a 0.763 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.067301 12.952sec(train) 4.041sec(infer)\n",
      "Epoch 79 tst: l 0.884 a 0.714 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.935sec\n",
      "Epoch 80 tr: l 0.697 a 0.764 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.066965 12.814sec(train) 4.054sec(infer)\n",
      "Epoch 80 tst: l 0.842 a 0.723 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.772sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 81 tr: l 0.700 a 0.764 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.066630 13.514sec(train) 3.914sec(infer)\n",
      "Epoch 81 tst: l 0.880 a 0.715 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.717sec\n",
      "Epoch 82 tr: l 0.692 a 0.766 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.066297 12.392sec(train) 4.763sec(infer)\n",
      "Epoch 82 tst: l 0.837 a 0.723 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.921sec\n",
      "Epoch 83 tr: l 0.695 a 0.766 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.065965 11.650sec(train) 4.756sec(infer)\n",
      "Epoch 83 tst: l 0.876 a 0.717 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.923sec\n",
      "Epoch 84 tr: l 0.687 a 0.768 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.065635 13.663sec(train) 3.584sec(infer)\n",
      "Epoch 84 tst: l 0.833 a 0.725 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.827sec\n",
      "Epoch 85 tr: l 0.690 a 0.767 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.065307 13.886sec(train) 3.856sec(infer)\n",
      "Epoch 85 tst: l 0.870 a 0.718 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.653sec\n",
      "Epoch 86 tr: l 0.682 a 0.769 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.064981 12.294sec(train) 4.778sec(infer)\n",
      "Epoch 86 tst: l 0.830 a 0.726 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.855sec\n",
      "Epoch 87 tr: l 0.684 a 0.769 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.064656 12.256sec(train) 4.501sec(infer)\n",
      "Epoch 87 tst: l 0.865 a 0.720 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.923sec\n",
      "Epoch 88 tr: l 0.676 a 0.771 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.064333 13.170sec(train) 3.854sec(infer)\n",
      "Epoch 88 tst: l 0.825 a 0.727 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.669sec\n",
      "Epoch 89 tr: l 0.679 a 0.771 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.064011 12.658sec(train) 4.688sec(infer)\n",
      "Epoch 89 tst: l 0.860 a 0.722 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.935sec\n",
      "Epoch 90 tr: l 0.671 a 0.772 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.063691 12.195sec(train) 4.071sec(infer)\n",
      "Epoch 90 tst: l 0.821 a 0.728 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.908sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 91 tr: l 0.673 a 0.773 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.063372 13.986sec(train) 3.089sec(infer)\n",
      "Epoch 91 tst: l 0.856 a 0.724 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.663sec\n",
      "Epoch 92 tr: l 0.666 a 0.774 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.063056 13.563sec(train) 4.737sec(infer)\n",
      "Epoch 92 tst: l 0.817 a 0.729 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.874sec\n",
      "Epoch 93 tr: l 0.669 a 0.774 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.062740 11.227sec(train) 4.753sec(infer)\n",
      "Epoch 93 tst: l 0.852 a 0.726 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.942sec\n",
      "Epoch 94 tr: l 0.662 a 0.775 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.062427 12.473sec(train) 4.307sec(infer)\n",
      "Epoch 94 tst: l 0.812 a 0.730 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.929sec\n",
      "Epoch 95 tr: l 0.664 a 0.775 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.062114 13.820sec(train) 3.601sec(infer)\n",
      "Epoch 95 tst: l 0.848 a 0.727 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.647sec\n",
      "Epoch 96 tr: l 0.657 a 0.777 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.061804 13.045sec(train) 4.205sec(infer)\n",
      "Epoch 96 tst: l 0.809 a 0.731 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.782sec\n",
      "Epoch 97 tr: l 0.660 a 0.777 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.061495 12.300sec(train) 4.627sec(infer)\n",
      "Epoch 97 tst: l 0.845 a 0.727 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.939sec\n",
      "Epoch 98 tr: l 0.653 a 0.778 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.061187 13.011sec(train) 3.897sec(infer)\n",
      "Epoch 98 tst: l 0.805 a 0.732 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.803sec\n",
      "Epoch 99 tr: l 0.657 a 0.778 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.060881 12.667sec(train) 4.602sec(infer)\n",
      "Epoch 99 tst: l 0.842 a 0.728 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.801sec\n",
      "Epoch 100 tr: l 0.683 a 0.773 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.006058 12.376sec(train) 3.940sec(infer)\n",
      "Epoch 100 tst: l 0.814 a 0.735 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.773sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 101 tr: l 0.682 a 0.775 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.006027 12.952sec(train) 4.062sec(infer)\n",
      "Epoch 101 tst: l 0.803 a 0.741 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.756sec\n",
      "Epoch 102 tr: l 0.680 a 0.776 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005997 12.923sec(train) 4.115sec(infer)\n",
      "Epoch 102 tst: l 0.797 a 0.744 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.844sec\n",
      "Epoch 103 tr: l 0.679 a 0.776 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005967 12.023sec(train) 4.754sec(infer)\n",
      "Epoch 103 tst: l 0.795 a 0.746 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.926sec\n",
      "Epoch 104 tr: l 0.679 a 0.777 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005937 12.688sec(train) 4.111sec(infer)\n",
      "Epoch 104 tst: l 0.794 a 0.746 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.910sec\n",
      "Epoch 105 tr: l 0.678 a 0.777 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005908 13.328sec(train) 3.862sec(infer)\n",
      "Epoch 105 tst: l 0.794 a 0.746 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.741sec\n",
      "Epoch 106 tr: l 0.677 a 0.777 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005878 13.035sec(train) 4.150sec(infer)\n",
      "Epoch 106 tst: l 0.793 a 0.747 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.665sec\n",
      "Epoch 107 tr: l 0.677 a 0.777 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005849 12.557sec(train) 4.546sec(infer)\n",
      "Epoch 107 tst: l 0.793 a 0.747 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.907sec\n",
      "Epoch 108 tr: l 0.677 a 0.778 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005820 12.252sec(train) 4.451sec(infer)\n",
      "Epoch 108 tst: l 0.793 a 0.747 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.785sec\n",
      "Epoch 109 tr: l 0.676 a 0.778 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005790 12.674sec(train) 4.286sec(infer)\n",
      "Epoch 109 tst: l 0.793 a 0.747 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.937sec\n",
      "Epoch 110 tr: l 0.676 a 0.778 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005762 13.143sec(train) 4.007sec(infer)\n",
      "Epoch 110 tst: l 0.793 a 0.747 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.792sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 111 tr: l 0.675 a 0.778 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005733 13.547sec(train) 3.703sec(infer)\n",
      "Epoch 111 tst: l 0.793 a 0.747 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.653sec\n",
      "Epoch 112 tr: l 0.675 a 0.778 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005704 12.782sec(train) 4.785sec(infer)\n",
      "Epoch 112 tst: l 0.792 a 0.747 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.938sec\n",
      "Epoch 113 tr: l 0.675 a 0.778 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005676 12.058sec(train) 4.153sec(infer)\n",
      "Epoch 113 tst: l 0.792 a 0.747 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.833sec\n",
      "Epoch 114 tr: l 0.675 a 0.779 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005647 13.112sec(train) 4.084sec(infer)\n",
      "Epoch 114 tst: l 0.792 a 0.747 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.842sec\n",
      "Epoch 115 tr: l 0.674 a 0.779 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005619 13.055sec(train) 4.385sec(infer)\n",
      "Epoch 115 tst: l 0.792 a 0.747 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.935sec\n",
      "Epoch 116 tr: l 0.674 a 0.779 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005591 12.544sec(train) 3.957sec(infer)\n",
      "Epoch 116 tst: l 0.792 a 0.747 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.769sec\n",
      "Epoch 117 tr: l 0.674 a 0.779 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005563 13.549sec(train) 3.936sec(infer)\n",
      "Epoch 117 tst: l 0.792 a 0.748 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.732sec\n",
      "Epoch 118 tr: l 0.673 a 0.779 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005535 12.793sec(train) 4.618sec(infer)\n",
      "Epoch 118 tst: l 0.792 a 0.748 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.794sec\n",
      "Epoch 119 tr: l 0.673 a 0.779 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005507 11.394sec(train) 4.672sec(infer)\n",
      "Epoch 119 tst: l 0.792 a 0.747 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.924sec\n",
      "Epoch 120 tr: l 0.673 a 0.779 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005480 13.066sec(train) 4.159sec(infer)\n",
      "Epoch 120 tst: l 0.792 a 0.748 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.932sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 121 tr: l 0.673 a 0.779 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005452 14.125sec(train) 3.306sec(infer)\n",
      "Epoch 121 tst: l 0.792 a 0.748 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.671sec\n",
      "Epoch 122 tr: l 0.672 a 0.779 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005425 12.961sec(train) 4.522sec(infer)\n",
      "Epoch 122 tst: l 0.791 a 0.748 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.805sec\n",
      "Epoch 123 tr: l 0.672 a 0.779 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005398 11.863sec(train) 4.656sec(infer)\n",
      "Epoch 123 tst: l 0.791 a 0.748 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.948sec\n",
      "Epoch 124 tr: l 0.672 a 0.779 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005371 13.131sec(train) 3.518sec(infer)\n",
      "Epoch 124 tst: l 0.791 a 0.748 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.693sec\n",
      "Epoch 125 tr: l 0.672 a 0.780 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005344 12.925sec(train) 4.766sec(infer)\n",
      "Epoch 125 tst: l 0.791 a 0.748 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.939sec\n",
      "Epoch 126 tr: l 0.672 a 0.780 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005318 12.091sec(train) 4.252sec(infer)\n",
      "Epoch 126 tst: l 0.791 a 0.748 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.933sec\n",
      "Epoch 127 tr: l 0.671 a 0.780 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005291 13.593sec(train) 3.411sec(infer)\n",
      "Epoch 127 tst: l 0.791 a 0.748 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.799sec\n",
      "Epoch 128 tr: l 0.671 a 0.780 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005264 13.841sec(train) 4.428sec(infer)\n",
      "Epoch 128 tst: l 0.791 a 0.748 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.633sec\n",
      "Epoch 129 tr: l 0.671 a 0.780 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005238 11.678sec(train) 4.752sec(infer)\n",
      "Epoch 129 tst: l 0.791 a 0.748 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.931sec\n",
      "Epoch 130 tr: l 0.671 a 0.780 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005212 11.791sec(train) 4.585sec(infer)\n",
      "Epoch 130 tst: l 0.791 a 0.748 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.946sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 131 tr: l 0.671 a 0.780 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005186 13.854sec(train) 3.492sec(infer)\n",
      "Epoch 131 tst: l 0.791 a 0.748 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.709sec\n",
      "Epoch 132 tr: l 0.670 a 0.780 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005160 13.553sec(train) 3.991sec(infer)\n",
      "Epoch 132 tst: l 0.791 a 0.748 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.842sec\n",
      "Epoch 133 tr: l 0.670 a 0.780 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005134 12.189sec(train) 4.670sec(infer)\n",
      "Epoch 133 tst: l 0.790 a 0.748 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.796sec\n",
      "Epoch 134 tr: l 0.670 a 0.780 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005108 12.921sec(train) 3.919sec(infer)\n",
      "Epoch 134 tst: l 0.790 a 0.748 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.814sec\n",
      "Epoch 135 tr: l 0.670 a 0.780 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005083 13.019sec(train) 4.344sec(infer)\n",
      "Epoch 135 tst: l 0.790 a 0.748 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.817sec\n",
      "Epoch 136 tr: l 0.670 a 0.780 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005058 12.060sec(train) 4.761sec(infer)\n",
      "Epoch 136 tst: l 0.790 a 0.748 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.924sec\n",
      "Epoch 137 tr: l 0.669 a 0.780 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005032 13.121sec(train) 3.570sec(infer)\n",
      "Epoch 137 tst: l 0.790 a 0.748 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.947sec\n",
      "Epoch 138 tr: l 0.669 a 0.780 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005007 13.913sec(train) 3.934sec(infer)\n",
      "Epoch 138 tst: l 0.790 a 0.748 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.684sec\n",
      "Epoch 139 tr: l 0.669 a 0.780 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.004982 12.628sec(train) 4.608sec(infer)\n",
      "Epoch 139 tst: l 0.790 a 0.748 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.827sec\n",
      "Epoch 140 tr: l 0.669 a 0.781 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.004957 12.023sec(train) 4.438sec(infer)\n",
      "Epoch 140 tst: l 0.790 a 0.748 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.940sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 141 tr: l 0.669 a 0.781 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.004932 12.490sec(train) 4.490sec(infer)\n",
      "Epoch 141 tst: l 0.790 a 0.748 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.800sec\n",
      "Epoch 142 tr: l 0.669 a 0.781 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.004908 13.231sec(train) 3.882sec(infer)\n",
      "Epoch 142 tst: l 0.790 a 0.748 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.832sec\n",
      "Epoch 143 tr: l 0.668 a 0.781 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.004883 13.158sec(train) 4.099sec(infer)\n",
      "Epoch 143 tst: l 0.790 a 0.748 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.750sec\n",
      "Epoch 144 tr: l 0.668 a 0.781 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.004859 13.012sec(train) 4.141sec(infer)\n",
      "Epoch 144 tst: l 0.789 a 0.748 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.689sec\n",
      "Epoch 145 tr: l 0.668 a 0.781 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.004834 12.530sec(train) 4.443sec(infer)\n",
      "Epoch 145 tst: l 0.789 a 0.748 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.927sec\n",
      "Epoch 146 tr: l 0.668 a 0.781 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.004810 12.088sec(train) 4.411sec(infer)\n",
      "Epoch 146 tst: l 0.789 a 0.748 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.806sec\n",
      "Epoch 147 tr: l 0.668 a 0.781 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.004786 13.216sec(train) 4.033sec(infer)\n",
      "Epoch 147 tst: l 0.789 a 0.748 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.828sec\n",
      "Epoch 148 tr: l 0.668 a 0.781 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.004762 13.143sec(train) 4.037sec(infer)\n",
      "Epoch 148 tst: l 0.789 a 0.748 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.926sec\n",
      "Epoch 149 tr: l 0.667 a 0.781 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.004738 12.772sec(train) 4.071sec(infer)\n",
      "Epoch 149 tst: l 0.789 a 0.748 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.789sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "---train cluster Ended in 0.75 hour (2685.226 sec) \n",
      "---------------------------------DFedAvgM, lr: 0.1, seed: 6753---------------------------------\n",
      "config: {'m': 100, 'm_test': 20, 'p': 2, 'n': 1500, 'uneven': True, 'local_model_init': False, 'Gp': 0.15, 'graph': 'er', 'agg': 'seq', 'h1': 512, 'num_epochs': 150, 'batch_size': 100, 'tau': 3, 'lr': 0.1, 'data_seed': 6753, 'train_seed': 6753, 'config_override': '', 'project_dir': 'output_dfca_gi'}\n",
      "Using device: cuda:3\n",
      "Epoch -1 tr: l 3.874 a 0.025 clct[np.int64(100), np.int64(0)] cl_acc 0.500  4.437sec\n",
      "Epoch -1 tst: l 3.875 a 0.024 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.970sec\n",
      "Epoch 0 tr: l 3.522 a 0.201 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.100000 12.761sec(train) 3.605sec(infer)\n",
      "Epoch 0 tst: l 3.598 a 0.172 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.796sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 1 tr: l 3.179 a 0.298 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.099500 13.605sec(train) 4.067sec(infer)\n",
      "Epoch 1 tst: l 3.285 a 0.260 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.781sec\n",
      "Epoch 2 tr: l 2.827 a 0.366 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.099003 12.214sec(train) 4.760sec(infer)\n",
      "Epoch 2 tst: l 2.957 a 0.324 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.941sec\n",
      "Epoch 3 tr: l 2.521 a 0.422 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.098507 11.335sec(train) 4.685sec(infer)\n",
      "Epoch 3 tst: l 2.670 a 0.381 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.985sec\n",
      "Epoch 4 tr: l 2.276 a 0.464 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.098015 13.120sec(train) 3.803sec(infer)\n",
      "Epoch 4 tst: l 2.436 a 0.424 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.842sec\n",
      "Epoch 5 tr: l 2.081 a 0.497 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.097525 13.589sec(train) 3.732sec(infer)\n",
      "Epoch 5 tst: l 2.250 a 0.458 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.765sec\n",
      "Epoch 6 tr: l 1.927 a 0.522 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.097037 12.204sec(train) 4.684sec(infer)\n",
      "Epoch 6 tst: l 2.100 a 0.483 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.815sec\n",
      "Epoch 7 tr: l 1.830 a 0.526 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.096552 12.323sec(train) 4.281sec(infer)\n",
      "Epoch 7 tst: l 2.011 a 0.486 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.982sec\n",
      "Epoch 8 tr: l 1.769 a 0.524 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.096069 12.970sec(train) 4.153sec(infer)\n",
      "Epoch 8 tst: l 1.939 a 0.486 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.707sec\n",
      "Epoch 9 tr: l 1.705 a 0.522 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.095589 12.283sec(train) 4.775sec(infer)\n",
      "Epoch 9 tst: l 1.884 a 0.487 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.968sec\n",
      "Epoch 10 tr: l 1.609 a 0.558 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.095111 12.007sec(train) 4.139sec(infer)\n",
      "Epoch 10 tst: l 1.776 a 0.520 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.974sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 11 tr: l 1.547 a 0.563 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.094635 13.853sec(train) 3.153sec(infer)\n",
      "Epoch 11 tst: l 1.722 a 0.528 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.583sec\n",
      "Epoch 12 tr: l 1.479 a 0.587 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.094162 13.402sec(train) 4.790sec(infer)\n",
      "Epoch 12 tst: l 1.647 a 0.550 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.971sec\n",
      "Epoch 13 tr: l 1.429 a 0.594 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.093691 10.948sec(train) 4.766sec(infer)\n",
      "Epoch 13 tst: l 1.598 a 0.560 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.972sec\n",
      "Epoch 14 tr: l 1.371 a 0.614 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.093223 12.853sec(train) 3.770sec(infer)\n",
      "Epoch 14 tst: l 1.540 a 0.574 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.981sec\n",
      "Epoch 15 tr: l 1.336 a 0.618 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.092757 13.650sec(train) 4.065sec(infer)\n",
      "Epoch 15 tst: l 1.505 a 0.585 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.744sec\n",
      "Epoch 16 tr: l 1.286 a 0.633 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.092293 12.231sec(train) 4.364sec(infer)\n",
      "Epoch 16 tst: l 1.457 a 0.593 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.823sec\n",
      "Epoch 17 tr: l 1.258 a 0.638 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.091832 12.316sec(train) 4.404sec(infer)\n",
      "Epoch 17 tst: l 1.428 a 0.603 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.956sec\n",
      "Epoch 18 tr: l 1.221 a 0.646 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.091372 12.946sec(train) 3.966sec(infer)\n",
      "Epoch 18 tst: l 1.394 a 0.607 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.717sec\n",
      "Epoch 19 tr: l 1.200 a 0.650 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.090916 12.237sec(train) 4.800sec(infer)\n",
      "Epoch 19 tst: l 1.371 a 0.615 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.959sec\n",
      "Epoch 20 tr: l 1.171 a 0.655 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.090461 12.069sec(train) 4.382sec(infer)\n",
      "Epoch 20 tst: l 1.350 a 0.615 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.979sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 21 tr: l 1.148 a 0.661 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.090009 13.401sec(train) 3.371sec(infer)\n",
      "Epoch 21 tst: l 1.323 a 0.624 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.656sec\n",
      "Epoch 22 tr: l 1.136 a 0.659 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.089559 13.215sec(train) 4.402sec(infer)\n",
      "Epoch 22 tst: l 1.314 a 0.619 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.781sec\n",
      "Epoch 23 tr: l 1.118 a 0.664 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.089111 11.617sec(train) 4.720sec(infer)\n",
      "Epoch 23 tst: l 1.296 a 0.629 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.979sec\n",
      "Epoch 24 tr: l 1.094 a 0.670 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.088665 11.995sec(train) 4.140sec(infer)\n",
      "Epoch 24 tst: l 1.274 a 0.630 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.825sec\n",
      "Epoch 25 tr: l 1.074 a 0.676 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.088222 13.249sec(train) 3.899sec(infer)\n",
      "Epoch 25 tst: l 1.256 a 0.641 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.853sec\n",
      "Epoch 26 tr: l 1.054 a 0.682 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.087781 12.768sec(train) 4.111sec(infer)\n",
      "Epoch 26 tst: l 1.236 a 0.641 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.776sec\n",
      "Epoch 27 tr: l 1.039 a 0.683 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.087342 12.057sec(train) 2.733sec(infer)\n",
      "Epoch 27 tst: l 1.223 a 0.648 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.529sec\n",
      "Epoch 28 tr: l 1.019 a 0.691 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.086905 10.542sec(train) 3.962sec(infer)\n",
      "Epoch 28 tst: l 1.205 a 0.648 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.782sec\n",
      "Epoch 29 tr: l 1.008 a 0.691 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.086471 11.532sec(train) 4.781sec(infer)\n",
      "Epoch 29 tst: l 1.196 a 0.657 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.973sec\n",
      "Epoch 30 tr: l 1.000 a 0.695 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.086038 12.075sec(train) 4.411sec(infer)\n",
      "Epoch 30 tst: l 1.191 a 0.653 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.982sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 31 tr: l 1.000 a 0.692 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.085608 13.640sec(train) 3.587sec(infer)\n",
      "Epoch 31 tst: l 1.194 a 0.655 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.832sec\n",
      "Epoch 32 tr: l 0.988 a 0.696 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.085180 13.151sec(train) 4.164sec(infer)\n",
      "Epoch 32 tst: l 1.179 a 0.656 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.682sec\n",
      "Epoch 33 tr: l 0.956 a 0.707 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.084754 12.098sec(train) 4.711sec(infer)\n",
      "Epoch 33 tst: l 1.155 a 0.665 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.963sec\n",
      "Epoch 34 tr: l 0.950 a 0.707 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.084331 12.278sec(train) 4.223sec(infer)\n",
      "Epoch 34 tst: l 1.137 a 0.668 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.816sec\n",
      "Epoch 35 tr: l 0.936 a 0.712 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.083909 12.516sec(train) 4.243sec(infer)\n",
      "Epoch 35 tst: l 1.141 a 0.666 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.822sec\n",
      "Epoch 36 tr: l 0.930 a 0.711 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.083489 12.379sec(train) 4.427sec(infer)\n",
      "Epoch 36 tst: l 1.126 a 0.671 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.966sec\n",
      "Epoch 37 tr: l 0.912 a 0.719 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.083072 12.742sec(train) 3.532sec(infer)\n",
      "Epoch 37 tst: l 1.122 a 0.672 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.699sec\n",
      "Epoch 38 tr: l 0.907 a 0.716 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.082657 13.282sec(train) 4.269sec(infer)\n",
      "Epoch 38 tst: l 1.105 a 0.675 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.953sec\n",
      "Epoch 39 tr: l 0.897 a 0.722 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.082243 11.915sec(train) 4.696sec(infer)\n",
      "Epoch 39 tst: l 1.112 a 0.673 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.845sec\n",
      "Epoch 40 tr: l 0.890 a 0.721 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.081832 12.360sec(train) 4.126sec(infer)\n",
      "Epoch 40 tst: l 1.092 a 0.679 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.943sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 41 tr: l 0.877 a 0.728 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.081423 12.836sec(train) 4.533sec(infer)\n",
      "Epoch 41 tst: l 1.094 a 0.679 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.902sec\n",
      "Epoch 42 tr: l 0.872 a 0.725 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.081016 12.799sec(train) 3.435sec(infer)\n",
      "Epoch 42 tst: l 1.075 a 0.683 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.700sec\n",
      "Epoch 43 tr: l 0.865 a 0.730 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.080611 13.269sec(train) 4.442sec(infer)\n",
      "Epoch 43 tst: l 1.085 a 0.681 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.798sec\n",
      "Epoch 44 tr: l 0.857 a 0.728 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.080208 12.197sec(train) 4.577sec(infer)\n",
      "Epoch 44 tst: l 1.065 a 0.687 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.821sec\n",
      "Epoch 45 tr: l 0.846 a 0.736 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.079807 11.972sec(train) 4.380sec(infer)\n",
      "Epoch 45 tst: l 1.069 a 0.685 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.962sec\n",
      "Epoch 46 tr: l 0.843 a 0.732 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.079408 12.731sec(train) 4.482sec(infer)\n",
      "Epoch 46 tst: l 1.053 a 0.690 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.856sec\n",
      "Epoch 47 tr: l 0.838 a 0.736 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.079010 13.311sec(train) 3.488sec(infer)\n",
      "Epoch 47 tst: l 1.063 a 0.687 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.827sec\n",
      "Epoch 48 tr: l 0.831 a 0.735 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.078615 11.364sec(train) 4.564sec(infer)\n",
      "Epoch 48 tst: l 1.045 a 0.692 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.832sec\n",
      "Epoch 49 tr: l 0.821 a 0.741 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.078222 13.288sec(train) 3.375sec(infer)\n",
      "Epoch 49 tst: l 1.047 a 0.691 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.707sec\n",
      "Epoch 50 tr: l 0.819 a 0.738 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.077831 12.668sec(train) 4.765sec(infer)\n",
      "Epoch 50 tst: l 1.037 a 0.693 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.966sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 51 tr: l 0.815 a 0.741 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.077442 11.365sec(train) 4.759sec(infer)\n",
      "Epoch 51 tst: l 1.044 a 0.692 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.980sec\n",
      "Epoch 52 tr: l 0.812 a 0.740 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.077055 13.473sec(train) 3.505sec(infer)\n",
      "Epoch 52 tst: l 1.036 a 0.693 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.951sec\n",
      "Epoch 53 tr: l 0.805 a 0.744 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.076670 13.870sec(train) 3.956sec(infer)\n",
      "Epoch 53 tst: l 1.035 a 0.693 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.579sec\n",
      "Epoch 54 tr: l 0.802 a 0.742 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.076286 11.993sec(train) 4.758sec(infer)\n",
      "Epoch 54 tst: l 1.029 a 0.695 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.971sec\n",
      "Epoch 55 tr: l 0.796 a 0.746 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.075905 11.601sec(train) 4.264sec(infer)\n",
      "Epoch 55 tst: l 1.029 a 0.695 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.964sec\n",
      "Epoch 56 tr: l 0.791 a 0.745 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.075525 12.939sec(train) 4.060sec(infer)\n",
      "Epoch 56 tst: l 1.021 a 0.697 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.777sec\n",
      "Epoch 57 tr: l 0.783 a 0.750 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.075148 12.730sec(train) 4.342sec(infer)\n",
      "Epoch 57 tst: l 1.015 a 0.698 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.891sec\n",
      "Epoch 58 tr: l 0.781 a 0.748 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.074772 12.401sec(train) 4.026sec(infer)\n",
      "Epoch 58 tst: l 1.012 a 0.700 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.816sec\n",
      "Epoch 59 tr: l 0.774 a 0.751 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.074398 13.150sec(train) 4.322sec(infer)\n",
      "Epoch 59 tst: l 1.008 a 0.700 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.807sec\n",
      "Epoch 60 tr: l 0.772 a 0.750 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.074026 12.332sec(train) 4.390sec(infer)\n",
      "Epoch 60 tst: l 1.005 a 0.701 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.835sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 61 tr: l 0.765 a 0.755 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.073656 11.789sec(train) 4.735sec(infer)\n",
      "Epoch 61 tst: l 0.996 a 0.702 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.965sec\n",
      "Epoch 62 tr: l 0.763 a 0.753 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.073288 12.901sec(train) 3.791sec(infer)\n",
      "Epoch 62 tst: l 0.997 a 0.704 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.843sec\n",
      "Epoch 63 tr: l 0.756 a 0.757 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.072921 13.365sec(train) 3.578sec(infer)\n",
      "Epoch 63 tst: l 0.988 a 0.705 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.819sec\n",
      "Epoch 64 tr: l 0.755 a 0.755 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.072557 12.661sec(train) 4.750sec(infer)\n",
      "Epoch 64 tst: l 0.993 a 0.706 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.833sec\n",
      "Epoch 65 tr: l 0.749 a 0.758 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.072194 12.015sec(train) 4.057sec(infer)\n",
      "Epoch 65 tst: l 0.979 a 0.708 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.826sec\n",
      "Epoch 66 tr: l 0.749 a 0.756 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.071833 12.229sec(train) 4.641sec(infer)\n",
      "Epoch 66 tst: l 0.987 a 0.707 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.967sec\n",
      "Epoch 67 tr: l 0.743 a 0.760 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.071474 12.425sec(train) 4.005sec(infer)\n",
      "Epoch 67 tst: l 0.973 a 0.708 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.855sec\n",
      "Epoch 68 tr: l 0.743 a 0.758 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.071116 13.421sec(train) 3.380sec(infer)\n",
      "Epoch 68 tst: l 0.984 a 0.709 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.771sec\n",
      "Epoch 69 tr: l 0.737 a 0.761 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.070761 12.855sec(train) 4.752sec(infer)\n",
      "Epoch 69 tst: l 0.966 a 0.710 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.869sec\n",
      "Epoch 70 tr: l 0.737 a 0.759 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.070407 11.925sec(train) 4.189sec(infer)\n",
      "Epoch 70 tst: l 0.979 a 0.710 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.958sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 71 tr: l 0.730 a 0.763 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.070055 12.624sec(train) 4.255sec(infer)\n",
      "Epoch 71 tst: l 0.959 a 0.712 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.867sec\n",
      "Epoch 72 tr: l 0.731 a 0.761 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.069705 12.740sec(train) 4.589sec(infer)\n",
      "Epoch 72 tst: l 0.973 a 0.711 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.817sec\n",
      "Epoch 73 tr: l 0.724 a 0.765 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.069356 12.277sec(train) 3.963sec(infer)\n",
      "Epoch 73 tst: l 0.952 a 0.713 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.962sec\n",
      "Epoch 74 tr: l 0.724 a 0.762 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.069009 13.188sec(train) 3.853sec(infer)\n",
      "Epoch 74 tst: l 0.967 a 0.713 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.682sec\n",
      "Epoch 75 tr: l 0.718 a 0.767 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.068664 13.029sec(train) 4.405sec(infer)\n",
      "Epoch 75 tst: l 0.947 a 0.715 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.820sec\n",
      "Epoch 76 tr: l 0.718 a 0.764 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.068321 11.428sec(train) 4.759sec(infer)\n",
      "Epoch 76 tst: l 0.962 a 0.714 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.990sec\n",
      "Epoch 77 tr: l 0.712 a 0.768 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.067979 12.364sec(train) 4.242sec(infer)\n",
      "Epoch 77 tst: l 0.941 a 0.717 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.972sec\n",
      "Epoch 78 tr: l 0.712 a 0.766 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.067639 13.858sec(train) 3.365sec(infer)\n",
      "Epoch 78 tst: l 0.957 a 0.716 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.676sec\n",
      "Epoch 79 tr: l 0.706 a 0.770 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.067301 12.896sec(train) 4.502sec(infer)\n",
      "Epoch 79 tst: l 0.936 a 0.718 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.828sec\n",
      "Epoch 80 tr: l 0.706 a 0.767 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.066965 11.682sec(train) 4.708sec(infer)\n",
      "Epoch 80 tst: l 0.951 a 0.717 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.983sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 81 tr: l 0.700 a 0.771 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.066630 12.947sec(train) 3.474sec(infer)\n",
      "Epoch 81 tst: l 0.930 a 0.721 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.701sec\n",
      "Epoch 82 tr: l 0.701 a 0.769 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.066297 12.786sec(train) 4.779sec(infer)\n",
      "Epoch 82 tst: l 0.946 a 0.719 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.973sec\n",
      "Epoch 83 tr: l 0.694 a 0.773 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.065965 11.981sec(train) 4.236sec(infer)\n",
      "Epoch 83 tst: l 0.924 a 0.722 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.966sec\n",
      "Epoch 84 tr: l 0.696 a 0.771 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.065635 13.493sec(train) 3.348sec(infer)\n",
      "Epoch 84 tst: l 0.942 a 0.720 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.820sec\n",
      "Epoch 85 tr: l 0.690 a 0.774 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.065307 13.562sec(train) 4.640sec(infer)\n",
      "Epoch 85 tst: l 0.919 a 0.723 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.729sec\n",
      "Epoch 86 tr: l 0.692 a 0.771 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.064981 11.212sec(train) 4.761sec(infer)\n",
      "Epoch 86 tst: l 0.938 a 0.721 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.960sec\n",
      "Epoch 87 tr: l 0.686 a 0.774 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.064656 11.871sec(train) 4.454sec(infer)\n",
      "Epoch 87 tst: l 0.915 a 0.723 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.970sec\n",
      "Epoch 88 tr: l 0.688 a 0.771 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.064333 13.599sec(train) 3.558sec(infer)\n",
      "Epoch 88 tst: l 0.935 a 0.721 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.692sec\n",
      "Epoch 89 tr: l 0.682 a 0.774 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.064011 12.846sec(train) 4.248sec(infer)\n",
      "Epoch 89 tst: l 0.912 a 0.724 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.816sec\n",
      "Epoch 90 tr: l 0.685 a 0.772 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.063691 12.048sec(train) 4.634sec(infer)\n",
      "Epoch 90 tst: l 0.931 a 0.722 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.929sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 91 tr: l 0.677 a 0.776 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.063372 12.750sec(train) 3.889sec(infer)\n",
      "Epoch 91 tst: l 0.907 a 0.726 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.823sec\n",
      "Epoch 92 tr: l 0.680 a 0.774 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.063056 12.366sec(train) 4.695sec(infer)\n",
      "Epoch 92 tst: l 0.927 a 0.723 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.847sec\n",
      "Epoch 93 tr: l 0.672 a 0.778 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.062740 12.191sec(train) 4.566sec(infer)\n",
      "Epoch 93 tst: l 0.903 a 0.727 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.982sec\n",
      "Epoch 94 tr: l 0.675 a 0.775 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.062427 12.993sec(train) 3.410sec(infer)\n",
      "Epoch 94 tst: l 0.923 a 0.723 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.654sec\n",
      "Epoch 95 tr: l 0.667 a 0.779 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.062114 13.496sec(train) 4.122sec(infer)\n",
      "Epoch 95 tst: l 0.898 a 0.729 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.755sec\n",
      "Epoch 96 tr: l 0.670 a 0.777 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.061804 11.795sec(train) 4.781sec(infer)\n",
      "Epoch 96 tst: l 0.919 a 0.725 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.983sec\n",
      "Epoch 97 tr: l 0.663 a 0.781 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.061495 11.999sec(train) 4.036sec(infer)\n",
      "Epoch 97 tst: l 0.894 a 0.730 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.829sec\n",
      "Epoch 98 tr: l 0.666 a 0.778 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.061187 13.163sec(train) 4.176sec(infer)\n",
      "Epoch 98 tst: l 0.915 a 0.726 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.966sec\n",
      "Epoch 99 tr: l 0.659 a 0.782 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.060881 12.763sec(train) 3.863sec(infer)\n",
      "Epoch 99 tst: l 0.891 a 0.731 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.672sec\n",
      "Epoch 100 tr: l 0.684 a 0.775 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.006058 13.016sec(train) 4.077sec(infer)\n",
      "Epoch 100 tst: l 0.835 a 0.743 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.803sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 101 tr: l 0.684 a 0.776 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.006027 12.361sec(train) 4.733sec(infer)\n",
      "Epoch 101 tst: l 0.821 a 0.747 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.934sec\n",
      "Epoch 102 tr: l 0.683 a 0.777 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005997 11.909sec(train) 4.172sec(infer)\n",
      "Epoch 102 tst: l 0.820 a 0.749 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.837sec\n",
      "Epoch 103 tr: l 0.682 a 0.777 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005967 12.733sec(train) 4.405sec(infer)\n",
      "Epoch 103 tst: l 0.821 a 0.748 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.959sec\n",
      "Epoch 104 tr: l 0.681 a 0.777 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005937 13.164sec(train) 3.857sec(infer)\n",
      "Epoch 104 tst: l 0.821 a 0.748 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.832sec\n",
      "Epoch 105 tr: l 0.681 a 0.778 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005908 12.683sec(train) 4.222sec(infer)\n",
      "Epoch 105 tst: l 0.821 a 0.748 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.812sec\n",
      "Epoch 106 tr: l 0.680 a 0.778 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005878 12.634sec(train) 4.338sec(infer)\n",
      "Epoch 106 tst: l 0.821 a 0.748 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.833sec\n",
      "Epoch 107 tr: l 0.680 a 0.778 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005849 12.428sec(train) 4.359sec(infer)\n",
      "Epoch 107 tst: l 0.820 a 0.749 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.811sec\n",
      "Epoch 108 tr: l 0.679 a 0.779 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005820 11.782sec(train) 4.779sec(infer)\n",
      "Epoch 108 tst: l 0.820 a 0.749 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.985sec\n",
      "Epoch 109 tr: l 0.679 a 0.779 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005790 12.919sec(train) 3.650sec(infer)\n",
      "Epoch 109 tst: l 0.820 a 0.749 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.873sec\n",
      "Epoch 110 tr: l 0.678 a 0.779 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005762 13.867sec(train) 3.693sec(infer)\n",
      "Epoch 110 tst: l 0.819 a 0.749 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.611sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 111 tr: l 0.678 a 0.779 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005733 12.306sec(train) 4.757sec(infer)\n",
      "Epoch 111 tst: l 0.819 a 0.749 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.975sec\n",
      "Epoch 112 tr: l 0.678 a 0.779 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005704 11.388sec(train) 4.468sec(infer)\n",
      "Epoch 112 tst: l 0.819 a 0.749 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.978sec\n",
      "Epoch 113 tr: l 0.677 a 0.779 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005676 12.881sec(train) 3.706sec(infer)\n",
      "Epoch 113 tst: l 0.819 a 0.749 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.722sec\n",
      "Epoch 114 tr: l 0.677 a 0.780 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005647 13.261sec(train) 4.415sec(infer)\n",
      "Epoch 114 tst: l 0.819 a 0.749 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.965sec\n",
      "Epoch 115 tr: l 0.677 a 0.780 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005619 11.802sec(train) 4.230sec(infer)\n",
      "Epoch 115 tst: l 0.819 a 0.749 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.818sec\n",
      "Epoch 116 tr: l 0.676 a 0.780 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005591 13.394sec(train) 3.609sec(infer)\n",
      "Epoch 116 tst: l 0.819 a 0.749 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.783sec\n",
      "Epoch 117 tr: l 0.676 a 0.780 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005563 13.005sec(train) 4.711sec(infer)\n",
      "Epoch 117 tst: l 0.819 a 0.749 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.827sec\n",
      "Epoch 118 tr: l 0.676 a 0.780 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005535 11.006sec(train) 4.775sec(infer)\n",
      "Epoch 118 tst: l 0.819 a 0.749 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.973sec\n",
      "Epoch 119 tr: l 0.676 a 0.780 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005507 12.672sec(train) 4.549sec(infer)\n",
      "Epoch 119 tst: l 0.819 a 0.749 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.978sec\n",
      "Epoch 120 tr: l 0.675 a 0.780 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005480 13.795sec(train) 3.088sec(infer)\n",
      "Epoch 120 tst: l 0.819 a 0.749 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.684sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 121 tr: l 0.675 a 0.780 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005452 12.822sec(train) 4.637sec(infer)\n",
      "Epoch 121 tst: l 0.819 a 0.749 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.821sec\n",
      "Epoch 122 tr: l 0.675 a 0.780 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005425 11.504sec(train) 4.691sec(infer)\n",
      "Epoch 122 tst: l 0.818 a 0.749 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.971sec\n",
      "Epoch 123 tr: l 0.675 a 0.780 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005398 12.864sec(train) 3.610sec(infer)\n",
      "Epoch 123 tst: l 0.818 a 0.749 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.781sec\n",
      "Epoch 124 tr: l 0.674 a 0.781 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005371 12.707sec(train) 4.761sec(infer)\n",
      "Epoch 124 tst: l 0.818 a 0.749 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.923sec\n",
      "Epoch 125 tr: l 0.674 a 0.781 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005344 12.148sec(train) 4.167sec(infer)\n",
      "Epoch 125 tst: l 0.818 a 0.749 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.973sec\n",
      "Epoch 126 tr: l 0.674 a 0.781 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005318 13.313sec(train) 3.594sec(infer)\n",
      "Epoch 126 tst: l 0.818 a 0.749 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.675sec\n",
      "Epoch 127 tr: l 0.674 a 0.781 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005291 13.400sec(train) 4.236sec(infer)\n",
      "Epoch 127 tst: l 0.818 a 0.749 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.842sec\n",
      "Epoch 128 tr: l 0.673 a 0.781 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005264 11.495sec(train) 4.773sec(infer)\n",
      "Epoch 128 tst: l 0.818 a 0.749 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.967sec\n",
      "Epoch 129 tr: l 0.673 a 0.781 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005238 12.114sec(train) 4.040sec(infer)\n",
      "Epoch 129 tst: l 0.818 a 0.749 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.858sec\n",
      "Epoch 130 tr: l 0.673 a 0.781 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005212 13.597sec(train) 3.955sec(infer)\n",
      "Epoch 130 tst: l 0.818 a 0.749 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.960sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 131 tr: l 0.673 a 0.781 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005186 12.801sec(train) 4.167sec(infer)\n",
      "Epoch 131 tst: l 0.818 a 0.749 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.690sec\n",
      "Epoch 132 tr: l 0.672 a 0.781 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005160 12.650sec(train) 4.256sec(infer)\n",
      "Epoch 132 tst: l 0.818 a 0.749 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.959sec\n",
      "Epoch 133 tr: l 0.672 a 0.781 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005134 12.344sec(train) 4.653sec(infer)\n",
      "Epoch 133 tst: l 0.818 a 0.749 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.827sec\n",
      "Epoch 134 tr: l 0.672 a 0.781 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005108 12.032sec(train) 4.149sec(infer)\n",
      "Epoch 134 tst: l 0.818 a 0.749 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.856sec\n",
      "Epoch 135 tr: l 0.672 a 0.781 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005083 13.023sec(train) 3.709sec(infer)\n",
      "Epoch 135 tst: l 0.818 a 0.749 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.831sec\n",
      "Epoch 136 tr: l 0.671 a 0.781 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005058 12.507sec(train) 4.473sec(infer)\n",
      "Epoch 136 tst: l 0.817 a 0.749 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.812sec\n",
      "Epoch 137 tr: l 0.671 a 0.782 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005032 12.032sec(train) 4.291sec(infer)\n",
      "Epoch 137 tst: l 0.817 a 0.749 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.982sec\n",
      "Epoch 138 tr: l 0.671 a 0.782 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.005007 12.227sec(train) 4.650sec(infer)\n",
      "Epoch 138 tst: l 0.817 a 0.749 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.847sec\n",
      "Epoch 139 tr: l 0.671 a 0.782 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.004982 13.167sec(train) 3.653sec(infer)\n",
      "Epoch 139 tst: l 0.817 a 0.749 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.821sec\n",
      "Epoch 140 tr: l 0.671 a 0.782 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.004957 12.754sec(train) 4.371sec(infer)\n",
      "Epoch 140 tst: l 0.817 a 0.749 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.820sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 141 tr: l 0.670 a 0.782 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.004932 12.533sec(train) 4.185sec(infer)\n",
      "Epoch 141 tst: l 0.817 a 0.749 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.838sec\n",
      "Epoch 142 tr: l 0.670 a 0.782 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.004908 12.816sec(train) 4.083sec(infer)\n",
      "Epoch 142 tst: l 0.817 a 0.749 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.833sec\n",
      "Epoch 143 tr: l 0.670 a 0.782 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.004883 11.906sec(train) 4.765sec(infer)\n",
      "Epoch 143 tst: l 0.817 a 0.749 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.978sec\n",
      "Epoch 144 tr: l 0.670 a 0.782 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.004859 12.479sec(train) 3.904sec(infer)\n",
      "Epoch 144 tst: l 0.817 a 0.749 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.979sec\n",
      "Epoch 145 tr: l 0.670 a 0.782 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.004834 14.017sec(train) 3.297sec(infer)\n",
      "Epoch 145 tst: l 0.817 a 0.749 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.630sec\n",
      "Epoch 146 tr: l 0.669 a 0.782 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.004810 12.934sec(train) 4.796sec(infer)\n",
      "Epoch 146 tst: l 0.817 a 0.749 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.956sec\n",
      "Epoch 147 tr: l 0.669 a 0.782 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.004786 11.100sec(train) 4.679sec(infer)\n",
      "Epoch 147 tst: l 0.816 a 0.749 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.973sec\n",
      "Epoch 148 tr: l 0.669 a 0.782 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.004762 12.640sec(train) 3.624sec(infer)\n",
      "Epoch 148 tst: l 0.816 a 0.749 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.829sec\n",
      "Epoch 149 tr: l 0.669 a 0.782 clct[np.int64(100), np.int64(0)] cl_acc 0.500  lr 0.004738 13.350sec(train) 4.386sec(infer)\n",
      "Epoch 149 tst: l 0.816 a 0.749 clct[np.int64(20), np.int64(0)] cl_acc 0.500  0.819sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "---train cluster Ended in 0.74 hour (2653.891 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": "code",
   "execution_count": 10,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-19T06:26:17.155055Z",
     "iopub.status.busy": "2025-09-19T06:26:17.154375Z",
     "iopub.status.idle": "2025-09-19T06:26:17.164741Z",
     "shell.execute_reply": "2025-09-19T06:26:17.163782Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "---------------------------------IFCA, lr: 0.1, seed: 6003---------------------------------\n",
      "config: {'m': 100, 'm_test': 20, 'p': 2, 'n': 1500, 'uneven': True, 'local_model_init': False, 'Gp': 0.15, 'graph': 'er', 'agg': 'seq', 'h1': 512, 'num_epochs': 150, 'batch_size': 100, 'tau': 5, 'lr': 0.1, 'data_seed': 6003, 'train_seed': 6003, 'config_override': '', 'project_dir': 'output_dfca_gi'}\n",
      "Using device: cuda:3\n",
      "Epoch -1 tr: l 3.867 a 0.021 clct[np.int64(44), np.int64(56)] cl_acc 0.900  2.138sec\n",
      "Epoch -1 tst: l 3.868 a 0.021 clct[np.int64(7), np.int64(13)] cl_acc 0.850  0.430sec\n",
      "Epoch 0 tr: l 3.213 a 0.299 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.100000 15.552sec(train) 4.026sec(infer)\n",
      "Epoch 0 tst: l 3.220 a 0.294 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.773sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 1 tr: l 2.368 a 0.531 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.099500 16.507sec(train) 4.321sec(infer)\n",
      "Epoch 1 tst: l 2.385 a 0.525 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.890sec\n",
      "Epoch 2 tr: l 1.760 a 0.622 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.099003 16.411sec(train) 3.903sec(infer)\n",
      "Epoch 2 tst: l 1.783 a 0.613 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.715sec\n",
      "Epoch 3 tr: l 1.410 a 0.667 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.098507 17.132sec(train) 2.987sec(infer)\n",
      "Epoch 3 tst: l 1.439 a 0.660 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.670sec\n",
      "Epoch 4 tr: l 1.211 a 0.691 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.098015 17.568sec(train) 3.204sec(infer)\n",
      "Epoch 4 tst: l 1.244 a 0.686 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.772sec\n",
      "Epoch 5 tr: l 1.119 a 0.694 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.097525 17.566sec(train) 3.603sec(infer)\n",
      "Epoch 5 tst: l 1.157 a 0.686 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.736sec\n",
      "Epoch 6 tr: l 1.004 a 0.720 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.097037 17.409sec(train) 3.887sec(infer)\n",
      "Epoch 6 tst: l 1.045 a 0.714 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.733sec\n",
      "Epoch 7 tr: l 0.927 a 0.734 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.096552 16.610sec(train) 3.941sec(infer)\n",
      "Epoch 7 tst: l 0.967 a 0.728 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.740sec\n",
      "Epoch 8 tr: l 0.877 a 0.748 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.096069 16.422sec(train) 3.693sec(infer)\n",
      "Epoch 8 tst: l 0.927 a 0.740 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.790sec\n",
      "Epoch 9 tr: l 0.810 a 0.761 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.095589 16.452sec(train) 3.979sec(infer)\n",
      "Epoch 9 tst: l 0.856 a 0.753 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.905sec\n",
      "Epoch 10 tr: l 0.773 a 0.773 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.095111 16.463sec(train) 3.933sec(infer)\n",
      "Epoch 10 tst: l 0.827 a 0.764 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.912sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 11 tr: l 0.731 a 0.779 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.094635 17.613sec(train) 3.295sec(infer)\n",
      "Epoch 11 tst: l 0.782 a 0.769 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.655sec\n",
      "Epoch 12 tr: l 0.704 a 0.789 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.094162 18.348sec(train) 2.431sec(infer)\n",
      "Epoch 12 tst: l 0.762 a 0.779 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.524sec\n",
      "Epoch 13 tr: l 0.675 a 0.793 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.093691 17.721sec(train) 3.578sec(infer)\n",
      "Epoch 13 tst: l 0.730 a 0.783 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.648sec\n",
      "Epoch 14 tr: l 0.656 a 0.800 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.093223 16.857sec(train) 4.259sec(infer)\n",
      "Epoch 14 tst: l 0.717 a 0.790 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.880sec\n",
      "Epoch 15 tr: l 0.637 a 0.801 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.092757 16.129sec(train) 4.313sec(infer)\n",
      "Epoch 15 tst: l 0.696 a 0.790 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.890sec\n",
      "Epoch 16 tr: l 0.627 a 0.805 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.092293 16.292sec(train) 4.069sec(infer)\n",
      "Epoch 16 tst: l 0.689 a 0.794 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.725sec\n",
      "Epoch 17 tr: l 0.607 a 0.809 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.091832 16.507sec(train) 3.535sec(infer)\n",
      "Epoch 17 tst: l 0.671 a 0.797 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.801sec\n",
      "Epoch 18 tr: l 0.591 a 0.815 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.091372 17.367sec(train) 2.792sec(infer)\n",
      "Epoch 18 tst: l 0.657 a 0.802 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.789sec\n",
      "Epoch 19 tr: l 0.578 a 0.817 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.090916 18.151sec(train) 3.238sec(infer)\n",
      "Epoch 19 tst: l 0.644 a 0.804 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.657sec\n",
      "Epoch 20 tr: l 0.567 a 0.820 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.090461 17.567sec(train) 3.996sec(infer)\n",
      "Epoch 20 tst: l 0.637 a 0.807 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.774sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 21 tr: l 0.558 a 0.821 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.090009 16.414sec(train) 3.913sec(infer)\n",
      "Epoch 21 tst: l 0.625 a 0.808 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.733sec\n",
      "Epoch 22 tr: l 0.546 a 0.824 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.089559 16.291sec(train) 3.762sec(infer)\n",
      "Epoch 22 tst: l 0.619 a 0.812 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.790sec\n",
      "Epoch 23 tr: l 0.537 a 0.827 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.089111 16.455sec(train) 4.068sec(infer)\n",
      "Epoch 23 tst: l 0.607 a 0.813 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.919sec\n",
      "Epoch 24 tr: l 0.526 a 0.830 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.088665 16.728sec(train) 3.781sec(infer)\n",
      "Epoch 24 tst: l 0.601 a 0.817 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.899sec\n",
      "Epoch 25 tr: l 0.519 a 0.832 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.088222 17.636sec(train) 3.587sec(infer)\n",
      "Epoch 25 tst: l 0.592 a 0.818 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.590sec\n",
      "Epoch 26 tr: l 0.510 a 0.834 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.087781 17.578sec(train) 3.214sec(infer)\n",
      "Epoch 26 tst: l 0.587 a 0.820 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.641sec\n",
      "Epoch 27 tr: l 0.506 a 0.835 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.087342 17.463sec(train) 3.189sec(infer)\n",
      "Epoch 27 tst: l 0.581 a 0.821 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.774sec\n",
      "Epoch 28 tr: l 0.499 a 0.837 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.086905 17.252sec(train) 3.909sec(infer)\n",
      "Epoch 28 tst: l 0.577 a 0.822 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.793sec\n",
      "Epoch 29 tr: l 0.492 a 0.839 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.086471 16.730sec(train) 4.320sec(infer)\n",
      "Epoch 29 tst: l 0.570 a 0.825 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.825sec\n",
      "Epoch 30 tr: l 0.486 a 0.840 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.086038 16.682sec(train) 3.698sec(infer)\n",
      "Epoch 30 tst: l 0.566 a 0.824 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.751sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 31 tr: l 0.483 a 0.841 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.085608 17.363sec(train) 3.061sec(infer)\n",
      "Epoch 31 tst: l 0.564 a 0.827 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.642sec\n",
      "Epoch 32 tr: l 0.473 a 0.845 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.085180 17.595sec(train) 3.608sec(infer)\n",
      "Epoch 32 tst: l 0.556 a 0.828 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.763sec\n",
      "Epoch 33 tr: l 0.469 a 0.845 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.084754 16.669sec(train) 4.285sec(infer)\n",
      "Epoch 33 tst: l 0.552 a 0.830 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.899sec\n",
      "Epoch 34 tr: l 0.462 a 0.847 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.084331 16.497sec(train) 4.032sec(infer)\n",
      "Epoch 34 tst: l 0.546 a 0.831 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.852sec\n",
      "Epoch 35 tr: l 0.458 a 0.848 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.083909 17.058sec(train) 3.084sec(infer)\n",
      "Epoch 35 tst: l 0.543 a 0.832 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.668sec\n",
      "Epoch 36 tr: l 0.452 a 0.850 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.083489 17.321sec(train) 3.303sec(infer)\n",
      "Epoch 36 tst: l 0.538 a 0.833 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.713sec\n",
      "Epoch 37 tr: l 0.449 a 0.851 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.083072 17.730sec(train) 3.768sec(infer)\n",
      "Epoch 37 tst: l 0.535 a 0.834 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.773sec\n",
      "Epoch 38 tr: l 0.443 a 0.852 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.082657 17.628sec(train) 3.625sec(infer)\n",
      "Epoch 38 tst: l 0.531 a 0.834 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.746sec\n",
      "Epoch 39 tr: l 0.440 a 0.853 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.082243 16.995sec(train) 3.808sec(infer)\n",
      "Epoch 39 tst: l 0.528 a 0.835 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.576sec\n",
      "Epoch 40 tr: l 0.435 a 0.854 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.081832 16.567sec(train) 3.716sec(infer)\n",
      "Epoch 40 tst: l 0.525 a 0.835 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.769sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 41 tr: l 0.432 a 0.854 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.081423 16.452sec(train) 3.942sec(infer)\n",
      "Epoch 41 tst: l 0.522 a 0.836 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.885sec\n",
      "Epoch 42 tr: l 0.429 a 0.855 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.081016 16.389sec(train) 4.061sec(infer)\n",
      "Epoch 42 tst: l 0.521 a 0.837 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.896sec\n",
      "Epoch 43 tr: l 0.428 a 0.854 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.080611 17.268sec(train) 3.551sec(infer)\n",
      "Epoch 43 tst: l 0.520 a 0.836 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.797sec\n",
      "Epoch 44 tr: l 0.427 a 0.855 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.080208 18.123sec(train) 2.391sec(infer)\n",
      "Epoch 44 tst: l 0.520 a 0.837 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.565sec\n",
      "Epoch 45 tr: l 0.421 a 0.856 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.079807 18.003sec(train) 3.283sec(infer)\n",
      "Epoch 45 tst: l 0.514 a 0.839 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.545sec\n",
      "Epoch 46 tr: l 0.416 a 0.859 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.079408 17.053sec(train) 4.154sec(infer)\n",
      "Epoch 46 tst: l 0.510 a 0.840 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.900sec\n",
      "Epoch 47 tr: l 0.412 a 0.859 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.079010 16.207sec(train) 4.356sec(infer)\n",
      "Epoch 47 tst: l 0.506 a 0.841 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.902sec\n",
      "Epoch 48 tr: l 0.409 a 0.861 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.078615 16.542sec(train) 4.151sec(infer)\n",
      "Epoch 48 tst: l 0.506 a 0.841 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.714sec\n",
      "Epoch 49 tr: l 0.407 a 0.861 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.078222 16.636sec(train) 3.627sec(infer)\n",
      "Epoch 49 tst: l 0.502 a 0.843 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.801sec\n",
      "Epoch 50 tr: l 0.405 a 0.862 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.077831 17.224sec(train) 3.090sec(infer)\n",
      "Epoch 50 tst: l 0.504 a 0.841 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.876sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 51 tr: l 0.404 a 0.861 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.077442 18.226sec(train) 3.046sec(infer)\n",
      "Epoch 51 tst: l 0.501 a 0.842 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.660sec\n",
      "Epoch 52 tr: l 0.401 a 0.862 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.077055 18.121sec(train) 3.822sec(infer)\n",
      "Epoch 52 tst: l 0.501 a 0.842 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.622sec\n",
      "Epoch 53 tr: l 0.397 a 0.863 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.076670 16.924sec(train) 3.818sec(infer)\n",
      "Epoch 53 tst: l 0.496 a 0.843 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.667sec\n",
      "Epoch 54 tr: l 0.394 a 0.864 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.076286 16.579sec(train) 3.742sec(infer)\n",
      "Epoch 54 tst: l 0.495 a 0.844 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.781sec\n",
      "Epoch 55 tr: l 0.391 a 0.865 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.075905 16.512sec(train) 4.075sec(infer)\n",
      "Epoch 55 tst: l 0.491 a 0.844 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.898sec\n",
      "Epoch 56 tr: l 0.389 a 0.866 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.075525 16.558sec(train) 4.015sec(infer)\n",
      "Epoch 56 tst: l 0.492 a 0.846 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.888sec\n",
      "Epoch 57 tr: l 0.386 a 0.866 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.075148 17.436sec(train) 3.541sec(infer)\n",
      "Epoch 57 tst: l 0.488 a 0.845 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.599sec\n",
      "Epoch 58 tr: l 0.384 a 0.867 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.074772 17.670sec(train) 3.083sec(infer)\n",
      "Epoch 58 tst: l 0.488 a 0.847 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.656sec\n",
      "Epoch 59 tr: l 0.381 a 0.868 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.074398 17.687sec(train) 3.237sec(infer)\n",
      "Epoch 59 tst: l 0.484 a 0.847 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.895sec\n",
      "Epoch 60 tr: l 0.379 a 0.868 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.074026 17.493sec(train) 3.733sec(infer)\n",
      "Epoch 60 tst: l 0.485 a 0.848 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.772sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 61 tr: l 0.377 a 0.869 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.073656 17.068sec(train) 4.143sec(infer)\n",
      "Epoch 61 tst: l 0.481 a 0.848 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.777sec\n",
      "Epoch 62 tr: l 0.375 a 0.870 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.073288 16.665sec(train) 3.843sec(infer)\n",
      "Epoch 62 tst: l 0.482 a 0.849 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.784sec\n",
      "Epoch 63 tr: l 0.373 a 0.870 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.072921 17.096sec(train) 3.177sec(infer)\n",
      "Epoch 63 tst: l 0.479 a 0.848 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.781sec\n",
      "Epoch 64 tr: l 0.372 a 0.870 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.072557 17.606sec(train) 3.441sec(infer)\n",
      "Epoch 64 tst: l 0.480 a 0.849 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.774sec\n",
      "Epoch 65 tr: l 0.369 a 0.871 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.072194 17.119sec(train) 4.310sec(infer)\n",
      "Epoch 65 tst: l 0.477 a 0.849 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.806sec\n",
      "Epoch 66 tr: l 0.368 a 0.871 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.071833 16.379sec(train) 4.299sec(infer)\n",
      "Epoch 66 tst: l 0.477 a 0.850 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.729sec\n",
      "Epoch 67 tr: l 0.365 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.071474 16.910sec(train) 3.116sec(infer)\n",
      "Epoch 67 tst: l 0.474 a 0.850 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.796sec\n",
      "Epoch 68 tr: l 0.364 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.071116 17.305sec(train) 3.168sec(infer)\n",
      "Epoch 68 tst: l 0.475 a 0.850 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.767sec\n",
      "Epoch 69 tr: l 0.361 a 0.873 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.070761 17.476sec(train) 3.685sec(infer)\n",
      "Epoch 69 tst: l 0.472 a 0.850 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.791sec\n",
      "Epoch 70 tr: l 0.360 a 0.873 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.070407 17.997sec(train) 3.640sec(infer)\n",
      "Epoch 70 tst: l 0.472 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.710sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 71 tr: l 0.358 a 0.874 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.070055 17.526sec(train) 3.544sec(infer)\n",
      "Epoch 71 tst: l 0.469 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.598sec\n",
      "Epoch 72 tr: l 0.356 a 0.874 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.069705 17.011sec(train) 3.707sec(infer)\n",
      "Epoch 72 tst: l 0.470 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.798sec\n",
      "Epoch 73 tr: l 0.354 a 0.875 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.069356 16.618sec(train) 4.037sec(infer)\n",
      "Epoch 73 tst: l 0.467 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.909sec\n",
      "Epoch 74 tr: l 0.353 a 0.875 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.069009 16.286sec(train) 4.305sec(infer)\n",
      "Epoch 74 tst: l 0.467 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.914sec\n",
      "Epoch 75 tr: l 0.351 a 0.876 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.068664 16.955sec(train) 3.952sec(infer)\n",
      "Epoch 75 tst: l 0.465 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.709sec\n",
      "Epoch 76 tr: l 0.350 a 0.876 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.068321 17.789sec(train) 2.471sec(infer)\n",
      "Epoch 76 tst: l 0.466 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.684sec\n",
      "Epoch 77 tr: l 0.349 a 0.877 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.067979 18.401sec(train) 2.708sec(infer)\n",
      "Epoch 77 tst: l 0.464 a 0.853 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.583sec\n",
      "Epoch 78 tr: l 0.348 a 0.877 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.067639 17.789sec(train) 4.154sec(infer)\n",
      "Epoch 78 tst: l 0.465 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.715sec\n",
      "Epoch 79 tr: l 0.347 a 0.877 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.067301 16.557sec(train) 4.320sec(infer)\n",
      "Epoch 79 tst: l 0.464 a 0.853 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.889sec\n",
      "Epoch 80 tr: l 0.345 a 0.878 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.066965 16.298sec(train) 4.049sec(infer)\n",
      "Epoch 80 tst: l 0.463 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.748sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 81 tr: l 0.344 a 0.878 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.066630 16.746sec(train) 3.732sec(infer)\n",
      "Epoch 81 tst: l 0.462 a 0.853 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.801sec\n",
      "Epoch 82 tr: l 0.342 a 0.879 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.066297 16.516sec(train) 3.836sec(infer)\n",
      "Epoch 82 tst: l 0.461 a 0.853 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.910sec\n",
      "Epoch 83 tr: l 0.340 a 0.879 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.065965 17.465sec(train) 3.298sec(infer)\n",
      "Epoch 83 tst: l 0.460 a 0.854 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.794sec\n",
      "Epoch 84 tr: l 0.339 a 0.879 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.065635 18.194sec(train) 3.253sec(infer)\n",
      "Epoch 84 tst: l 0.459 a 0.854 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.463sec\n",
      "Epoch 85 tr: l 0.337 a 0.879 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.065307 17.627sec(train) 3.315sec(infer)\n",
      "Epoch 85 tst: l 0.458 a 0.854 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.682sec\n",
      "Epoch 86 tr: l 0.336 a 0.880 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064981 16.823sec(train) 3.785sec(infer)\n",
      "Epoch 86 tst: l 0.457 a 0.854 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.722sec\n",
      "Epoch 87 tr: l 0.335 a 0.880 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064656 16.435sec(train) 4.177sec(infer)\n",
      "Epoch 87 tst: l 0.456 a 0.855 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.886sec\n",
      "Epoch 88 tr: l 0.333 a 0.881 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064333 16.249sec(train) 4.305sec(infer)\n",
      "Epoch 88 tst: l 0.455 a 0.855 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.905sec\n",
      "Epoch 89 tr: l 0.332 a 0.881 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064011 16.886sec(train) 3.562sec(infer)\n",
      "Epoch 89 tst: l 0.455 a 0.855 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.722sec\n",
      "Epoch 90 tr: l 0.330 a 0.882 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.063691 17.607sec(train) 2.981sec(infer)\n",
      "Epoch 90 tst: l 0.454 a 0.855 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.647sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 91 tr: l 0.329 a 0.882 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.063372 17.556sec(train) 3.583sec(infer)\n",
      "Epoch 91 tst: l 0.453 a 0.855 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.821sec\n",
      "Epoch 92 tr: l 0.328 a 0.882 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.063056 17.376sec(train) 3.739sec(infer)\n",
      "Epoch 92 tst: l 0.453 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.786sec\n",
      "Epoch 93 tr: l 0.327 a 0.883 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.062740 17.253sec(train) 3.893sec(infer)\n",
      "Epoch 93 tst: l 0.452 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.776sec\n",
      "Epoch 94 tr: l 0.326 a 0.883 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.062427 16.846sec(train) 3.757sec(infer)\n",
      "Epoch 94 tst: l 0.452 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.673sec\n",
      "Epoch 95 tr: l 0.325 a 0.883 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.062114 17.052sec(train) 3.491sec(infer)\n",
      "Epoch 95 tst: l 0.451 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.814sec\n",
      "Epoch 96 tr: l 0.323 a 0.883 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.061804 17.467sec(train) 3.545sec(infer)\n",
      "Epoch 96 tst: l 0.451 a 0.857 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.764sec\n",
      "Epoch 97 tr: l 0.323 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.061495 17.483sec(train) 4.046sec(infer)\n",
      "Epoch 97 tst: l 0.450 a 0.857 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.757sec\n",
      "Epoch 98 tr: l 0.322 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.061187 16.758sec(train) 4.056sec(infer)\n",
      "Epoch 98 tst: l 0.450 a 0.857 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.733sec\n",
      "Epoch 99 tr: l 0.321 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.060881 16.795sec(train) 3.504sec(infer)\n",
      "Epoch 99 tst: l 0.449 a 0.857 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.792sec\n",
      "Epoch 100 tr: l 0.319 a 0.885 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.006058 17.067sec(train) 3.387sec(infer)\n",
      "Epoch 100 tst: l 0.448 a 0.857 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.925sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 101 tr: l 0.319 a 0.885 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.006027 17.464sec(train) 3.710sec(infer)\n",
      "Epoch 101 tst: l 0.448 a 0.857 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.797sec\n",
      "Epoch 102 tr: l 0.319 a 0.885 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005997 17.630sec(train) 3.523sec(infer)\n",
      "Epoch 102 tst: l 0.448 a 0.857 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.659sec\n",
      "Epoch 103 tr: l 0.319 a 0.885 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005967 17.904sec(train) 3.014sec(infer)\n",
      "Epoch 103 tst: l 0.448 a 0.857 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.644sec\n",
      "Epoch 104 tr: l 0.319 a 0.885 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005937 17.574sec(train) 3.776sec(infer)\n",
      "Epoch 104 tst: l 0.448 a 0.857 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.768sec\n",
      "Epoch 105 tr: l 0.318 a 0.885 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005908 16.588sec(train) 4.323sec(infer)\n",
      "Epoch 105 tst: l 0.447 a 0.857 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.910sec\n",
      "Epoch 106 tr: l 0.318 a 0.885 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005878 16.079sec(train) 4.322sec(infer)\n",
      "Epoch 106 tst: l 0.447 a 0.857 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.919sec\n",
      "Epoch 107 tr: l 0.318 a 0.885 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005849 16.572sec(train) 3.810sec(infer)\n",
      "Epoch 107 tst: l 0.447 a 0.857 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.784sec\n",
      "Epoch 108 tr: l 0.318 a 0.886 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005820 17.152sec(train) 3.044sec(infer)\n",
      "Epoch 108 tst: l 0.447 a 0.857 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.771sec\n",
      "Epoch 109 tr: l 0.318 a 0.886 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005790 18.408sec(train) 2.783sec(infer)\n",
      "Epoch 109 tst: l 0.447 a 0.858 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.646sec\n",
      "Epoch 110 tr: l 0.318 a 0.886 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005762 18.278sec(train) 3.714sec(infer)\n",
      "Epoch 110 tst: l 0.447 a 0.858 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.631sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 111 tr: l 0.318 a 0.886 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005733 16.981sec(train) 4.285sec(infer)\n",
      "Epoch 111 tst: l 0.447 a 0.858 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.758sec\n",
      "Epoch 112 tr: l 0.317 a 0.886 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005704 16.561sec(train) 3.676sec(infer)\n",
      "Epoch 112 tst: l 0.447 a 0.858 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.785sec\n",
      "Epoch 113 tr: l 0.317 a 0.886 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005676 16.442sec(train) 3.844sec(infer)\n",
      "Epoch 113 tst: l 0.447 a 0.858 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.878sec\n",
      "Epoch 114 tr: l 0.317 a 0.886 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005647 16.680sec(train) 4.301sec(infer)\n",
      "Epoch 114 tst: l 0.447 a 0.858 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.897sec\n",
      "Epoch 115 tr: l 0.317 a 0.886 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005619 16.956sec(train) 3.838sec(infer)\n",
      "Epoch 115 tst: l 0.447 a 0.858 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.885sec\n",
      "Epoch 116 tr: l 0.317 a 0.886 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005591 17.829sec(train) 2.756sec(infer)\n",
      "Epoch 116 tst: l 0.447 a 0.858 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.621sec\n",
      "Epoch 117 tr: l 0.317 a 0.886 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005563 18.112sec(train) 3.032sec(infer)\n",
      "Epoch 117 tst: l 0.447 a 0.858 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.509sec\n",
      "Epoch 118 tr: l 0.317 a 0.886 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005535 17.511sec(train) 3.614sec(infer)\n",
      "Epoch 118 tst: l 0.447 a 0.858 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.782sec\n",
      "Epoch 119 tr: l 0.317 a 0.886 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005507 16.908sec(train) 4.298sec(infer)\n",
      "Epoch 119 tst: l 0.447 a 0.858 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.822sec\n",
      "Epoch 120 tr: l 0.316 a 0.886 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005480 16.559sec(train) 4.341sec(infer)\n",
      "Epoch 120 tst: l 0.447 a 0.858 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.732sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 121 tr: l 0.316 a 0.886 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005452 16.868sec(train) 3.374sec(infer)\n",
      "Epoch 121 tst: l 0.447 a 0.858 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.785sec\n",
      "Epoch 122 tr: l 0.316 a 0.886 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005425 17.498sec(train) 3.023sec(infer)\n",
      "Epoch 122 tst: l 0.446 a 0.858 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.626sec\n",
      "Epoch 123 tr: l 0.316 a 0.886 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005398 17.688sec(train) 3.451sec(infer)\n",
      "Epoch 123 tst: l 0.446 a 0.858 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.664sec\n",
      "Epoch 124 tr: l 0.316 a 0.886 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005371 17.064sec(train) 3.952sec(infer)\n",
      "Epoch 124 tst: l 0.446 a 0.858 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.907sec\n",
      "Epoch 125 tr: l 0.316 a 0.886 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005344 17.007sec(train) 3.755sec(infer)\n",
      "Epoch 125 tst: l 0.446 a 0.858 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.875sec\n",
      "Epoch 126 tr: l 0.316 a 0.886 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005318 17.586sec(train) 3.521sec(infer)\n",
      "Epoch 126 tst: l 0.446 a 0.858 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.613sec\n",
      "Epoch 127 tr: l 0.316 a 0.886 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005291 17.391sec(train) 3.500sec(infer)\n",
      "Epoch 127 tst: l 0.446 a 0.858 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.683sec\n",
      "Epoch 128 tr: l 0.316 a 0.886 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005264 17.514sec(train) 3.427sec(infer)\n",
      "Epoch 128 tst: l 0.446 a 0.858 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.915sec\n",
      "Epoch 129 tr: l 0.315 a 0.886 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005238 17.547sec(train) 3.742sec(infer)\n",
      "Epoch 129 tst: l 0.446 a 0.858 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.740sec\n",
      "Epoch 130 tr: l 0.315 a 0.886 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005212 17.137sec(train) 4.266sec(infer)\n",
      "Epoch 130 tst: l 0.446 a 0.858 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.621sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 131 tr: l 0.315 a 0.887 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005186 16.535sec(train) 3.641sec(infer)\n",
      "Epoch 131 tst: l 0.446 a 0.858 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.796sec\n",
      "Epoch 132 tr: l 0.315 a 0.887 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005160 16.526sec(train) 3.821sec(infer)\n",
      "Epoch 132 tst: l 0.446 a 0.858 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.907sec\n",
      "Epoch 133 tr: l 0.315 a 0.887 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005134 16.870sec(train) 3.847sec(infer)\n",
      "Epoch 133 tst: l 0.446 a 0.858 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.910sec\n",
      "Epoch 134 tr: l 0.315 a 0.887 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005108 17.583sec(train) 3.369sec(infer)\n",
      "Epoch 134 tst: l 0.446 a 0.858 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.764sec\n",
      "Epoch 135 tr: l 0.315 a 0.887 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005083 18.249sec(train) 2.611sec(infer)\n",
      "Epoch 135 tst: l 0.446 a 0.858 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.567sec\n",
      "Epoch 136 tr: l 0.315 a 0.887 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005058 18.015sec(train) 3.487sec(infer)\n",
      "Epoch 136 tst: l 0.446 a 0.858 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.687sec\n",
      "Epoch 137 tr: l 0.315 a 0.887 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005032 16.832sec(train) 4.278sec(infer)\n",
      "Epoch 137 tst: l 0.446 a 0.858 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.897sec\n",
      "Epoch 138 tr: l 0.314 a 0.887 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005007 16.337sec(train) 4.306sec(infer)\n",
      "Epoch 138 tst: l 0.446 a 0.858 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.920sec\n",
      "Epoch 139 tr: l 0.314 a 0.887 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004982 16.565sec(train) 3.963sec(infer)\n",
      "Epoch 139 tst: l 0.446 a 0.858 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.765sec\n",
      "Epoch 140 tr: l 0.314 a 0.887 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004957 16.647sec(train) 3.638sec(infer)\n",
      "Epoch 140 tst: l 0.446 a 0.858 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.806sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 141 tr: l 0.314 a 0.887 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004932 17.545sec(train) 3.096sec(infer)\n",
      "Epoch 141 tst: l 0.446 a 0.858 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.904sec\n",
      "Epoch 142 tr: l 0.314 a 0.887 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004908 18.416sec(train) 3.174sec(infer)\n",
      "Epoch 142 tst: l 0.445 a 0.858 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.664sec\n",
      "Epoch 143 tr: l 0.314 a 0.887 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004883 17.801sec(train) 3.817sec(infer)\n",
      "Epoch 143 tst: l 0.445 a 0.858 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.562sec\n",
      "Epoch 144 tr: l 0.314 a 0.887 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004859 16.911sec(train) 3.649sec(infer)\n",
      "Epoch 144 tst: l 0.445 a 0.858 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.735sec\n",
      "Epoch 145 tr: l 0.314 a 0.887 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004834 16.621sec(train) 3.980sec(infer)\n",
      "Epoch 145 tst: l 0.445 a 0.858 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.881sec\n",
      "Epoch 146 tr: l 0.314 a 0.887 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004810 16.291sec(train) 4.309sec(infer)\n",
      "Epoch 146 tst: l 0.445 a 0.858 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.907sec\n",
      "Epoch 147 tr: l 0.314 a 0.887 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004786 17.038sec(train) 3.878sec(infer)\n",
      "Epoch 147 tst: l 0.445 a 0.858 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.774sec\n",
      "Epoch 148 tr: l 0.313 a 0.887 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004762 17.817sec(train) 2.879sec(infer)\n",
      "Epoch 148 tst: l 0.445 a 0.858 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.634sec\n",
      "Epoch 149 tr: l 0.313 a 0.887 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004738 17.675sec(train) 3.401sec(infer)\n",
      "Epoch 149 tst: l 0.445 a 0.858 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.762sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "---train cluster Ended in 0.90 hour (3238.070 sec) \n",
      "---------------------------------IFCA, lr: 0.1, seed: 7293---------------------------------\n",
      "config: {'m': 100, 'm_test': 20, 'p': 2, 'n': 1500, 'uneven': True, 'local_model_init': False, 'Gp': 0.15, 'graph': 'er', 'agg': 'seq', 'h1': 512, 'num_epochs': 150, 'batch_size': 100, 'tau': 5, 'lr': 0.1, 'data_seed': 7293, 'train_seed': 7293, 'config_override': '', 'project_dir': 'output_dfca_gi'}\n",
      "Using device: cuda:3\n",
      "Epoch -1 tr: l 3.876 a 0.024 clct[np.int64(77), np.int64(23)] cl_acc 0.590  3.628sec\n",
      "Epoch -1 tst: l 3.874 a 0.024 clct[np.int64(14), np.int64(6)] cl_acc 0.600  0.737sec\n",
      "Epoch 0 tr: l 3.355 a 0.199 clct[np.int64(51), np.int64(49)] cl_acc 0.990  lr 0.100000 17.599sec(train) 3.839sec(infer)\n",
      "Epoch 0 tst: l 3.352 a 0.200 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.546sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 1 tr: l 2.448 a 0.513 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.099500 17.328sec(train) 3.264sec(infer)\n",
      "Epoch 1 tst: l 2.452 a 0.505 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.759sec\n",
      "Epoch 2 tr: l 1.797 a 0.615 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.099003 17.369sec(train) 3.194sec(infer)\n",
      "Epoch 2 tst: l 1.811 a 0.607 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.766sec\n",
      "Epoch 3 tr: l 1.436 a 0.655 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.098507 17.467sec(train) 3.893sec(infer)\n",
      "Epoch 3 tst: l 1.454 a 0.648 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.736sec\n",
      "Epoch 4 tr: l 1.249 a 0.671 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.098015 16.938sec(train) 4.252sec(infer)\n",
      "Epoch 4 tst: l 1.272 a 0.666 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.849sec\n",
      "Epoch 5 tr: l 1.116 a 0.693 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.097525 16.982sec(train) 3.185sec(infer)\n",
      "Epoch 5 tst: l 1.134 a 0.686 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.744sec\n",
      "Epoch 6 tr: l 1.000 a 0.722 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.097037 17.667sec(train) 3.135sec(infer)\n",
      "Epoch 6 tst: l 1.026 a 0.716 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.620sec\n",
      "Epoch 7 tr: l 0.929 a 0.736 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.096552 17.300sec(train) 4.119sec(infer)\n",
      "Epoch 7 tst: l 0.950 a 0.725 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.826sec\n",
      "Epoch 8 tr: l 0.872 a 0.749 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.096069 16.795sec(train) 4.249sec(infer)\n",
      "Epoch 8 tst: l 0.901 a 0.743 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.861sec\n",
      "Epoch 9 tr: l 0.816 a 0.761 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.095589 16.761sec(train) 3.584sec(infer)\n",
      "Epoch 9 tst: l 0.840 a 0.750 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.692sec\n",
      "Epoch 10 tr: l 0.783 a 0.769 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.095111 17.223sec(train) 3.048sec(infer)\n",
      "Epoch 10 tst: l 0.816 a 0.762 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.643sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 11 tr: l 0.744 a 0.777 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.094635 17.740sec(train) 3.199sec(infer)\n",
      "Epoch 11 tst: l 0.771 a 0.765 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.761sec\n",
      "Epoch 12 tr: l 0.722 a 0.782 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.094162 17.888sec(train) 3.586sec(infer)\n",
      "Epoch 12 tst: l 0.758 a 0.773 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.690sec\n",
      "Epoch 13 tr: l 0.690 a 0.789 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.093691 17.362sec(train) 4.093sec(infer)\n",
      "Epoch 13 tst: l 0.720 a 0.778 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.606sec\n",
      "Epoch 14 tr: l 0.676 a 0.794 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.093223 16.658sec(train) 3.666sec(infer)\n",
      "Epoch 14 tst: l 0.715 a 0.784 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.744sec\n",
      "Epoch 15 tr: l 0.651 a 0.798 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.092757 16.615sec(train) 3.775sec(infer)\n",
      "Epoch 15 tst: l 0.684 a 0.785 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.851sec\n",
      "Epoch 16 tr: l 0.633 a 0.804 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.092293 16.195sec(train) 4.186sec(infer)\n",
      "Epoch 16 tst: l 0.673 a 0.794 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.845sec\n",
      "Epoch 17 tr: l 0.613 a 0.807 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.091832 17.052sec(train) 3.640sec(infer)\n",
      "Epoch 17 tst: l 0.649 a 0.795 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.858sec\n",
      "Epoch 18 tr: l 0.603 a 0.811 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.091372 18.131sec(train) 2.489sec(infer)\n",
      "Epoch 18 tst: l 0.646 a 0.800 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.528sec\n",
      "Epoch 19 tr: l 0.596 a 0.810 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.090916 18.362sec(train) 2.867sec(infer)\n",
      "Epoch 19 tst: l 0.634 a 0.799 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.520sec\n",
      "Epoch 20 tr: l 0.590 a 0.813 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.090461 17.262sec(train) 3.920sec(infer)\n",
      "Epoch 20 tst: l 0.635 a 0.803 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.883sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 21 tr: l 0.574 a 0.816 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.090009 14.093sec(train) 3.138sec(infer)\n",
      "Epoch 21 tst: l 0.614 a 0.805 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.653sec\n",
      "Epoch 22 tr: l 0.561 a 0.821 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.089559 13.197sec(train) 4.023sec(infer)\n",
      "Epoch 22 tst: l 0.609 a 0.809 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.891sec\n",
      "Epoch 23 tr: l 0.556 a 0.821 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.089111 17.329sec(train) 3.147sec(infer)\n",
      "Epoch 23 tst: l 0.599 a 0.807 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.685sec\n",
      "Epoch 24 tr: l 0.545 a 0.825 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.088665 18.199sec(train) 2.699sec(infer)\n",
      "Epoch 24 tst: l 0.595 a 0.813 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.637sec\n",
      "Epoch 25 tr: l 0.533 a 0.827 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.088222 18.465sec(train) 3.476sec(infer)\n",
      "Epoch 25 tst: l 0.578 a 0.813 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.606sec\n",
      "Epoch 26 tr: l 0.525 a 0.831 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.087781 17.531sec(train) 4.253sec(infer)\n",
      "Epoch 26 tst: l 0.577 a 0.817 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.811sec\n",
      "Epoch 27 tr: l 0.518 a 0.831 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.087342 15.318sec(train) 4.058sec(infer)\n",
      "Epoch 27 tst: l 0.565 a 0.817 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.714sec\n",
      "Epoch 28 tr: l 0.514 a 0.833 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.086905 16.933sec(train) 3.383sec(infer)\n",
      "Epoch 28 tst: l 0.568 a 0.820 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.772sec\n",
      "Epoch 29 tr: l 0.505 a 0.834 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.086471 17.601sec(train) 3.336sec(infer)\n",
      "Epoch 29 tst: l 0.554 a 0.820 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.751sec\n",
      "Epoch 30 tr: l 0.499 a 0.837 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.086038 17.784sec(train) 3.873sec(infer)\n",
      "Epoch 30 tst: l 0.555 a 0.822 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.713sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 31 tr: l 0.493 a 0.837 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.085608 17.491sec(train) 3.828sec(infer)\n",
      "Epoch 31 tst: l 0.544 a 0.823 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.696sec\n",
      "Epoch 32 tr: l 0.488 a 0.839 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.085180 17.544sec(train) 2.965sec(infer)\n",
      "Epoch 32 tst: l 0.544 a 0.825 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.665sec\n",
      "Epoch 33 tr: l 0.481 a 0.841 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.084754 17.504sec(train) 3.486sec(infer)\n",
      "Epoch 33 tst: l 0.535 a 0.826 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.739sec\n",
      "Epoch 34 tr: l 0.478 a 0.842 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.084331 16.961sec(train) 4.236sec(infer)\n",
      "Epoch 34 tst: l 0.535 a 0.828 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.811sec\n",
      "Epoch 35 tr: l 0.472 a 0.844 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.083909 16.964sec(train) 3.926sec(infer)\n",
      "Epoch 35 tst: l 0.528 a 0.829 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.864sec\n",
      "Epoch 36 tr: l 0.467 a 0.845 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.083489 17.652sec(train) 2.994sec(infer)\n",
      "Epoch 36 tst: l 0.526 a 0.830 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.643sec\n",
      "Epoch 37 tr: l 0.465 a 0.846 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.083072 17.758sec(train) 3.497sec(infer)\n",
      "Epoch 37 tst: l 0.525 a 0.829 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.671sec\n",
      "Epoch 38 tr: l 0.461 a 0.845 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.082657 17.058sec(train) 4.210sec(infer)\n",
      "Epoch 38 tst: l 0.520 a 0.830 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.860sec\n",
      "Epoch 39 tr: l 0.455 a 0.849 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.082243 16.711sec(train) 4.133sec(infer)\n",
      "Epoch 39 tst: l 0.516 a 0.832 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.869sec\n",
      "Epoch 40 tr: l 0.451 a 0.849 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.081832 17.441sec(train) 3.414sec(infer)\n",
      "Epoch 40 tst: l 0.512 a 0.833 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.740sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 41 tr: l 0.449 a 0.849 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.081423 17.619sec(train) 3.118sec(infer)\n",
      "Epoch 41 tst: l 0.511 a 0.833 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.647sec\n",
      "Epoch 42 tr: l 0.446 a 0.850 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.081016 17.840sec(train) 3.311sec(infer)\n",
      "Epoch 42 tst: l 0.509 a 0.833 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.748sec\n",
      "Epoch 43 tr: l 0.439 a 0.852 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.080611 18.120sec(train) 3.611sec(infer)\n",
      "Epoch 43 tst: l 0.503 a 0.835 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.718sec\n",
      "Epoch 44 tr: l 0.435 a 0.853 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.080208 17.424sec(train) 4.106sec(infer)\n",
      "Epoch 44 tst: l 0.500 a 0.836 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.555sec\n",
      "Epoch 45 tr: l 0.431 a 0.854 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.079807 16.852sec(train) 3.578sec(infer)\n",
      "Epoch 45 tst: l 0.497 a 0.837 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.752sec\n",
      "Epoch 46 tr: l 0.428 a 0.855 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.079408 16.849sec(train) 3.882sec(infer)\n",
      "Epoch 46 tst: l 0.495 a 0.838 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.841sec\n",
      "Epoch 47 tr: l 0.425 a 0.856 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.079010 16.463sec(train) 4.241sec(infer)\n",
      "Epoch 47 tst: l 0.492 a 0.839 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.862sec\n",
      "Epoch 48 tr: l 0.422 a 0.857 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.078615 16.985sec(train) 3.829sec(infer)\n",
      "Epoch 48 tst: l 0.490 a 0.839 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.864sec\n",
      "Epoch 49 tr: l 0.418 a 0.858 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.078222 17.890sec(train) 2.406sec(infer)\n",
      "Epoch 49 tst: l 0.487 a 0.839 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.635sec\n",
      "Epoch 50 tr: l 0.416 a 0.858 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.077831 18.668sec(train) 2.791sec(infer)\n",
      "Epoch 50 tst: l 0.485 a 0.840 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.501sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 51 tr: l 0.413 a 0.860 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.077442 17.972sec(train) 4.191sec(infer)\n",
      "Epoch 51 tst: l 0.483 a 0.841 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.698sec\n",
      "Epoch 52 tr: l 0.411 a 0.860 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.077055 16.802sec(train) 4.256sec(infer)\n",
      "Epoch 52 tst: l 0.481 a 0.841 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.864sec\n",
      "Epoch 53 tr: l 0.408 a 0.861 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.076670 16.629sec(train) 3.969sec(infer)\n",
      "Epoch 53 tst: l 0.480 a 0.841 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.714sec\n",
      "Epoch 54 tr: l 0.406 a 0.861 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.076286 16.710sec(train) 3.711sec(infer)\n",
      "Epoch 54 tst: l 0.478 a 0.841 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.756sec\n",
      "Epoch 55 tr: l 0.403 a 0.862 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.075905 16.796sec(train) 3.756sec(infer)\n",
      "Epoch 55 tst: l 0.477 a 0.842 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.864sec\n",
      "Epoch 56 tr: l 0.401 a 0.863 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.075525 17.605sec(train) 3.438sec(infer)\n",
      "Epoch 56 tst: l 0.474 a 0.843 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.743sec\n",
      "Epoch 57 tr: l 0.398 a 0.863 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.075148 18.121sec(train) 3.428sec(infer)\n",
      "Epoch 57 tst: l 0.473 a 0.844 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.555sec\n",
      "Epoch 58 tr: l 0.396 a 0.864 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.074772 17.910sec(train) 3.060sec(infer)\n",
      "Epoch 58 tst: l 0.471 a 0.844 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.646sec\n",
      "Epoch 59 tr: l 0.394 a 0.864 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.074398 17.345sec(train) 3.611sec(infer)\n",
      "Epoch 59 tst: l 0.472 a 0.844 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.748sec\n",
      "Epoch 60 tr: l 0.394 a 0.865 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.074026 16.778sec(train) 4.269sec(infer)\n",
      "Epoch 60 tst: l 0.470 a 0.844 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.846sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 61 tr: l 0.389 a 0.865 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.073656 16.835sec(train) 4.256sec(infer)\n",
      "Epoch 61 tst: l 0.468 a 0.845 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.867sec\n",
      "Epoch 62 tr: l 0.387 a 0.867 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.073288 17.163sec(train) 3.311sec(infer)\n",
      "Epoch 62 tst: l 0.464 a 0.846 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.759sec\n",
      "Epoch 63 tr: l 0.384 a 0.867 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.072921 17.881sec(train) 3.074sec(infer)\n",
      "Epoch 63 tst: l 0.464 a 0.846 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.665sec\n",
      "Epoch 64 tr: l 0.382 a 0.868 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.072557 17.625sec(train) 4.090sec(infer)\n",
      "Epoch 64 tst: l 0.461 a 0.847 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.734sec\n",
      "Epoch 65 tr: l 0.379 a 0.868 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.072194 17.150sec(train) 3.937sec(infer)\n",
      "Epoch 65 tst: l 0.461 a 0.847 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.856sec\n",
      "Epoch 66 tr: l 0.378 a 0.869 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.071833 17.448sec(train) 3.310sec(infer)\n",
      "Epoch 66 tst: l 0.459 a 0.848 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.600sec\n",
      "Epoch 67 tr: l 0.376 a 0.869 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.071474 17.598sec(train) 3.259sec(infer)\n",
      "Epoch 67 tst: l 0.458 a 0.848 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.638sec\n",
      "Epoch 68 tr: l 0.374 a 0.870 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.071116 17.117sec(train) 3.963sec(infer)\n",
      "Epoch 68 tst: l 0.457 a 0.848 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.791sec\n",
      "Epoch 69 tr: l 0.372 a 0.871 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.070761 17.369sec(train) 3.659sec(infer)\n",
      "Epoch 69 tst: l 0.456 a 0.849 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.851sec\n",
      "Epoch 70 tr: l 0.371 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.070407 17.637sec(train) 3.719sec(infer)\n",
      "Epoch 70 tst: l 0.455 a 0.849 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.566sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 71 tr: l 0.369 a 0.871 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.070055 17.359sec(train) 3.670sec(infer)\n",
      "Epoch 71 tst: l 0.454 a 0.850 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.664sec\n",
      "Epoch 72 tr: l 0.368 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.069705 17.036sec(train) 3.854sec(infer)\n",
      "Epoch 72 tst: l 0.454 a 0.849 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.864sec\n",
      "Epoch 73 tr: l 0.366 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.069356 16.722sec(train) 4.175sec(infer)\n",
      "Epoch 73 tst: l 0.452 a 0.850 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.858sec\n",
      "Epoch 74 tr: l 0.365 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.069009 17.248sec(train) 3.831sec(infer)\n",
      "Epoch 74 tst: l 0.452 a 0.849 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.832sec\n",
      "Epoch 75 tr: l 0.363 a 0.873 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.068664 17.647sec(train) 2.909sec(infer)\n",
      "Epoch 75 tst: l 0.450 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.650sec\n",
      "Epoch 76 tr: l 0.361 a 0.873 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.068321 18.257sec(train) 2.760sec(infer)\n",
      "Epoch 76 tst: l 0.450 a 0.850 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.638sec\n",
      "Epoch 77 tr: l 0.359 a 0.874 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.067979 18.028sec(train) 3.827sec(infer)\n",
      "Epoch 77 tst: l 0.447 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.707sec\n",
      "Epoch 78 tr: l 0.358 a 0.874 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.067639 17.144sec(train) 4.262sec(infer)\n",
      "Epoch 78 tst: l 0.448 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.864sec\n",
      "Epoch 79 tr: l 0.356 a 0.875 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.067301 16.358sec(train) 3.917sec(infer)\n",
      "Epoch 79 tst: l 0.445 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.719sec\n",
      "Epoch 80 tr: l 0.354 a 0.875 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.066965 16.713sec(train) 3.720sec(infer)\n",
      "Epoch 80 tst: l 0.446 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.755sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 81 tr: l 0.353 a 0.876 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.066630 16.628sec(train) 4.038sec(infer)\n",
      "Epoch 81 tst: l 0.443 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.865sec\n",
      "Epoch 82 tr: l 0.352 a 0.876 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.066297 17.302sec(train) 3.702sec(infer)\n",
      "Epoch 82 tst: l 0.444 a 0.853 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.871sec\n",
      "Epoch 83 tr: l 0.351 a 0.877 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.065965 18.224sec(train) 2.853sec(infer)\n",
      "Epoch 83 tst: l 0.443 a 0.853 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.488sec\n",
      "Epoch 84 tr: l 0.350 a 0.876 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.065635 18.913sec(train) 2.711sec(infer)\n",
      "Epoch 84 tst: l 0.443 a 0.853 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.513sec\n",
      "Epoch 85 tr: l 0.348 a 0.877 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.065307 17.522sec(train) 3.857sec(infer)\n",
      "Epoch 85 tst: l 0.442 a 0.853 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.765sec\n",
      "Epoch 86 tr: l 0.347 a 0.878 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064981 16.837sec(train) 4.229sec(infer)\n",
      "Epoch 86 tst: l 0.440 a 0.853 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.858sec\n",
      "Epoch 87 tr: l 0.345 a 0.878 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064656 16.547sec(train) 4.260sec(infer)\n",
      "Epoch 87 tst: l 0.441 a 0.853 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.849sec\n",
      "Epoch 88 tr: l 0.344 a 0.878 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064333 16.836sec(train) 3.723sec(infer)\n",
      "Epoch 88 tst: l 0.438 a 0.853 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.767sec\n",
      "Epoch 89 tr: l 0.342 a 0.879 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064011 17.331sec(train) 3.261sec(infer)\n",
      "Epoch 89 tst: l 0.439 a 0.854 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.842sec\n",
      "Epoch 90 tr: l 0.341 a 0.879 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.063691 17.698sec(train) 3.514sec(infer)\n",
      "Epoch 90 tst: l 0.437 a 0.854 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.733sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 91 tr: l 0.340 a 0.880 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.063372 18.031sec(train) 3.730sec(infer)\n",
      "Epoch 91 tst: l 0.438 a 0.855 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.738sec\n",
      "Epoch 92 tr: l 0.339 a 0.880 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.063056 17.688sec(train) 3.212sec(infer)\n",
      "Epoch 92 tst: l 0.436 a 0.854 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.642sec\n",
      "Epoch 93 tr: l 0.337 a 0.880 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.062740 17.802sec(train) 3.414sec(infer)\n",
      "Epoch 93 tst: l 0.436 a 0.855 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.615sec\n",
      "Epoch 94 tr: l 0.336 a 0.881 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.062427 17.154sec(train) 3.622sec(infer)\n",
      "Epoch 94 tst: l 0.435 a 0.855 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.708sec\n",
      "Epoch 95 tr: l 0.335 a 0.881 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.062114 16.903sec(train) 3.797sec(infer)\n",
      "Epoch 95 tst: l 0.435 a 0.855 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.854sec\n",
      "Epoch 96 tr: l 0.334 a 0.882 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.061804 17.155sec(train) 3.601sec(infer)\n",
      "Epoch 96 tst: l 0.434 a 0.855 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.841sec\n",
      "Epoch 97 tr: l 0.333 a 0.881 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.061495 17.652sec(train) 3.813sec(infer)\n",
      "Epoch 97 tst: l 0.434 a 0.855 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.716sec\n",
      "Epoch 98 tr: l 0.331 a 0.882 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.061187 17.213sec(train) 3.785sec(infer)\n",
      "Epoch 98 tst: l 0.432 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.707sec\n",
      "Epoch 99 tr: l 0.330 a 0.882 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.060881 16.997sec(train) 3.575sec(infer)\n",
      "Epoch 99 tst: l 0.432 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.749sec\n",
      "Epoch 100 tr: l 0.329 a 0.883 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.006058 17.416sec(train) 3.573sec(infer)\n",
      "Epoch 100 tst: l 0.431 a 0.857 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.847sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 101 tr: l 0.329 a 0.883 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.006027 17.515sec(train) 3.759sec(infer)\n",
      "Epoch 101 tst: l 0.431 a 0.857 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.755sec\n",
      "Epoch 102 tr: l 0.328 a 0.883 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005997 17.567sec(train) 3.635sec(infer)\n",
      "Epoch 102 tst: l 0.430 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.594sec\n",
      "Epoch 103 tr: l 0.328 a 0.883 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005967 18.049sec(train) 2.907sec(infer)\n",
      "Epoch 103 tst: l 0.430 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.651sec\n",
      "Epoch 104 tr: l 0.328 a 0.883 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005937 17.819sec(train) 3.508sec(infer)\n",
      "Epoch 104 tst: l 0.430 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.716sec\n",
      "Epoch 105 tr: l 0.328 a 0.883 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005908 16.895sec(train) 4.270sec(infer)\n",
      "Epoch 105 tst: l 0.430 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.859sec\n",
      "Epoch 106 tr: l 0.328 a 0.883 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005878 16.695sec(train) 4.265sec(infer)\n",
      "Epoch 106 tst: l 0.430 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.858sec\n",
      "Epoch 107 tr: l 0.328 a 0.883 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005849 16.693sec(train) 3.751sec(infer)\n",
      "Epoch 107 tst: l 0.430 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.766sec\n",
      "Epoch 108 tr: l 0.327 a 0.883 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005820 17.141sec(train) 3.428sec(infer)\n",
      "Epoch 108 tst: l 0.430 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.752sec\n",
      "Epoch 109 tr: l 0.327 a 0.883 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005790 17.936sec(train) 3.040sec(infer)\n",
      "Epoch 109 tst: l 0.430 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.780sec\n",
      "Epoch 110 tr: l 0.327 a 0.883 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005762 18.590sec(train) 3.210sec(infer)\n",
      "Epoch 110 tst: l 0.430 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.621sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 111 tr: l 0.327 a 0.883 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005733 17.824sec(train) 3.892sec(infer)\n",
      "Epoch 111 tst: l 0.430 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.417sec\n",
      "Epoch 112 tr: l 0.327 a 0.883 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005704 17.169sec(train) 3.582sec(infer)\n",
      "Epoch 112 tst: l 0.430 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.769sec\n",
      "Epoch 113 tr: l 0.327 a 0.883 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005676 17.132sec(train) 3.882sec(infer)\n",
      "Epoch 113 tst: l 0.430 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.869sec\n",
      "Epoch 114 tr: l 0.327 a 0.883 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005647 16.518sec(train) 4.255sec(infer)\n",
      "Epoch 114 tst: l 0.430 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.856sec\n",
      "Epoch 115 tr: l 0.327 a 0.883 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005619 16.514sec(train) 4.243sec(infer)\n",
      "Epoch 115 tst: l 0.430 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.862sec\n",
      "Epoch 116 tr: l 0.326 a 0.883 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005591 17.394sec(train) 2.883sec(infer)\n",
      "Epoch 116 tst: l 0.430 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.733sec\n",
      "Epoch 117 tr: l 0.326 a 0.883 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005563 18.396sec(train) 2.613sec(infer)\n",
      "Epoch 117 tst: l 0.430 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.606sec\n",
      "Epoch 118 tr: l 0.326 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005535 18.233sec(train) 3.503sec(infer)\n",
      "Epoch 118 tst: l 0.429 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.757sec\n",
      "Epoch 119 tr: l 0.326 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005507 17.443sec(train) 4.101sec(infer)\n",
      "Epoch 119 tst: l 0.429 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.746sec\n",
      "Epoch 120 tr: l 0.326 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005480 16.895sec(train) 4.208sec(infer)\n",
      "Epoch 120 tst: l 0.429 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.710sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 121 tr: l 0.326 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005452 16.814sec(train) 3.593sec(infer)\n",
      "Epoch 121 tst: l 0.429 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.746sec\n",
      "Epoch 122 tr: l 0.326 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005425 16.986sec(train) 3.458sec(infer)\n",
      "Epoch 122 tst: l 0.429 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.859sec\n",
      "Epoch 123 tr: l 0.326 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005398 17.722sec(train) 3.603sec(infer)\n",
      "Epoch 123 tst: l 0.429 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.754sec\n",
      "Epoch 124 tr: l 0.325 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005371 17.755sec(train) 4.047sec(infer)\n",
      "Epoch 124 tst: l 0.429 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.735sec\n",
      "Epoch 125 tr: l 0.325 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005344 17.045sec(train) 3.470sec(infer)\n",
      "Epoch 125 tst: l 0.429 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.761sec\n",
      "Epoch 126 tr: l 0.325 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005318 17.405sec(train) 3.123sec(infer)\n",
      "Epoch 126 tst: l 0.429 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.650sec\n",
      "Epoch 127 tr: l 0.325 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005291 17.703sec(train) 3.627sec(infer)\n",
      "Epoch 127 tst: l 0.429 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.750sec\n",
      "Epoch 128 tr: l 0.325 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005264 17.213sec(train) 4.280sec(infer)\n",
      "Epoch 128 tst: l 0.429 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.745sec\n",
      "Epoch 129 tr: l 0.325 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005238 17.312sec(train) 3.678sec(infer)\n",
      "Epoch 129 tst: l 0.429 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.706sec\n",
      "Epoch 130 tr: l 0.325 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005212 17.683sec(train) 2.888sec(infer)\n",
      "Epoch 130 tst: l 0.429 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.641sec\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.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005186 17.463sec(train) 3.808sec(infer)\n",
      "Epoch 131 tst: l 0.429 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.733sec\n",
      "Epoch 132 tr: l 0.324 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005160 16.793sec(train) 4.261sec(infer)\n",
      "Epoch 132 tst: l 0.429 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.877sec\n",
      "Epoch 133 tr: l 0.324 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005134 16.530sec(train) 4.164sec(infer)\n",
      "Epoch 133 tst: l 0.429 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.851sec\n",
      "Epoch 134 tr: l 0.324 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005108 17.327sec(train) 3.375sec(infer)\n",
      "Epoch 134 tst: l 0.429 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.747sec\n",
      "Epoch 135 tr: l 0.324 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005083 17.652sec(train) 3.073sec(infer)\n",
      "Epoch 135 tst: l 0.429 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.662sec\n",
      "Epoch 136 tr: l 0.324 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005058 18.081sec(train) 3.143sec(infer)\n",
      "Epoch 136 tst: l 0.429 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.713sec\n",
      "Epoch 137 tr: l 0.324 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005032 17.839sec(train) 3.790sec(infer)\n",
      "Epoch 137 tst: l 0.429 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.713sec\n",
      "Epoch 138 tr: l 0.324 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005007 17.183sec(train) 4.199sec(infer)\n",
      "Epoch 138 tst: l 0.428 a 0.857 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.618sec\n",
      "Epoch 139 tr: l 0.324 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004982 16.811sec(train) 3.564sec(infer)\n",
      "Epoch 139 tst: l 0.428 a 0.857 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.747sec\n",
      "Epoch 140 tr: l 0.324 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004957 16.757sec(train) 3.838sec(infer)\n",
      "Epoch 140 tst: l 0.428 a 0.857 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.869sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 141 tr: l 0.324 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004932 16.390sec(train) 4.271sec(infer)\n",
      "Epoch 141 tst: l 0.428 a 0.857 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.863sec\n",
      "Epoch 142 tr: l 0.323 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004908 17.182sec(train) 3.670sec(infer)\n",
      "Epoch 142 tst: l 0.428 a 0.857 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.867sec\n",
      "Epoch 143 tr: l 0.323 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004883 18.252sec(train) 2.535sec(infer)\n",
      "Epoch 143 tst: l 0.428 a 0.857 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.487sec\n",
      "Epoch 144 tr: l 0.323 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004859 18.526sec(train) 2.906sec(infer)\n",
      "Epoch 144 tst: l 0.428 a 0.857 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.508sec\n",
      "Epoch 145 tr: l 0.323 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004834 17.716sec(train) 3.952sec(infer)\n",
      "Epoch 145 tst: l 0.428 a 0.857 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.750sec\n",
      "Epoch 146 tr: l 0.323 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004810 16.687sec(train) 4.240sec(infer)\n",
      "Epoch 146 tst: l 0.428 a 0.857 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.862sec\n",
      "Epoch 147 tr: l 0.323 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004786 16.381sec(train) 4.261sec(infer)\n",
      "Epoch 147 tst: l 0.428 a 0.857 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.816sec\n",
      "Epoch 148 tr: l 0.323 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004762 16.669sec(train) 3.653sec(infer)\n",
      "Epoch 148 tst: l 0.428 a 0.857 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.764sec\n",
      "Epoch 149 tr: l 0.323 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004738 17.218sec(train) 3.202sec(infer)\n",
      "Epoch 149 tst: l 0.428 a 0.857 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.815sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "---train cluster Ended in 0.90 hour (3253.984 sec) \n",
      "---------------------------------IFCA, lr: 0.1, seed: 7383---------------------------------\n",
      "config: {'m': 100, 'm_test': 20, 'p': 2, 'n': 1500, 'uneven': True, 'local_model_init': False, 'Gp': 0.15, 'graph': 'er', 'agg': 'seq', 'h1': 512, 'num_epochs': 150, 'batch_size': 100, 'tau': 5, 'lr': 0.1, 'data_seed': 7383, 'train_seed': 7383, 'config_override': '', 'project_dir': 'output_dfca_gi'}\n",
      "Using device: cuda:3\n",
      "Epoch -1 tr: l 3.872 a 0.018 clct[np.int64(59), np.int64(41)] cl_acc 0.610  4.302sec\n",
      "Epoch -1 tst: l 3.874 a 0.018 clct[np.int64(11), np.int64(9)] cl_acc 0.550  0.907sec\n",
      "Epoch 0 tr: l 3.364 a 0.202 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.100000 16.654sec(train) 4.045sec(infer)\n",
      "Epoch 0 tst: l 3.371 a 0.201 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.897sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 1 tr: l 2.495 a 0.491 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.099500 17.533sec(train) 3.035sec(infer)\n",
      "Epoch 1 tst: l 2.511 a 0.488 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.673sec\n",
      "Epoch 2 tr: l 1.842 a 0.609 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.099003 17.691sec(train) 3.407sec(infer)\n",
      "Epoch 2 tst: l 1.868 a 0.602 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.661sec\n",
      "Epoch 3 tr: l 1.456 a 0.664 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.098507 17.478sec(train) 3.849sec(infer)\n",
      "Epoch 3 tst: l 1.489 a 0.658 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.882sec\n",
      "Epoch 4 tr: l 1.238 a 0.688 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.098015 17.782sec(train) 3.745sec(infer)\n",
      "Epoch 4 tst: l 1.277 a 0.682 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.805sec\n",
      "Epoch 5 tr: l 1.109 a 0.705 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.097525 17.758sec(train) 3.461sec(infer)\n",
      "Epoch 5 tst: l 1.148 a 0.699 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.609sec\n",
      "Epoch 6 tr: l 1.028 a 0.713 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.097037 17.557sec(train) 3.737sec(infer)\n",
      "Epoch 6 tst: l 1.078 a 0.706 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.663sec\n",
      "Epoch 7 tr: l 0.938 a 0.738 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.096552 17.314sec(train) 3.838sec(infer)\n",
      "Epoch 7 tst: l 0.982 a 0.730 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.916sec\n",
      "Epoch 8 tr: l 0.868 a 0.750 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.096069 17.636sec(train) 3.658sec(infer)\n",
      "Epoch 8 tst: l 0.923 a 0.744 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.799sec\n",
      "Epoch 9 tr: l 0.817 a 0.767 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.095589 17.620sec(train) 3.812sec(infer)\n",
      "Epoch 9 tst: l 0.869 a 0.759 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.581sec\n",
      "Epoch 10 tr: l 0.774 a 0.771 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.095111 17.355sec(train) 3.662sec(infer)\n",
      "Epoch 10 tst: l 0.834 a 0.764 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.792sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 11 tr: l 0.744 a 0.782 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.094635 16.835sec(train) 3.916sec(infer)\n",
      "Epoch 11 tst: l 0.802 a 0.775 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.905sec\n",
      "Epoch 12 tr: l 0.714 a 0.784 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.094162 16.965sec(train) 4.004sec(infer)\n",
      "Epoch 12 tst: l 0.778 a 0.776 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.900sec\n",
      "Epoch 13 tr: l 0.691 a 0.793 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.093691 17.477sec(train) 3.795sec(infer)\n",
      "Epoch 13 tst: l 0.753 a 0.785 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.785sec\n",
      "Epoch 14 tr: l 0.664 a 0.797 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.093223 17.762sec(train) 2.902sec(infer)\n",
      "Epoch 14 tst: l 0.731 a 0.788 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.678sec\n",
      "Epoch 15 tr: l 0.645 a 0.804 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.092757 18.305sec(train) 3.045sec(infer)\n",
      "Epoch 15 tst: l 0.710 a 0.796 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.645sec\n",
      "Epoch 16 tr: l 0.626 a 0.806 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.092293 17.646sec(train) 3.968sec(infer)\n",
      "Epoch 16 tst: l 0.696 a 0.796 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.751sec\n",
      "Epoch 17 tr: l 0.610 a 0.812 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.091832 16.829sec(train) 4.315sec(infer)\n",
      "Epoch 17 tst: l 0.679 a 0.803 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.897sec\n",
      "Epoch 18 tr: l 0.595 a 0.813 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.091372 16.679sec(train) 4.058sec(infer)\n",
      "Epoch 18 tst: l 0.669 a 0.803 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.721sec\n",
      "Epoch 19 tr: l 0.584 a 0.819 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.090916 16.851sec(train) 3.739sec(infer)\n",
      "Epoch 19 tst: l 0.657 a 0.807 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.783sec\n",
      "Epoch 20 tr: l 0.571 a 0.819 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.090461 16.817sec(train) 3.893sec(infer)\n",
      "Epoch 20 tst: l 0.648 a 0.808 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.894sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 21 tr: l 0.562 a 0.824 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.090009 17.475sec(train) 3.627sec(infer)\n",
      "Epoch 21 tst: l 0.637 a 0.812 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.908sec\n",
      "Epoch 22 tr: l 0.551 a 0.823 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.089559 18.446sec(train) 3.020sec(infer)\n",
      "Epoch 22 tst: l 0.630 a 0.813 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.499sec\n",
      "Epoch 23 tr: l 0.542 a 0.829 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.089111 18.698sec(train) 2.683sec(infer)\n",
      "Epoch 23 tst: l 0.619 a 0.816 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.525sec\n",
      "Epoch 24 tr: l 0.533 a 0.828 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.088665 17.546sec(train) 3.800sec(infer)\n",
      "Epoch 24 tst: l 0.615 a 0.817 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.879sec\n",
      "Epoch 25 tr: l 0.525 a 0.832 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.088222 16.559sec(train) 4.279sec(infer)\n",
      "Epoch 25 tst: l 0.605 a 0.819 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.898sec\n",
      "Epoch 26 tr: l 0.517 a 0.831 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.087781 16.818sec(train) 4.324sec(infer)\n",
      "Epoch 26 tst: l 0.601 a 0.820 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.898sec\n",
      "Epoch 27 tr: l 0.509 a 0.836 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.087342 16.643sec(train) 3.995sec(infer)\n",
      "Epoch 27 tst: l 0.591 a 0.822 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.754sec\n",
      "Epoch 28 tr: l 0.502 a 0.836 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.086905 17.278sec(train) 3.343sec(infer)\n",
      "Epoch 28 tst: l 0.588 a 0.823 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.777sec\n",
      "Epoch 29 tr: l 0.495 a 0.840 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.086471 17.745sec(train) 3.302sec(infer)\n",
      "Epoch 29 tst: l 0.580 a 0.825 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.768sec\n",
      "Epoch 30 tr: l 0.490 a 0.839 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.086038 17.859sec(train) 3.789sec(infer)\n",
      "Epoch 30 tst: l 0.578 a 0.827 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.764sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 31 tr: l 0.485 a 0.843 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.085608 17.748sec(train) 3.714sec(infer)\n",
      "Epoch 31 tst: l 0.572 a 0.829 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.632sec\n",
      "Epoch 32 tr: l 0.478 a 0.842 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.085180 17.801sec(train) 3.167sec(infer)\n",
      "Epoch 32 tst: l 0.568 a 0.829 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.654sec\n",
      "Epoch 33 tr: l 0.473 a 0.846 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.084754 17.307sec(train) 3.876sec(infer)\n",
      "Epoch 33 tst: l 0.562 a 0.831 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.821sec\n",
      "Epoch 34 tr: l 0.467 a 0.845 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.084331 16.609sec(train) 4.311sec(infer)\n",
      "Epoch 34 tst: l 0.559 a 0.832 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.887sec\n",
      "Epoch 35 tr: l 0.462 a 0.849 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.083909 17.243sec(train) 3.930sec(infer)\n",
      "Epoch 35 tst: l 0.553 a 0.834 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.884sec\n",
      "Epoch 36 tr: l 0.458 a 0.847 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.083489 17.665sec(train) 3.021sec(infer)\n",
      "Epoch 36 tst: l 0.552 a 0.833 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.669sec\n",
      "Epoch 37 tr: l 0.453 a 0.851 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.083072 17.754sec(train) 3.586sec(infer)\n",
      "Epoch 37 tst: l 0.546 a 0.835 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.659sec\n",
      "Epoch 38 tr: l 0.450 a 0.849 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.082657 17.145sec(train) 4.182sec(infer)\n",
      "Epoch 38 tst: l 0.546 a 0.833 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.906sec\n",
      "Epoch 39 tr: l 0.446 a 0.853 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.082243 17.036sec(train) 3.977sec(infer)\n",
      "Epoch 39 tst: l 0.540 a 0.836 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.883sec\n",
      "Epoch 40 tr: l 0.442 a 0.851 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.081832 17.632sec(train) 3.477sec(infer)\n",
      "Epoch 40 tst: l 0.540 a 0.835 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.629sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 41 tr: l 0.438 a 0.854 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.081423 17.780sec(train) 3.282sec(infer)\n",
      "Epoch 41 tst: l 0.534 a 0.837 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.655sec\n",
      "Epoch 42 tr: l 0.434 a 0.853 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.081016 13.901sec(train) 2.135sec(infer)\n",
      "Epoch 42 tst: l 0.534 a 0.837 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.672sec\n",
      "Epoch 43 tr: l 0.431 a 0.856 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.080611 15.926sec(train) 3.670sec(infer)\n",
      "Epoch 43 tst: l 0.528 a 0.838 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.759sec\n",
      "Epoch 44 tr: l 0.427 a 0.855 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.080208 17.516sec(train) 4.286sec(infer)\n",
      "Epoch 44 tst: l 0.528 a 0.839 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.758sec\n",
      "Epoch 45 tr: l 0.425 a 0.858 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.079807 17.246sec(train) 3.621sec(infer)\n",
      "Epoch 45 tst: l 0.524 a 0.839 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.777sec\n",
      "Epoch 46 tr: l 0.423 a 0.857 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.079408 17.324sec(train) 3.254sec(infer)\n",
      "Epoch 46 tst: l 0.526 a 0.840 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.760sec\n",
      "Epoch 47 tr: l 0.419 a 0.859 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.079010 17.619sec(train) 3.620sec(infer)\n",
      "Epoch 47 tst: l 0.519 a 0.840 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.776sec\n",
      "Epoch 48 tr: l 0.417 a 0.859 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.078615 17.326sec(train) 4.209sec(infer)\n",
      "Epoch 48 tst: l 0.521 a 0.842 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.770sec\n",
      "Epoch 49 tr: l 0.413 a 0.860 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.078222 17.306sec(train) 3.690sec(infer)\n",
      "Epoch 49 tst: l 0.516 a 0.840 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.742sec\n",
      "Epoch 50 tr: l 0.412 a 0.860 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.077831 17.932sec(train) 2.987sec(infer)\n",
      "Epoch 50 tst: l 0.517 a 0.842 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.648sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 51 tr: l 0.409 a 0.860 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.077442 17.612sec(train) 3.831sec(infer)\n",
      "Epoch 51 tst: l 0.514 a 0.840 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.764sec\n",
      "Epoch 52 tr: l 0.406 a 0.861 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.077055 17.192sec(train) 4.369sec(infer)\n",
      "Epoch 52 tst: l 0.512 a 0.843 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.914sec\n",
      "Epoch 53 tr: l 0.402 a 0.862 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.076670 15.278sec(train) 4.353sec(infer)\n",
      "Epoch 53 tst: l 0.509 a 0.842 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.816sec\n",
      "Epoch 54 tr: l 0.400 a 0.863 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.076286 17.383sec(train) 2.896sec(infer)\n",
      "Epoch 54 tst: l 0.507 a 0.844 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.793sec\n",
      "Epoch 55 tr: l 0.396 a 0.864 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.075905 18.624sec(train) 2.599sec(infer)\n",
      "Epoch 55 tst: l 0.505 a 0.844 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.715sec\n",
      "Epoch 56 tr: l 0.394 a 0.865 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.075525 18.328sec(train) 3.731sec(infer)\n",
      "Epoch 56 tst: l 0.503 a 0.845 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.641sec\n",
      "Epoch 57 tr: l 0.391 a 0.865 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.075148 17.463sec(train) 4.173sec(infer)\n",
      "Epoch 57 tst: l 0.501 a 0.845 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.787sec\n",
      "Epoch 58 tr: l 0.389 a 0.866 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.074772 16.771sec(train) 3.981sec(infer)\n",
      "Epoch 58 tst: l 0.499 a 0.846 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.744sec\n",
      "Epoch 59 tr: l 0.386 a 0.867 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.074398 16.834sec(train) 3.773sec(infer)\n",
      "Epoch 59 tst: l 0.497 a 0.846 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.769sec\n",
      "Epoch 60 tr: l 0.384 a 0.867 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.074026 16.918sec(train) 3.899sec(infer)\n",
      "Epoch 60 tst: l 0.496 a 0.848 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.897sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 61 tr: l 0.382 a 0.868 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.073656 17.529sec(train) 3.718sec(infer)\n",
      "Epoch 61 tst: l 0.494 a 0.846 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.804sec\n",
      "Epoch 62 tr: l 0.380 a 0.869 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.073288 17.949sec(train) 3.728sec(infer)\n",
      "Epoch 62 tst: l 0.493 a 0.848 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.586sec\n",
      "Epoch 63 tr: l 0.378 a 0.869 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.072921 17.487sec(train) 3.383sec(infer)\n",
      "Epoch 63 tst: l 0.492 a 0.847 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.732sec\n",
      "Epoch 64 tr: l 0.376 a 0.870 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.072557 17.466sec(train) 3.302sec(infer)\n",
      "Epoch 64 tst: l 0.490 a 0.849 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.834sec\n",
      "Epoch 65 tr: l 0.374 a 0.870 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.072194 17.559sec(train) 3.853sec(infer)\n",
      "Epoch 65 tst: l 0.489 a 0.848 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.779sec\n",
      "Epoch 66 tr: l 0.372 a 0.871 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.071833 17.674sec(train) 4.194sec(infer)\n",
      "Epoch 66 tst: l 0.487 a 0.850 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.780sec\n",
      "Epoch 67 tr: l 0.370 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.071474 16.281sec(train) 4.175sec(infer)\n",
      "Epoch 67 tst: l 0.486 a 0.849 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.882sec\n",
      "Epoch 68 tr: l 0.368 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.071116 17.501sec(train) 3.594sec(infer)\n",
      "Epoch 68 tst: l 0.484 a 0.850 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.648sec\n",
      "Epoch 69 tr: l 0.366 a 0.873 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.070761 17.981sec(train) 3.179sec(infer)\n",
      "Epoch 69 tst: l 0.483 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.644sec\n",
      "Epoch 70 tr: l 0.364 a 0.873 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.070407 17.223sec(train) 3.949sec(infer)\n",
      "Epoch 70 tst: l 0.482 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.890sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 71 tr: l 0.362 a 0.874 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.070055 16.500sec(train) 4.341sec(infer)\n",
      "Epoch 71 tst: l 0.481 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.904sec\n",
      "Epoch 72 tr: l 0.360 a 0.874 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.069705 16.783sec(train) 4.114sec(infer)\n",
      "Epoch 72 tst: l 0.480 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.910sec\n",
      "Epoch 73 tr: l 0.358 a 0.874 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.069356 17.256sec(train) 3.182sec(infer)\n",
      "Epoch 73 tst: l 0.478 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.743sec\n",
      "Epoch 74 tr: l 0.357 a 0.875 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.069009 17.876sec(train) 2.917sec(infer)\n",
      "Epoch 74 tst: l 0.478 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.651sec\n",
      "Epoch 75 tr: l 0.355 a 0.875 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.068664 18.160sec(train) 3.358sec(infer)\n",
      "Epoch 75 tst: l 0.476 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.652sec\n",
      "Epoch 76 tr: l 0.353 a 0.876 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.068321 17.648sec(train) 4.058sec(infer)\n",
      "Epoch 76 tst: l 0.476 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.750sec\n",
      "Epoch 77 tr: l 0.352 a 0.876 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.067979 17.259sec(train) 4.224sec(infer)\n",
      "Epoch 77 tst: l 0.474 a 0.853 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.730sec\n",
      "Epoch 78 tr: l 0.350 a 0.877 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.067639 16.784sec(train) 3.667sec(infer)\n",
      "Epoch 78 tst: l 0.474 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.785sec\n",
      "Epoch 79 tr: l 0.349 a 0.877 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.067301 16.840sec(train) 3.942sec(infer)\n",
      "Epoch 79 tst: l 0.472 a 0.854 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.891sec\n",
      "Epoch 80 tr: l 0.347 a 0.878 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.066965 16.574sec(train) 4.270sec(infer)\n",
      "Epoch 80 tst: l 0.472 a 0.853 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.916sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 81 tr: l 0.346 a 0.878 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.066630 17.489sec(train) 3.602sec(infer)\n",
      "Epoch 81 tst: l 0.471 a 0.854 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.897sec\n",
      "Epoch 82 tr: l 0.344 a 0.878 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.066297 18.292sec(train) 2.411sec(infer)\n",
      "Epoch 82 tst: l 0.470 a 0.854 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.534sec\n",
      "Epoch 83 tr: l 0.343 a 0.878 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.065965 18.560sec(train) 3.123sec(infer)\n",
      "Epoch 83 tst: l 0.469 a 0.855 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.520sec\n",
      "Epoch 84 tr: l 0.341 a 0.879 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.065635 17.577sec(train) 4.160sec(infer)\n",
      "Epoch 84 tst: l 0.468 a 0.854 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.845sec\n",
      "Epoch 85 tr: l 0.340 a 0.879 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.065307 16.618sec(train) 4.297sec(infer)\n",
      "Epoch 85 tst: l 0.467 a 0.855 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.878sec\n",
      "Epoch 86 tr: l 0.339 a 0.880 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064981 16.483sec(train) 4.271sec(infer)\n",
      "Epoch 86 tst: l 0.467 a 0.855 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.728sec\n",
      "Epoch 87 tr: l 0.337 a 0.880 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064656 16.847sec(train) 3.639sec(infer)\n",
      "Epoch 87 tst: l 0.466 a 0.855 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.775sec\n",
      "Epoch 88 tr: l 0.336 a 0.881 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064333 17.274sec(train) 3.298sec(infer)\n",
      "Epoch 88 tst: l 0.465 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.898sec\n",
      "Epoch 89 tr: l 0.335 a 0.881 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064011 17.830sec(train) 3.667sec(infer)\n",
      "Epoch 89 tst: l 0.464 a 0.855 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.761sec\n",
      "Epoch 90 tr: l 0.333 a 0.881 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.063691 17.792sec(train) 3.913sec(infer)\n",
      "Epoch 90 tst: l 0.464 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.828sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 91 tr: l 0.332 a 0.882 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.063372 17.534sec(train) 3.216sec(infer)\n",
      "Epoch 91 tst: l 0.463 a 0.855 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.694sec\n",
      "Epoch 92 tr: l 0.331 a 0.882 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.063056 17.529sec(train) 3.441sec(infer)\n",
      "Epoch 92 tst: l 0.462 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.666sec\n",
      "Epoch 93 tr: l 0.329 a 0.882 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.062740 17.077sec(train) 4.123sec(infer)\n",
      "Epoch 93 tst: l 0.462 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.853sec\n",
      "Epoch 94 tr: l 0.328 a 0.883 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.062427 16.781sec(train) 4.206sec(infer)\n",
      "Epoch 94 tst: l 0.461 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.893sec\n",
      "Epoch 95 tr: l 0.327 a 0.883 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.062114 17.200sec(train) 3.565sec(infer)\n",
      "Epoch 95 tst: l 0.460 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.643sec\n",
      "Epoch 96 tr: l 0.326 a 0.883 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.061804 17.699sec(train) 3.135sec(infer)\n",
      "Epoch 96 tst: l 0.460 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.654sec\n",
      "Epoch 97 tr: l 0.325 a 0.883 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.061495 17.226sec(train) 3.873sec(infer)\n",
      "Epoch 97 tst: l 0.459 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.893sec\n",
      "Epoch 98 tr: l 0.324 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.061187 16.702sec(train) 4.189sec(infer)\n",
      "Epoch 98 tst: l 0.459 a 0.857 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.890sec\n",
      "Epoch 99 tr: l 0.322 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.060881 16.977sec(train) 3.792sec(infer)\n",
      "Epoch 99 tst: l 0.458 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.916sec\n",
      "Epoch 100 tr: l 0.322 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.006058 17.936sec(train) 3.274sec(infer)\n",
      "Epoch 100 tst: l 0.457 a 0.857 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.681sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 101 tr: l 0.322 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.006027 17.745sec(train) 3.222sec(infer)\n",
      "Epoch 101 tst: l 0.457 a 0.857 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.641sec\n",
      "Epoch 102 tr: l 0.321 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005997 18.010sec(train) 3.482sec(infer)\n",
      "Epoch 102 tst: l 0.457 a 0.857 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.732sec\n",
      "Epoch 103 tr: l 0.321 a 0.885 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005967 17.700sec(train) 4.061sec(infer)\n",
      "Epoch 103 tst: l 0.457 a 0.857 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.757sec\n",
      "Epoch 104 tr: l 0.321 a 0.885 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005937 16.675sec(train) 4.279sec(infer)\n",
      "Epoch 104 tst: l 0.457 a 0.857 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.721sec\n",
      "Epoch 105 tr: l 0.321 a 0.885 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005908 16.683sec(train) 3.675sec(infer)\n",
      "Epoch 105 tst: l 0.457 a 0.857 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.797sec\n",
      "Epoch 106 tr: l 0.321 a 0.885 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005878 16.724sec(train) 3.875sec(infer)\n",
      "Epoch 106 tst: l 0.457 a 0.857 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.880sec\n",
      "Epoch 107 tr: l 0.321 a 0.885 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005849 16.821sec(train) 4.042sec(infer)\n",
      "Epoch 107 tst: l 0.456 a 0.857 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.913sec\n",
      "Epoch 108 tr: l 0.320 a 0.885 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005820 17.841sec(train) 3.322sec(infer)\n",
      "Epoch 108 tst: l 0.456 a 0.857 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.818sec\n",
      "Epoch 109 tr: l 0.320 a 0.885 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005790 18.632sec(train) 2.578sec(infer)\n",
      "Epoch 109 tst: l 0.456 a 0.857 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.479sec\n",
      "Epoch 110 tr: l 0.320 a 0.885 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005762 18.453sec(train) 3.440sec(infer)\n",
      "Epoch 110 tst: l 0.456 a 0.857 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.533sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 111 tr: l 0.320 a 0.885 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005733 17.238sec(train) 4.172sec(infer)\n",
      "Epoch 111 tst: l 0.456 a 0.857 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.901sec\n",
      "Epoch 112 tr: l 0.320 a 0.885 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005704 16.549sec(train) 4.326sec(infer)\n",
      "Epoch 112 tst: l 0.456 a 0.857 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.897sec\n",
      "Epoch 113 tr: l 0.320 a 0.885 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005676 16.731sec(train) 4.224sec(infer)\n",
      "Epoch 113 tst: l 0.456 a 0.857 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.727sec\n",
      "Epoch 114 tr: l 0.320 a 0.885 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005647 17.028sec(train) 3.726sec(infer)\n",
      "Epoch 114 tst: l 0.456 a 0.857 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.800sec\n",
      "Epoch 115 tr: l 0.320 a 0.885 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005619 17.178sec(train) 3.372sec(infer)\n",
      "Epoch 115 tst: l 0.456 a 0.857 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.874sec\n",
      "Epoch 116 tr: l 0.319 a 0.885 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005591 18.217sec(train) 3.380sec(infer)\n",
      "Epoch 116 tst: l 0.456 a 0.857 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.762sec\n",
      "Epoch 117 tr: l 0.319 a 0.885 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005563 18.081sec(train) 3.706sec(infer)\n",
      "Epoch 117 tst: l 0.456 a 0.857 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.682sec\n",
      "Epoch 118 tr: l 0.319 a 0.885 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005535 17.534sec(train) 3.406sec(infer)\n",
      "Epoch 118 tst: l 0.456 a 0.857 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.663sec\n",
      "Epoch 119 tr: l 0.319 a 0.885 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005507 17.373sec(train) 3.718sec(infer)\n",
      "Epoch 119 tst: l 0.456 a 0.857 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.690sec\n",
      "Epoch 120 tr: l 0.319 a 0.885 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005480 16.944sec(train) 4.157sec(infer)\n",
      "Epoch 120 tst: l 0.456 a 0.857 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.897sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 121 tr: l 0.319 a 0.885 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005452 17.087sec(train) 4.267sec(infer)\n",
      "Epoch 121 tst: l 0.456 a 0.857 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.911sec\n",
      "Epoch 122 tr: l 0.319 a 0.885 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005425 17.344sec(train) 3.456sec(infer)\n",
      "Epoch 122 tst: l 0.455 a 0.857 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.716sec\n",
      "Epoch 123 tr: l 0.319 a 0.885 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005398 17.928sec(train) 3.139sec(infer)\n",
      "Epoch 123 tst: l 0.455 a 0.857 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.649sec\n",
      "Epoch 124 tr: l 0.318 a 0.885 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005371 17.370sec(train) 3.951sec(infer)\n",
      "Epoch 124 tst: l 0.455 a 0.857 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.861sec\n",
      "Epoch 125 tr: l 0.318 a 0.885 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005344 17.096sec(train) 3.980sec(infer)\n",
      "Epoch 125 tst: l 0.455 a 0.857 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.914sec\n",
      "Epoch 126 tr: l 0.318 a 0.885 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005318 17.417sec(train) 3.771sec(infer)\n",
      "Epoch 126 tst: l 0.455 a 0.858 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.769sec\n",
      "Epoch 127 tr: l 0.318 a 0.885 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005291 17.615sec(train) 3.252sec(infer)\n",
      "Epoch 127 tst: l 0.455 a 0.858 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.668sec\n",
      "Epoch 128 tr: l 0.318 a 0.885 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005264 17.490sec(train) 3.562sec(infer)\n",
      "Epoch 128 tst: l 0.455 a 0.858 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.743sec\n",
      "Epoch 129 tr: l 0.318 a 0.885 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005238 17.704sec(train) 3.636sec(infer)\n",
      "Epoch 129 tst: l 0.455 a 0.857 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.768sec\n",
      "Epoch 130 tr: l 0.318 a 0.886 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005212 17.778sec(train) 4.034sec(infer)\n",
      "Epoch 130 tst: l 0.455 a 0.858 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.750sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 131 tr: l 0.318 a 0.886 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005186 17.263sec(train) 3.969sec(infer)\n",
      "Epoch 131 tst: l 0.455 a 0.858 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.766sec\n",
      "Epoch 132 tr: l 0.318 a 0.886 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005160 16.784sec(train) 3.767sec(infer)\n",
      "Epoch 132 tst: l 0.455 a 0.858 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.768sec\n",
      "Epoch 133 tr: l 0.317 a 0.886 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005134 16.773sec(train) 4.013sec(infer)\n",
      "Epoch 133 tst: l 0.455 a 0.858 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.901sec\n",
      "Epoch 134 tr: l 0.317 a 0.886 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005108 17.012sec(train) 3.902sec(infer)\n",
      "Epoch 134 tst: l 0.455 a 0.857 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.897sec\n",
      "Epoch 135 tr: l 0.317 a 0.886 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005083 17.791sec(train) 3.479sec(infer)\n",
      "Epoch 135 tst: l 0.455 a 0.857 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.606sec\n",
      "Epoch 136 tr: l 0.317 a 0.886 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005058 18.380sec(train) 2.545sec(infer)\n",
      "Epoch 136 tst: l 0.455 a 0.858 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.544sec\n",
      "Epoch 137 tr: l 0.317 a 0.886 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005032 18.068sec(train) 3.459sec(infer)\n",
      "Epoch 137 tst: l 0.455 a 0.857 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.701sec\n",
      "Epoch 138 tr: l 0.317 a 0.886 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005007 17.129sec(train) 4.299sec(infer)\n",
      "Epoch 138 tst: l 0.455 a 0.858 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.895sec\n",
      "Epoch 139 tr: l 0.317 a 0.886 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004982 16.643sec(train) 4.358sec(infer)\n",
      "Epoch 139 tst: l 0.454 a 0.858 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.892sec\n",
      "Epoch 140 tr: l 0.317 a 0.886 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004957 16.715sec(train) 4.049sec(infer)\n",
      "Epoch 140 tst: l 0.454 a 0.858 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.742sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 141 tr: l 0.317 a 0.886 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004932 16.734sec(train) 3.724sec(infer)\n",
      "Epoch 141 tst: l 0.454 a 0.858 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.799sec\n",
      "Epoch 142 tr: l 0.316 a 0.886 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004908 17.453sec(train) 3.606sec(infer)\n",
      "Epoch 142 tst: l 0.454 a 0.858 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.862sec\n",
      "Epoch 143 tr: l 0.316 a 0.886 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004883 18.037sec(train) 3.125sec(infer)\n",
      "Epoch 143 tst: l 0.454 a 0.858 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.755sec\n",
      "Epoch 144 tr: l 0.316 a 0.886 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004859 18.582sec(train) 3.445sec(infer)\n",
      "Epoch 144 tst: l 0.454 a 0.857 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.452sec\n",
      "Epoch 145 tr: l 0.316 a 0.886 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004834 17.656sec(train) 3.563sec(infer)\n",
      "Epoch 145 tst: l 0.454 a 0.857 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.665sec\n",
      "Epoch 146 tr: l 0.316 a 0.886 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004810 17.116sec(train) 3.822sec(infer)\n",
      "Epoch 146 tst: l 0.454 a 0.858 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.899sec\n",
      "Epoch 147 tr: l 0.316 a 0.886 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004786 16.710sec(train) 4.348sec(infer)\n",
      "Epoch 147 tst: l 0.454 a 0.858 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.894sec\n",
      "Epoch 148 tr: l 0.316 a 0.886 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004762 16.752sec(train) 4.358sec(infer)\n",
      "Epoch 148 tst: l 0.454 a 0.858 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.902sec\n",
      "Epoch 149 tr: l 0.316 a 0.886 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004738 17.275sec(train) 3.407sec(infer)\n",
      "Epoch 149 tst: l 0.454 a 0.858 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.758sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "---train cluster Ended in 0.91 hour (3277.875 sec) \n",
      "---------------------------------IFCA, lr: 0.1, seed: 6930---------------------------------\n",
      "config: {'m': 100, 'm_test': 20, 'p': 2, 'n': 1500, 'uneven': True, 'local_model_init': False, 'Gp': 0.15, 'graph': 'er', 'agg': 'seq', 'h1': 512, 'num_epochs': 150, 'batch_size': 100, 'tau': 5, 'lr': 0.1, 'data_seed': 6930, 'train_seed': 6930, 'config_override': '', 'project_dir': 'output_dfca_gi'}\n",
      "Using device: cuda:3\n",
      "Epoch -1 tr: l 3.868 a 0.026 clct[np.int64(82), np.int64(18)] cl_acc 0.620  3.846sec\n",
      "Epoch -1 tst: l 3.867 a 0.026 clct[np.int64(17), np.int64(3)] cl_acc 0.550  0.887sec\n",
      "Epoch 0 tr: l 3.312 a 0.218 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.100000 16.927sec(train) 4.197sec(infer)\n",
      "Epoch 0 tst: l 3.342 a 0.217 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.862sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 1 tr: l 2.417 a 0.511 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.099500 17.363sec(train) 3.723sec(infer)\n",
      "Epoch 1 tst: l 2.449 a 0.507 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.832sec\n",
      "Epoch 2 tr: l 1.784 a 0.611 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.099003 17.674sec(train) 3.346sec(infer)\n",
      "Epoch 2 tst: l 1.815 a 0.608 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.594sec\n",
      "Epoch 3 tr: l 1.425 a 0.661 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.098507 17.673sec(train) 3.660sec(infer)\n",
      "Epoch 3 tst: l 1.455 a 0.658 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.658sec\n",
      "Epoch 4 tr: l 1.240 a 0.676 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.098015 17.304sec(train) 3.698sec(infer)\n",
      "Epoch 4 tst: l 1.275 a 0.670 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.871sec\n",
      "Epoch 5 tr: l 1.135 a 0.689 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.097525 17.646sec(train) 3.757sec(infer)\n",
      "Epoch 5 tst: l 1.169 a 0.681 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.770sec\n",
      "Epoch 6 tr: l 1.016 a 0.712 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.097037 17.527sec(train) 3.896sec(infer)\n",
      "Epoch 6 tst: l 1.055 a 0.707 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.588sec\n",
      "Epoch 7 tr: l 0.936 a 0.735 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.096552 17.406sec(train) 3.573sec(infer)\n",
      "Epoch 7 tst: l 0.977 a 0.728 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.726sec\n",
      "Epoch 8 tr: l 0.870 a 0.746 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.096069 17.537sec(train) 3.333sec(infer)\n",
      "Epoch 8 tst: l 0.915 a 0.741 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.809sec\n",
      "Epoch 9 tr: l 0.828 a 0.758 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.095589 18.055sec(train) 3.886sec(infer)\n",
      "Epoch 9 tst: l 0.873 a 0.750 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.742sec\n",
      "Epoch 10 tr: l 0.786 a 0.764 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.095111 17.441sec(train) 4.375sec(infer)\n",
      "Epoch 10 tst: l 0.837 a 0.758 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.751sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 11 tr: l 0.752 a 0.775 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.094635 16.836sec(train) 3.793sec(infer)\n",
      "Epoch 11 tst: l 0.801 a 0.767 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.775sec\n",
      "Epoch 12 tr: l 0.716 a 0.782 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.094162 16.872sec(train) 3.719sec(infer)\n",
      "Epoch 12 tst: l 0.772 a 0.773 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.883sec\n",
      "Epoch 13 tr: l 0.695 a 0.787 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.093691 17.011sec(train) 3.826sec(infer)\n",
      "Epoch 13 tst: l 0.747 a 0.780 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.863sec\n",
      "Epoch 14 tr: l 0.666 a 0.795 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.093223 17.802sec(train) 3.601sec(infer)\n",
      "Epoch 14 tst: l 0.726 a 0.785 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.758sec\n",
      "Epoch 15 tr: l 0.652 a 0.798 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.092757 18.597sec(train) 2.795sec(infer)\n",
      "Epoch 15 tst: l 0.708 a 0.791 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.536sec\n",
      "Epoch 16 tr: l 0.629 a 0.804 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.092293 18.240sec(train) 3.256sec(infer)\n",
      "Epoch 16 tst: l 0.692 a 0.793 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.576sec\n",
      "Epoch 17 tr: l 0.617 a 0.806 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.091832 17.415sec(train) 4.064sec(infer)\n",
      "Epoch 17 tst: l 0.677 a 0.797 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.851sec\n",
      "Epoch 18 tr: l 0.600 a 0.811 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.091372 16.680sec(train) 4.380sec(infer)\n",
      "Epoch 18 tst: l 0.666 a 0.801 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.870sec\n",
      "Epoch 19 tr: l 0.589 a 0.812 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.090916 16.556sec(train) 4.339sec(infer)\n",
      "Epoch 19 tst: l 0.654 a 0.802 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.751sec\n",
      "Epoch 20 tr: l 0.576 a 0.816 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.090461 16.934sec(train) 3.725sec(infer)\n",
      "Epoch 20 tst: l 0.644 a 0.805 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.772sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 21 tr: l 0.567 a 0.817 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.090009 17.185sec(train) 3.467sec(infer)\n",
      "Epoch 21 tst: l 0.637 a 0.807 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.861sec\n",
      "Epoch 22 tr: l 0.556 a 0.821 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.089559 18.030sec(train) 3.152sec(infer)\n",
      "Epoch 22 tst: l 0.626 a 0.809 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.751sec\n",
      "Epoch 23 tr: l 0.545 a 0.823 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.089111 18.600sec(train) 3.457sec(infer)\n",
      "Epoch 23 tst: l 0.616 a 0.811 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.623sec\n",
      "Epoch 24 tr: l 0.536 a 0.826 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.088665 17.944sec(train) 3.580sec(infer)\n",
      "Epoch 24 tst: l 0.610 a 0.812 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.616sec\n",
      "Epoch 25 tr: l 0.528 a 0.828 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.088222 17.139sec(train) 3.792sec(infer)\n",
      "Epoch 25 tst: l 0.600 a 0.815 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.747sec\n",
      "Epoch 26 tr: l 0.520 a 0.831 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.087781 16.879sec(train) 4.178sec(infer)\n",
      "Epoch 26 tst: l 0.597 a 0.816 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.882sec\n",
      "Epoch 27 tr: l 0.515 a 0.832 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.087342 16.767sec(train) 4.418sec(infer)\n",
      "Epoch 27 tst: l 0.589 a 0.819 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.886sec\n",
      "Epoch 28 tr: l 0.504 a 0.835 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.086905 17.278sec(train) 3.835sec(infer)\n",
      "Epoch 28 tst: l 0.583 a 0.819 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.714sec\n",
      "Epoch 29 tr: l 0.497 a 0.836 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.086471 17.863sec(train) 3.017sec(infer)\n",
      "Epoch 29 tst: l 0.574 a 0.822 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.643sec\n",
      "Epoch 30 tr: l 0.490 a 0.838 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.086038 17.932sec(train) 3.540sec(infer)\n",
      "Epoch 30 tst: l 0.573 a 0.822 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.722sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 31 tr: l 0.487 a 0.839 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.085608 17.561sec(train) 3.849sec(infer)\n",
      "Epoch 31 tst: l 0.565 a 0.823 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.874sec\n",
      "Epoch 32 tr: l 0.483 a 0.839 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.085180 17.608sec(train) 3.777sec(infer)\n",
      "Epoch 32 tst: l 0.568 a 0.823 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.766sec\n",
      "Epoch 33 tr: l 0.478 a 0.840 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.084754 17.387sec(train) 3.418sec(infer)\n",
      "Epoch 33 tst: l 0.559 a 0.825 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.642sec\n",
      "Epoch 34 tr: l 0.472 a 0.842 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.084331 17.274sec(train) 3.825sec(infer)\n",
      "Epoch 34 tst: l 0.559 a 0.826 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.773sec\n",
      "Epoch 35 tr: l 0.466 a 0.844 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.083909 17.115sec(train) 3.878sec(infer)\n",
      "Epoch 35 tst: l 0.549 a 0.828 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.881sec\n",
      "Epoch 36 tr: l 0.461 a 0.845 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.083489 17.830sec(train) 3.690sec(infer)\n",
      "Epoch 36 tst: l 0.550 a 0.829 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.750sec\n",
      "Epoch 37 tr: l 0.459 a 0.846 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.083072 17.645sec(train) 3.700sec(infer)\n",
      "Epoch 37 tst: l 0.544 a 0.829 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.577sec\n",
      "Epoch 38 tr: l 0.454 a 0.847 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.082657 17.231sec(train) 3.780sec(infer)\n",
      "Epoch 38 tst: l 0.543 a 0.830 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.756sec\n",
      "Epoch 39 tr: l 0.448 a 0.850 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.082243 16.901sec(train) 3.630sec(infer)\n",
      "Epoch 39 tst: l 0.536 a 0.832 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.779sec\n",
      "Epoch 40 tr: l 0.442 a 0.850 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.081832 17.253sec(train) 3.435sec(infer)\n",
      "Epoch 40 tst: l 0.533 a 0.833 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.848sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 41 tr: l 0.438 a 0.852 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.081423 17.468sec(train) 3.749sec(infer)\n",
      "Epoch 41 tst: l 0.528 a 0.834 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.767sec\n",
      "Epoch 42 tr: l 0.434 a 0.853 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.081016 18.038sec(train) 3.582sec(infer)\n",
      "Epoch 42 tst: l 0.527 a 0.834 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.767sec\n",
      "Epoch 43 tr: l 0.432 a 0.853 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.080611 18.013sec(train) 3.159sec(infer)\n",
      "Epoch 43 tst: l 0.522 a 0.835 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.464sec\n",
      "Epoch 44 tr: l 0.431 a 0.853 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.080208 17.718sec(train) 3.595sec(infer)\n",
      "Epoch 44 tst: l 0.527 a 0.835 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.625sec\n",
      "Epoch 45 tr: l 0.429 a 0.852 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.079807 17.015sec(train) 4.193sec(infer)\n",
      "Epoch 45 tst: l 0.521 a 0.835 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.868sec\n",
      "Epoch 46 tr: l 0.424 a 0.855 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.079408 16.524sec(train) 4.424sec(infer)\n",
      "Epoch 46 tst: l 0.521 a 0.836 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.881sec\n",
      "Epoch 47 tr: l 0.419 a 0.856 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.079010 16.704sec(train) 4.185sec(infer)\n",
      "Epoch 47 tst: l 0.514 a 0.837 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.694sec\n",
      "Epoch 48 tr: l 0.416 a 0.857 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.078615 17.248sec(train) 3.608sec(infer)\n",
      "Epoch 48 tst: l 0.515 a 0.839 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.774sec\n",
      "Epoch 49 tr: l 0.413 a 0.858 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.078222 17.703sec(train) 3.057sec(infer)\n",
      "Epoch 49 tst: l 0.509 a 0.838 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.881sec\n",
      "Epoch 50 tr: l 0.410 a 0.859 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.077831 18.806sec(train) 3.136sec(infer)\n",
      "Epoch 50 tst: l 0.510 a 0.841 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.628sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 51 tr: l 0.408 a 0.859 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.077442 18.416sec(train) 3.836sec(infer)\n",
      "Epoch 51 tst: l 0.505 a 0.839 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.430sec\n",
      "Epoch 52 tr: l 0.404 a 0.860 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.077055 17.166sec(train) 3.771sec(infer)\n",
      "Epoch 52 tst: l 0.506 a 0.841 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.734sec\n",
      "Epoch 53 tr: l 0.401 a 0.861 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.076670 16.832sec(train) 3.933sec(infer)\n",
      "Epoch 53 tst: l 0.500 a 0.841 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.866sec\n",
      "Epoch 54 tr: l 0.397 a 0.862 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.076286 16.606sec(train) 4.393sec(infer)\n",
      "Epoch 54 tst: l 0.501 a 0.842 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.886sec\n",
      "Epoch 55 tr: l 0.395 a 0.863 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.075905 16.652sec(train) 4.274sec(infer)\n",
      "Epoch 55 tst: l 0.496 a 0.842 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.879sec\n",
      "Epoch 56 tr: l 0.392 a 0.863 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.075525 17.367sec(train) 3.158sec(infer)\n",
      "Epoch 56 tst: l 0.497 a 0.843 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.722sec\n",
      "Epoch 57 tr: l 0.390 a 0.864 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.075148 18.092sec(train) 3.105sec(infer)\n",
      "Epoch 57 tst: l 0.493 a 0.843 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.682sec\n",
      "Epoch 58 tr: l 0.389 a 0.864 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.074772 17.808sec(train) 3.781sec(infer)\n",
      "Epoch 58 tst: l 0.495 a 0.843 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.824sec\n",
      "Epoch 59 tr: l 0.387 a 0.865 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.074398 17.790sec(train) 3.787sec(infer)\n",
      "Epoch 59 tst: l 0.491 a 0.843 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.776sec\n",
      "Epoch 60 tr: l 0.384 a 0.866 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.074026 17.486sec(train) 3.558sec(infer)\n",
      "Epoch 60 tst: l 0.491 a 0.845 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.633sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 61 tr: l 0.381 a 0.867 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.073656 17.169sec(train) 3.843sec(infer)\n",
      "Epoch 61 tst: l 0.487 a 0.844 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.747sec\n",
      "Epoch 62 tr: l 0.380 a 0.867 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.073288 14.144sec(train) 2.853sec(infer)\n",
      "Epoch 62 tst: l 0.487 a 0.845 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.656sec\n",
      "Epoch 63 tr: l 0.379 a 0.867 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.072921 14.461sec(train) 3.668sec(infer)\n",
      "Epoch 63 tst: l 0.486 a 0.844 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.774sec\n",
      "Epoch 64 tr: l 0.377 a 0.867 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.072557 18.124sec(train) 3.397sec(infer)\n",
      "Epoch 64 tst: l 0.485 a 0.846 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.560sec\n",
      "Epoch 65 tr: l 0.374 a 0.868 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.072194 18.156sec(train) 3.093sec(infer)\n",
      "Epoch 65 tst: l 0.483 a 0.844 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.664sec\n",
      "Epoch 66 tr: l 0.372 a 0.869 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.071833 17.647sec(train) 3.569sec(infer)\n",
      "Epoch 66 tst: l 0.482 a 0.847 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.741sec\n",
      "Epoch 67 tr: l 0.370 a 0.869 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.071474 17.061sec(train) 4.350sec(infer)\n",
      "Epoch 67 tst: l 0.480 a 0.846 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.876sec\n",
      "Epoch 68 tr: l 0.368 a 0.870 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.071116 16.687sec(train) 4.390sec(infer)\n",
      "Epoch 68 tst: l 0.479 a 0.848 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.869sec\n",
      "Epoch 69 tr: l 0.366 a 0.871 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.070761 16.923sec(train) 3.557sec(infer)\n",
      "Epoch 69 tst: l 0.478 a 0.847 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.758sec\n",
      "Epoch 70 tr: l 0.364 a 0.871 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.070407 17.751sec(train) 3.239sec(infer)\n",
      "Epoch 70 tst: l 0.476 a 0.848 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.746sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 71 tr: l 0.363 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.070055 17.710sec(train) 3.933sec(infer)\n",
      "Epoch 71 tst: l 0.476 a 0.848 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.757sec\n",
      "Epoch 72 tr: l 0.361 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.069705 17.355sec(train) 4.267sec(infer)\n",
      "Epoch 72 tst: l 0.474 a 0.848 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.843sec\n",
      "Epoch 73 tr: l 0.360 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.069356 17.022sec(train) 3.397sec(infer)\n",
      "Epoch 73 tst: l 0.475 a 0.848 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.749sec\n",
      "Epoch 74 tr: l 0.358 a 0.873 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.069009 17.514sec(train) 3.209sec(infer)\n",
      "Epoch 74 tst: l 0.472 a 0.849 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.664sec\n",
      "Epoch 75 tr: l 0.356 a 0.874 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.068664 17.581sec(train) 3.921sec(infer)\n",
      "Epoch 75 tst: l 0.472 a 0.849 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.754sec\n",
      "Epoch 76 tr: l 0.354 a 0.874 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.068321 17.383sec(train) 4.202sec(infer)\n",
      "Epoch 76 tst: l 0.469 a 0.850 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.821sec\n",
      "Epoch 77 tr: l 0.352 a 0.875 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.067979 17.589sec(train) 3.379sec(infer)\n",
      "Epoch 77 tst: l 0.470 a 0.850 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.590sec\n",
      "Epoch 78 tr: l 0.350 a 0.874 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.067639 18.018sec(train) 3.366sec(infer)\n",
      "Epoch 78 tst: l 0.467 a 0.850 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.629sec\n",
      "Epoch 79 tr: l 0.349 a 0.876 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.067301 15.986sec(train) 4.102sec(infer)\n",
      "Epoch 79 tst: l 0.468 a 0.850 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.870sec\n",
      "Epoch 80 tr: l 0.347 a 0.875 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.066965 16.415sec(train) 4.387sec(infer)\n",
      "Epoch 80 tst: l 0.465 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.882sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 81 tr: l 0.346 a 0.876 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.066630 17.480sec(train) 3.671sec(infer)\n",
      "Epoch 81 tst: l 0.466 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.709sec\n",
      "Epoch 82 tr: l 0.344 a 0.876 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.066297 18.330sec(train) 2.502sec(infer)\n",
      "Epoch 82 tst: l 0.463 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.649sec\n",
      "Epoch 83 tr: l 0.343 a 0.877 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.065965 18.602sec(train) 3.063sec(infer)\n",
      "Epoch 83 tst: l 0.464 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.627sec\n",
      "Epoch 84 tr: l 0.342 a 0.877 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.065635 17.751sec(train) 4.055sec(infer)\n",
      "Epoch 84 tst: l 0.462 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.768sec\n",
      "Epoch 85 tr: l 0.341 a 0.877 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.065307 16.991sec(train) 4.357sec(infer)\n",
      "Epoch 85 tst: l 0.463 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.729sec\n",
      "Epoch 86 tr: l 0.340 a 0.878 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064981 16.589sec(train) 3.779sec(infer)\n",
      "Epoch 86 tst: l 0.461 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.771sec\n",
      "Epoch 87 tr: l 0.339 a 0.878 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064656 16.813sec(train) 3.883sec(infer)\n",
      "Epoch 87 tst: l 0.461 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.862sec\n",
      "Epoch 88 tr: l 0.337 a 0.878 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064333 17.443sec(train) 3.785sec(infer)\n",
      "Epoch 88 tst: l 0.460 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.891sec\n",
      "Epoch 89 tr: l 0.336 a 0.879 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064011 17.955sec(train) 3.725sec(infer)\n",
      "Epoch 89 tst: l 0.460 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.734sec\n",
      "Epoch 90 tr: l 0.334 a 0.879 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.063691 17.453sec(train) 3.615sec(infer)\n",
      "Epoch 90 tst: l 0.459 a 0.853 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.651sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 91 tr: l 0.333 a 0.880 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.063372 17.480sec(train) 3.375sec(infer)\n",
      "Epoch 91 tst: l 0.458 a 0.853 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.855sec\n",
      "Epoch 92 tr: l 0.332 a 0.880 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.063056 17.408sec(train) 3.733sec(infer)\n",
      "Epoch 92 tst: l 0.457 a 0.854 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.763sec\n",
      "Epoch 93 tr: l 0.330 a 0.880 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.062740 17.520sec(train) 4.065sec(infer)\n",
      "Epoch 93 tst: l 0.456 a 0.853 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.761sec\n",
      "Epoch 94 tr: l 0.329 a 0.881 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.062427 17.244sec(train) 3.754sec(infer)\n",
      "Epoch 94 tst: l 0.455 a 0.854 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.710sec\n",
      "Epoch 95 tr: l 0.328 a 0.881 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.062114 17.415sec(train) 3.159sec(infer)\n",
      "Epoch 95 tst: l 0.455 a 0.854 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.780sec\n",
      "Epoch 96 tr: l 0.327 a 0.881 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.061804 17.816sec(train) 3.751sec(infer)\n",
      "Epoch 96 tst: l 0.454 a 0.855 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.740sec\n",
      "Epoch 97 tr: l 0.325 a 0.882 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.061495 17.231sec(train) 4.390sec(infer)\n",
      "Epoch 97 tst: l 0.454 a 0.854 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.824sec\n",
      "Epoch 98 tr: l 0.324 a 0.882 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.061187 16.645sec(train) 3.987sec(infer)\n",
      "Epoch 98 tst: l 0.452 a 0.855 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.711sec\n",
      "Epoch 99 tr: l 0.323 a 0.883 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.060881 16.843sec(train) 3.615sec(infer)\n",
      "Epoch 99 tst: l 0.453 a 0.854 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.749sec\n",
      "Epoch 100 tr: l 0.322 a 0.883 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.006058 17.335sec(train) 3.548sec(infer)\n",
      "Epoch 100 tst: l 0.451 a 0.855 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.880sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 101 tr: l 0.322 a 0.883 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.006027 17.845sec(train) 3.610sec(infer)\n",
      "Epoch 101 tst: l 0.451 a 0.855 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.750sec\n",
      "Epoch 102 tr: l 0.322 a 0.883 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005997 18.350sec(train) 3.178sec(infer)\n",
      "Epoch 102 tst: l 0.451 a 0.855 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.472sec\n",
      "Epoch 103 tr: l 0.321 a 0.883 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005967 18.323sec(train) 3.243sec(infer)\n",
      "Epoch 103 tst: l 0.451 a 0.855 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.606sec\n",
      "Epoch 104 tr: l 0.321 a 0.883 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005937 17.609sec(train) 4.062sec(infer)\n",
      "Epoch 104 tst: l 0.451 a 0.855 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.868sec\n",
      "Epoch 105 tr: l 0.321 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005908 16.847sec(train) 4.398sec(infer)\n",
      "Epoch 105 tst: l 0.451 a 0.855 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.889sec\n",
      "Epoch 106 tr: l 0.321 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005878 16.617sec(train) 4.346sec(infer)\n",
      "Epoch 106 tst: l 0.450 a 0.855 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.698sec\n",
      "Epoch 107 tr: l 0.321 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005849 16.796sec(train) 3.648sec(infer)\n",
      "Epoch 107 tst: l 0.450 a 0.855 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.765sec\n",
      "Epoch 108 tr: l 0.321 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005820 17.278sec(train) 3.443sec(infer)\n",
      "Epoch 108 tst: l 0.450 a 0.855 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.851sec\n",
      "Epoch 109 tr: l 0.320 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005790 18.096sec(train) 3.111sec(infer)\n",
      "Epoch 109 tst: l 0.450 a 0.855 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.739sec\n",
      "Epoch 110 tr: l 0.320 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005762 18.525sec(train) 3.520sec(infer)\n",
      "Epoch 110 tst: l 0.450 a 0.855 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.622sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 111 tr: l 0.320 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005733 17.789sec(train) 3.586sec(infer)\n",
      "Epoch 111 tst: l 0.450 a 0.855 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.656sec\n",
      "Epoch 112 tr: l 0.320 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005704 17.083sec(train) 3.850sec(infer)\n",
      "Epoch 112 tst: l 0.450 a 0.855 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.872sec\n",
      "Epoch 113 tr: l 0.320 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005676 16.646sec(train) 4.396sec(infer)\n",
      "Epoch 113 tst: l 0.450 a 0.855 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.880sec\n",
      "Epoch 114 tr: l 0.320 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005647 16.683sec(train) 4.388sec(infer)\n",
      "Epoch 114 tst: l 0.450 a 0.855 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.884sec\n",
      "Epoch 115 tr: l 0.320 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005619 17.182sec(train) 3.313sec(infer)\n",
      "Epoch 115 tst: l 0.450 a 0.855 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.754sec\n",
      "Epoch 116 tr: l 0.320 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005591 17.944sec(train) 3.152sec(infer)\n",
      "Epoch 116 tst: l 0.450 a 0.855 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.631sec\n",
      "Epoch 117 tr: l 0.319 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005563 17.866sec(train) 3.942sec(infer)\n",
      "Epoch 117 tst: l 0.450 a 0.855 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.723sec\n",
      "Epoch 118 tr: l 0.319 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005535 17.755sec(train) 3.794sec(infer)\n",
      "Epoch 118 tst: l 0.450 a 0.855 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.833sec\n",
      "Epoch 119 tr: l 0.319 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005507 17.643sec(train) 3.317sec(infer)\n",
      "Epoch 119 tst: l 0.449 a 0.855 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.609sec\n",
      "Epoch 120 tr: l 0.319 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005480 17.403sec(train) 3.645sec(infer)\n",
      "Epoch 120 tst: l 0.449 a 0.855 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.640sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 121 tr: l 0.319 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005452 16.969sec(train) 4.205sec(infer)\n",
      "Epoch 121 tst: l 0.449 a 0.855 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.871sec\n",
      "Epoch 122 tr: l 0.319 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005425 17.072sec(train) 3.809sec(infer)\n",
      "Epoch 122 tst: l 0.449 a 0.855 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.876sec\n",
      "Epoch 123 tr: l 0.319 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005398 17.649sec(train) 3.466sec(infer)\n",
      "Epoch 123 tst: l 0.449 a 0.855 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.560sec\n",
      "Epoch 124 tr: l 0.318 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005371 17.673sec(train) 3.664sec(infer)\n",
      "Epoch 124 tst: l 0.449 a 0.855 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.642sec\n",
      "Epoch 125 tr: l 0.318 a 0.885 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005344 16.892sec(train) 4.022sec(infer)\n",
      "Epoch 125 tst: l 0.449 a 0.855 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.873sec\n",
      "Epoch 126 tr: l 0.318 a 0.885 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005318 16.721sec(train) 4.181sec(infer)\n",
      "Epoch 126 tst: l 0.449 a 0.855 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.867sec\n",
      "Epoch 127 tr: l 0.318 a 0.885 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005291 17.539sec(train) 3.743sec(infer)\n",
      "Epoch 127 tst: l 0.449 a 0.855 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.681sec\n",
      "Epoch 128 tr: l 0.318 a 0.885 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005264 18.003sec(train) 2.876sec(infer)\n",
      "Epoch 128 tst: l 0.449 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.656sec\n",
      "Epoch 129 tr: l 0.318 a 0.885 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005238 18.244sec(train) 3.113sec(infer)\n",
      "Epoch 129 tst: l 0.449 a 0.855 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.624sec\n",
      "Epoch 130 tr: l 0.318 a 0.885 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005212 17.946sec(train) 3.944sec(infer)\n",
      "Epoch 130 tst: l 0.449 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.744sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 131 tr: l 0.318 a 0.885 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005186 16.800sec(train) 4.365sec(infer)\n",
      "Epoch 131 tst: l 0.449 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.840sec\n",
      "Epoch 132 tr: l 0.318 a 0.885 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005160 16.537sec(train) 3.752sec(infer)\n",
      "Epoch 132 tst: l 0.449 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.771sec\n",
      "Epoch 133 tr: l 0.317 a 0.885 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005134 16.732sec(train) 3.837sec(infer)\n",
      "Epoch 133 tst: l 0.449 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.867sec\n",
      "Epoch 134 tr: l 0.317 a 0.885 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005108 16.385sec(train) 4.188sec(infer)\n",
      "Epoch 134 tst: l 0.449 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.864sec\n",
      "Epoch 135 tr: l 0.317 a 0.885 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005083 17.379sec(train) 3.613sec(infer)\n",
      "Epoch 135 tst: l 0.449 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.880sec\n",
      "Epoch 136 tr: l 0.317 a 0.885 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005058 18.403sec(train) 2.582sec(infer)\n",
      "Epoch 136 tst: l 0.449 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.442sec\n",
      "Epoch 137 tr: l 0.317 a 0.885 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005032 18.875sec(train) 3.058sec(infer)\n",
      "Epoch 137 tst: l 0.448 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.519sec\n",
      "Epoch 138 tr: l 0.317 a 0.885 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005007 17.506sec(train) 4.155sec(infer)\n",
      "Epoch 138 tst: l 0.448 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.831sec\n",
      "Epoch 139 tr: l 0.317 a 0.885 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004982 16.627sec(train) 4.369sec(infer)\n",
      "Epoch 139 tst: l 0.448 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.874sec\n",
      "Epoch 140 tr: l 0.317 a 0.885 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004957 16.443sec(train) 4.208sec(infer)\n",
      "Epoch 140 tst: l 0.448 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.697sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 141 tr: l 0.317 a 0.885 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004932 16.837sec(train) 3.685sec(infer)\n",
      "Epoch 141 tst: l 0.448 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.775sec\n",
      "Epoch 142 tr: l 0.316 a 0.885 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004908 17.261sec(train) 3.339sec(infer)\n",
      "Epoch 142 tst: l 0.448 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.879sec\n",
      "Epoch 143 tr: l 0.316 a 0.885 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004883 17.865sec(train) 3.688sec(infer)\n",
      "Epoch 143 tst: l 0.448 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.745sec\n",
      "Epoch 144 tr: l 0.316 a 0.885 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004859 17.967sec(train) 3.867sec(infer)\n",
      "Epoch 144 tst: l 0.448 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.630sec\n",
      "Epoch 145 tr: l 0.316 a 0.885 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004834 17.587sec(train) 3.114sec(infer)\n",
      "Epoch 145 tst: l 0.448 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.641sec\n",
      "Epoch 146 tr: l 0.316 a 0.885 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004810 17.767sec(train) 3.589sec(infer)\n",
      "Epoch 146 tst: l 0.448 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.741sec\n",
      "Epoch 147 tr: l 0.316 a 0.885 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004786 17.202sec(train) 4.376sec(infer)\n",
      "Epoch 147 tst: l 0.448 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.881sec\n",
      "Epoch 148 tr: l 0.316 a 0.885 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004762 16.869sec(train) 4.177sec(infer)\n",
      "Epoch 148 tst: l 0.448 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.868sec\n",
      "Epoch 149 tr: l 0.316 a 0.885 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004738 18.014sec(train) 3.033sec(infer)\n",
      "Epoch 149 tst: l 0.448 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.710sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "---train cluster Ended in 0.91 hour (3282.774 sec) \n",
      "---------------------------------IFCA, lr: 0.1, seed: 6753---------------------------------\n",
      "config: {'m': 100, 'm_test': 20, 'p': 2, 'n': 1500, 'uneven': True, 'local_model_init': False, 'Gp': 0.15, 'graph': 'er', 'agg': 'seq', 'h1': 512, 'num_epochs': 150, 'batch_size': 100, 'tau': 5, 'lr': 0.1, 'data_seed': 6753, 'train_seed': 6753, 'config_override': '', 'project_dir': 'output_dfca_gi'}\n",
      "Using device: cuda:3\n",
      "Epoch -1 tr: l 3.869 a 0.025 clct[np.int64(27), np.int64(73)] cl_acc 0.730  3.997sec\n",
      "Epoch -1 tst: l 3.872 a 0.024 clct[np.int64(5), np.int64(15)] cl_acc 0.750  0.813sec\n",
      "Epoch 0 tr: l 3.240 a 0.303 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.100000 17.143sec(train) 3.991sec(infer)\n",
      "Epoch 0 tst: l 3.253 a 0.298 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.907sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 1 tr: l 2.368 a 0.526 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.099500 17.498sec(train) 3.710sec(infer)\n",
      "Epoch 1 tst: l 2.387 a 0.521 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.637sec\n",
      "Epoch 2 tr: l 1.771 a 0.612 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.099003 17.795sec(train) 3.553sec(infer)\n",
      "Epoch 2 tst: l 1.794 a 0.609 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.665sec\n",
      "Epoch 3 tr: l 1.453 a 0.643 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.098507 17.136sec(train) 3.976sec(infer)\n",
      "Epoch 3 tst: l 1.477 a 0.637 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.886sec\n",
      "Epoch 4 tr: l 1.283 a 0.656 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.098015 16.842sec(train) 4.341sec(infer)\n",
      "Epoch 4 tst: l 1.315 a 0.652 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.912sec\n",
      "Epoch 5 tr: l 1.125 a 0.696 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.097525 17.189sec(train) 3.989sec(infer)\n",
      "Epoch 5 tst: l 1.151 a 0.687 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.837sec\n",
      "Epoch 6 tr: l 1.021 a 0.717 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.097037 17.578sec(train) 3.110sec(infer)\n",
      "Epoch 6 tst: l 1.060 a 0.708 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.703sec\n",
      "Epoch 7 tr: l 0.933 a 0.737 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.096552 18.114sec(train) 2.940sec(infer)\n",
      "Epoch 7 tst: l 0.964 a 0.728 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.780sec\n",
      "Epoch 8 tr: l 0.873 a 0.750 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.096069 18.061sec(train) 3.716sec(infer)\n",
      "Epoch 8 tst: l 0.915 a 0.741 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.719sec\n",
      "Epoch 9 tr: l 0.818 a 0.762 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.095589 17.491sec(train) 4.352sec(infer)\n",
      "Epoch 9 tst: l 0.854 a 0.753 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.748sec\n",
      "Epoch 10 tr: l 0.786 a 0.769 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.095111 16.671sec(train) 3.914sec(infer)\n",
      "Epoch 10 tst: l 0.828 a 0.761 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.794sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 11 tr: l 0.749 a 0.775 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.094635 13.448sec(train) 3.213sec(infer)\n",
      "Epoch 11 tst: l 0.791 a 0.768 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.673sec\n",
      "Epoch 12 tr: l 0.725 a 0.781 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.094162 13.024sec(train) 3.212sec(infer)\n",
      "Epoch 12 tst: l 0.769 a 0.773 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.672sec\n",
      "Epoch 13 tr: l 0.693 a 0.789 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.093691 13.416sec(train) 2.759sec(infer)\n",
      "Epoch 13 tst: l 0.739 a 0.779 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.665sec\n",
      "Epoch 14 tr: l 0.674 a 0.793 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.093223 14.539sec(train) 1.972sec(infer)\n",
      "Epoch 14 tst: l 0.721 a 0.783 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.484sec\n",
      "Epoch 15 tr: l 0.650 a 0.799 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.092757 15.292sec(train) 2.123sec(infer)\n",
      "Epoch 15 tst: l 0.699 a 0.788 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.415sec\n",
      "Epoch 16 tr: l 0.636 a 0.802 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.092293 14.156sec(train) 3.230sec(infer)\n",
      "Epoch 16 tst: l 0.687 a 0.791 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.582sec\n",
      "Epoch 17 tr: l 0.616 a 0.808 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.091832 13.134sec(train) 3.214sec(infer)\n",
      "Epoch 17 tst: l 0.668 a 0.797 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.674sec\n",
      "Epoch 18 tr: l 0.606 a 0.809 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.091372 12.992sec(train) 3.242sec(infer)\n",
      "Epoch 18 tst: l 0.659 a 0.798 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.664sec\n",
      "Epoch 19 tr: l 0.594 a 0.813 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.090916 13.168sec(train) 3.186sec(infer)\n",
      "Epoch 19 tst: l 0.651 a 0.802 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.674sec\n",
      "Epoch 20 tr: l 0.579 a 0.816 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.090461 13.761sec(train) 2.559sec(infer)\n",
      "Epoch 20 tst: l 0.635 a 0.803 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.658sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 21 tr: l 0.566 a 0.820 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.090009 14.259sec(train) 2.497sec(infer)\n",
      "Epoch 21 tst: l 0.624 a 0.808 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.508sec\n",
      "Epoch 22 tr: l 0.555 a 0.822 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.089559 14.175sec(train) 2.720sec(infer)\n",
      "Epoch 22 tst: l 0.614 a 0.809 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.586sec\n",
      "Epoch 23 tr: l 0.545 a 0.825 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.089111 14.101sec(train) 2.619sec(infer)\n",
      "Epoch 23 tst: l 0.605 a 0.812 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.557sec\n",
      "Epoch 24 tr: l 0.536 a 0.827 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.088665 13.800sec(train) 2.960sec(infer)\n",
      "Epoch 24 tst: l 0.597 a 0.813 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.555sec\n",
      "Epoch 25 tr: l 0.527 a 0.829 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.088222 13.455sec(train) 3.220sec(infer)\n",
      "Epoch 25 tst: l 0.590 a 0.816 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.653sec\n",
      "Epoch 26 tr: l 0.520 a 0.831 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.087781 13.583sec(train) 2.792sec(infer)\n",
      "Epoch 26 tst: l 0.583 a 0.816 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.674sec\n",
      "Epoch 27 tr: l 0.512 a 0.834 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.087342 14.118sec(train) 2.556sec(infer)\n",
      "Epoch 27 tst: l 0.577 a 0.819 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.507sec\n",
      "Epoch 28 tr: l 0.507 a 0.833 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.086905 13.926sec(train) 3.082sec(infer)\n",
      "Epoch 28 tst: l 0.573 a 0.819 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.528sec\n",
      "Epoch 29 tr: l 0.502 a 0.836 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.086471 13.367sec(train) 3.246sec(infer)\n",
      "Epoch 29 tst: l 0.568 a 0.821 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.683sec\n",
      "Epoch 30 tr: l 0.495 a 0.835 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.086038 13.468sec(train) 2.915sec(infer)\n",
      "Epoch 30 tst: l 0.563 a 0.822 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.669sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 31 tr: l 0.488 a 0.839 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.085608 13.895sec(train) 2.646sec(infer)\n",
      "Epoch 31 tst: l 0.556 a 0.824 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.602sec\n",
      "Epoch 32 tr: l 0.482 a 0.839 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.085180 14.177sec(train) 2.521sec(infer)\n",
      "Epoch 32 tst: l 0.552 a 0.825 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.537sec\n",
      "Epoch 33 tr: l 0.476 a 0.842 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.084754 14.557sec(train) 2.430sec(infer)\n",
      "Epoch 33 tst: l 0.546 a 0.826 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.460sec\n",
      "Epoch 34 tr: l 0.472 a 0.841 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.084331 14.269sec(train) 2.723sec(infer)\n",
      "Epoch 34 tst: l 0.544 a 0.827 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.533sec\n",
      "Epoch 35 tr: l 0.467 a 0.845 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.083909 13.656sec(train) 3.234sec(infer)\n",
      "Epoch 35 tst: l 0.539 a 0.827 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.651sec\n",
      "Epoch 36 tr: l 0.462 a 0.844 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.083489 13.060sec(train) 3.227sec(infer)\n",
      "Epoch 36 tst: l 0.535 a 0.829 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.663sec\n",
      "Epoch 37 tr: l 0.456 a 0.847 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.083072 12.965sec(train) 3.208sec(infer)\n",
      "Epoch 37 tst: l 0.530 a 0.830 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.669sec\n",
      "Epoch 38 tr: l 0.452 a 0.847 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.082657 13.333sec(train) 2.859sec(infer)\n",
      "Epoch 38 tst: l 0.526 a 0.832 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.666sec\n",
      "Epoch 39 tr: l 0.447 a 0.849 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.082243 14.309sec(train) 2.134sec(infer)\n",
      "Epoch 39 tst: l 0.523 a 0.832 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.562sec\n",
      "Epoch 40 tr: l 0.443 a 0.849 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.081832 14.948sec(train) 2.075sec(infer)\n",
      "Epoch 40 tst: l 0.520 a 0.832 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.407sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 41 tr: l 0.440 a 0.851 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.081423 14.632sec(train) 2.982sec(infer)\n",
      "Epoch 41 tst: l 0.517 a 0.834 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.396sec\n",
      "Epoch 42 tr: l 0.438 a 0.850 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.081016 13.354sec(train) 3.224sec(infer)\n",
      "Epoch 42 tst: l 0.516 a 0.833 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.674sec\n",
      "Epoch 43 tr: l 0.434 a 0.852 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.080611 12.967sec(train) 3.227sec(infer)\n",
      "Epoch 43 tst: l 0.513 a 0.835 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.667sec\n",
      "Epoch 44 tr: l 0.430 a 0.852 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.080208 13.018sec(train) 3.246sec(infer)\n",
      "Epoch 44 tst: l 0.510 a 0.834 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.663sec\n",
      "Epoch 45 tr: l 0.426 a 0.854 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.079807 13.317sec(train) 3.055sec(infer)\n",
      "Epoch 45 tst: l 0.506 a 0.836 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.666sec\n",
      "Epoch 46 tr: l 0.424 a 0.854 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.079408 13.992sec(train) 2.357sec(infer)\n",
      "Epoch 46 tst: l 0.507 a 0.834 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.544sec\n",
      "Epoch 47 tr: l 0.423 a 0.855 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.079010 14.893sec(train) 2.143sec(infer)\n",
      "Epoch 47 tst: l 0.503 a 0.837 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.521sec\n",
      "Epoch 48 tr: l 0.419 a 0.855 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.078615 14.423sec(train) 2.639sec(infer)\n",
      "Epoch 48 tst: l 0.504 a 0.836 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.545sec\n",
      "Epoch 49 tr: l 0.416 a 0.856 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.078222 13.885sec(train) 3.007sec(infer)\n",
      "Epoch 49 tst: l 0.497 a 0.838 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.537sec\n",
      "Epoch 50 tr: l 0.412 a 0.857 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.077831 13.264sec(train) 3.206sec(infer)\n",
      "Epoch 50 tst: l 0.499 a 0.838 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.668sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 51 tr: l 0.408 a 0.859 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.077442 12.965sec(train) 3.164sec(infer)\n",
      "Epoch 51 tst: l 0.491 a 0.840 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.662sec\n",
      "Epoch 52 tr: l 0.405 a 0.859 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.077055 13.865sec(train) 2.684sec(infer)\n",
      "Epoch 52 tst: l 0.493 a 0.839 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.669sec\n",
      "Epoch 53 tr: l 0.402 a 0.861 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.076670 14.304sec(train) 2.558sec(infer)\n",
      "Epoch 53 tst: l 0.486 a 0.841 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.534sec\n",
      "Epoch 54 tr: l 0.399 a 0.861 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.076286 13.825sec(train) 3.183sec(infer)\n",
      "Epoch 54 tst: l 0.488 a 0.840 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.533sec\n",
      "Epoch 55 tr: l 0.396 a 0.862 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.075905 13.494sec(train) 2.886sec(infer)\n",
      "Epoch 55 tst: l 0.482 a 0.842 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.654sec\n",
      "Epoch 56 tr: l 0.394 a 0.863 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.075525 13.706sec(train) 2.640sec(infer)\n",
      "Epoch 56 tst: l 0.484 a 0.842 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.560sec\n",
      "Epoch 57 tr: l 0.392 a 0.863 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.075148 13.836sec(train) 2.735sec(infer)\n",
      "Epoch 57 tst: l 0.479 a 0.843 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.552sec\n",
      "Epoch 58 tr: l 0.390 a 0.864 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.074772 13.918sec(train) 2.815sec(infer)\n",
      "Epoch 58 tst: l 0.481 a 0.843 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.568sec\n",
      "Epoch 59 tr: l 0.388 a 0.864 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.074398 14.105sec(train) 2.517sec(infer)\n",
      "Epoch 59 tst: l 0.477 a 0.843 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.539sec\n",
      "Epoch 60 tr: l 0.386 a 0.865 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.074026 14.109sec(train) 2.958sec(infer)\n",
      "Epoch 60 tst: l 0.478 a 0.844 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.511sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 61 tr: l 0.383 a 0.865 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.073656 13.280sec(train) 3.233sec(infer)\n",
      "Epoch 61 tst: l 0.474 a 0.844 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.670sec\n",
      "Epoch 62 tr: l 0.381 a 0.866 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.073288 13.332sec(train) 3.220sec(infer)\n",
      "Epoch 62 tst: l 0.474 a 0.846 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.656sec\n",
      "Epoch 63 tr: l 0.378 a 0.867 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.072921 13.207sec(train) 2.989sec(infer)\n",
      "Epoch 63 tst: l 0.471 a 0.845 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.673sec\n",
      "Epoch 64 tr: l 0.377 a 0.868 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.072557 13.829sec(train) 2.608sec(infer)\n",
      "Epoch 64 tst: l 0.471 a 0.846 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.581sec\n",
      "Epoch 65 tr: l 0.375 a 0.867 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.072194 14.750sec(train) 2.054sec(infer)\n",
      "Epoch 65 tst: l 0.469 a 0.844 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.548sec\n",
      "Epoch 66 tr: l 0.373 a 0.868 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.071833 14.686sec(train) 2.529sec(infer)\n",
      "Epoch 66 tst: l 0.469 a 0.847 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.385sec\n",
      "Epoch 67 tr: l 0.371 a 0.869 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.071474 13.835sec(train) 3.204sec(infer)\n",
      "Epoch 67 tst: l 0.466 a 0.846 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.539sec\n",
      "Epoch 68 tr: l 0.369 a 0.870 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.071116 13.063sec(train) 3.231sec(infer)\n",
      "Epoch 68 tst: l 0.465 a 0.848 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.665sec\n",
      "Epoch 69 tr: l 0.367 a 0.870 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.070761 12.977sec(train) 3.216sec(infer)\n",
      "Epoch 69 tst: l 0.464 a 0.847 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.655sec\n",
      "Epoch 70 tr: l 0.365 a 0.870 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.070407 12.966sec(train) 3.201sec(infer)\n",
      "Epoch 70 tst: l 0.463 a 0.847 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.668sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 71 tr: l 0.364 a 0.870 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.070055 13.719sec(train) 2.519sec(infer)\n",
      "Epoch 71 tst: l 0.462 a 0.847 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.652sec\n",
      "Epoch 72 tr: l 0.362 a 0.871 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.069705 14.767sec(train) 1.945sec(infer)\n",
      "Epoch 72 tst: l 0.460 a 0.848 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.435sec\n",
      "Epoch 73 tr: l 0.360 a 0.871 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.069356 15.356sec(train) 2.269sec(infer)\n",
      "Epoch 73 tst: l 0.460 a 0.848 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.406sec\n",
      "Epoch 74 tr: l 0.358 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.069009 14.066sec(train) 3.168sec(infer)\n",
      "Epoch 74 tst: l 0.458 a 0.849 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.567sec\n",
      "Epoch 75 tr: l 0.356 a 0.873 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.068664 13.225sec(train) 3.245sec(infer)\n",
      "Epoch 75 tst: l 0.457 a 0.849 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.652sec\n",
      "Epoch 76 tr: l 0.354 a 0.874 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.068321 13.000sec(train) 3.221sec(infer)\n",
      "Epoch 76 tst: l 0.455 a 0.850 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.671sec\n",
      "Epoch 77 tr: l 0.353 a 0.874 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.067979 13.097sec(train) 3.106sec(infer)\n",
      "Epoch 77 tst: l 0.455 a 0.850 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.659sec\n",
      "Epoch 78 tr: l 0.351 a 0.875 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.067639 13.722sec(train) 2.516sec(infer)\n",
      "Epoch 78 tst: l 0.454 a 0.850 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.579sec\n",
      "Epoch 79 tr: l 0.349 a 0.875 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.067301 14.231sec(train) 2.593sec(infer)\n",
      "Epoch 79 tst: l 0.453 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.519sec\n",
      "Epoch 80 tr: l 0.348 a 0.875 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.066965 13.990sec(train) 2.702sec(infer)\n",
      "Epoch 80 tst: l 0.452 a 0.850 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.648sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 81 tr: l 0.347 a 0.875 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.066630 14.016sec(train) 2.610sec(infer)\n",
      "Epoch 81 tst: l 0.451 a 0.850 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.546sec\n",
      "Epoch 82 tr: l 0.346 a 0.876 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.066297 13.922sec(train) 2.938sec(infer)\n",
      "Epoch 82 tst: l 0.451 a 0.850 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.568sec\n",
      "Epoch 83 tr: l 0.344 a 0.876 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.065965 10.589sec(train) 2.036sec(infer)\n",
      "Epoch 83 tst: l 0.449 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.427sec\n",
      "Epoch 84 tr: l 0.342 a 0.877 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.065635 11.788sec(train) 2.841sec(infer)\n",
      "Epoch 84 tst: l 0.449 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.670sec\n",
      "Epoch 85 tr: l 0.341 a 0.877 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.065307 14.157sec(train) 2.510sec(infer)\n",
      "Epoch 85 tst: l 0.447 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.531sec\n",
      "Epoch 86 tr: l 0.339 a 0.878 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064981 14.342sec(train) 2.714sec(infer)\n",
      "Epoch 86 tst: l 0.447 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.528sec\n",
      "Epoch 87 tr: l 0.338 a 0.878 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064656 14.055sec(train) 2.618sec(infer)\n",
      "Epoch 87 tst: l 0.445 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.621sec\n",
      "Epoch 88 tr: l 0.337 a 0.879 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064333 13.973sec(train) 2.679sec(infer)\n",
      "Epoch 88 tst: l 0.446 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.519sec\n",
      "Epoch 89 tr: l 0.335 a 0.878 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064011 13.612sec(train) 3.110sec(infer)\n",
      "Epoch 89 tst: l 0.444 a 0.853 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.514sec\n",
      "Epoch 90 tr: l 0.334 a 0.879 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.063691 13.364sec(train) 3.075sec(infer)\n",
      "Epoch 90 tst: l 0.444 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.670sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 91 tr: l 0.333 a 0.879 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.063372 13.761sec(train) 2.553sec(infer)\n",
      "Epoch 91 tst: l 0.442 a 0.853 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.582sec\n",
      "Epoch 92 tr: l 0.331 a 0.880 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.063056 14.399sec(train) 2.733sec(infer)\n",
      "Epoch 92 tst: l 0.443 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.533sec\n",
      "Epoch 93 tr: l 0.330 a 0.880 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.062740 13.561sec(train) 3.238sec(infer)\n",
      "Epoch 93 tst: l 0.441 a 0.854 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.641sec\n",
      "Epoch 94 tr: l 0.329 a 0.881 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.062427 13.460sec(train) 3.161sec(infer)\n",
      "Epoch 94 tst: l 0.441 a 0.853 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.683sec\n",
      "Epoch 95 tr: l 0.328 a 0.881 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.062114 13.544sec(train) 2.825sec(infer)\n",
      "Epoch 95 tst: l 0.440 a 0.854 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.660sec\n",
      "Epoch 96 tr: l 0.326 a 0.881 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.061804 13.931sec(train) 2.638sec(infer)\n",
      "Epoch 96 tst: l 0.440 a 0.853 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.557sec\n",
      "Epoch 97 tr: l 0.325 a 0.881 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.061495 14.418sec(train) 2.413sec(infer)\n",
      "Epoch 97 tst: l 0.438 a 0.854 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.541sec\n",
      "Epoch 98 tr: l 0.324 a 0.882 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.061187 14.546sec(train) 2.522sec(infer)\n",
      "Epoch 98 tst: l 0.439 a 0.854 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.507sec\n",
      "Epoch 99 tr: l 0.323 a 0.882 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.060881 14.231sec(train) 2.935sec(infer)\n",
      "Epoch 99 tst: l 0.437 a 0.854 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.526sec\n",
      "Epoch 100 tr: l 0.322 a 0.882 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.006058 13.263sec(train) 3.224sec(infer)\n",
      "Epoch 100 tst: l 0.436 a 0.855 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.667sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 101 tr: l 0.322 a 0.883 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.006027 12.934sec(train) 3.243sec(infer)\n",
      "Epoch 101 tst: l 0.436 a 0.855 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.665sec\n",
      "Epoch 102 tr: l 0.321 a 0.883 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005997 12.962sec(train) 3.107sec(infer)\n",
      "Epoch 102 tst: l 0.436 a 0.855 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.650sec\n",
      "Epoch 103 tr: l 0.321 a 0.883 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005967 13.774sec(train) 2.772sec(infer)\n",
      "Epoch 103 tst: l 0.436 a 0.855 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.659sec\n",
      "Epoch 104 tr: l 0.321 a 0.883 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005937 14.520sec(train) 2.060sec(infer)\n",
      "Epoch 104 tst: l 0.436 a 0.855 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.535sec\n",
      "Epoch 105 tr: l 0.321 a 0.883 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005908 15.074sec(train) 2.088sec(infer)\n",
      "Epoch 105 tst: l 0.436 a 0.855 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.427sec\n",
      "Epoch 106 tr: l 0.321 a 0.883 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005878 12.687sec(train) 3.250sec(infer)\n",
      "Epoch 106 tst: l 0.436 a 0.855 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.631sec\n",
      "Epoch 107 tr: l 0.320 a 0.883 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005849 13.200sec(train) 3.195sec(infer)\n",
      "Epoch 107 tst: l 0.436 a 0.855 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.665sec\n",
      "Epoch 108 tr: l 0.320 a 0.883 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005820 13.423sec(train) 2.917sec(infer)\n",
      "Epoch 108 tst: l 0.436 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.663sec\n",
      "Epoch 109 tr: l 0.320 a 0.883 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005790 13.985sec(train) 2.558sec(infer)\n",
      "Epoch 109 tst: l 0.436 a 0.855 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.547sec\n",
      "Epoch 110 tr: l 0.320 a 0.883 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005762 14.048sec(train) 2.943sec(infer)\n",
      "Epoch 110 tst: l 0.436 a 0.855 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.521sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 111 tr: l 0.320 a 0.883 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005733 13.827sec(train) 2.950sec(infer)\n",
      "Epoch 111 tst: l 0.435 a 0.855 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.679sec\n",
      "Epoch 112 tr: l 0.320 a 0.883 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005704 13.853sec(train) 2.666sec(infer)\n",
      "Epoch 112 tst: l 0.435 a 0.855 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.602sec\n",
      "Epoch 113 tr: l 0.320 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005676 14.247sec(train) 2.649sec(infer)\n",
      "Epoch 113 tst: l 0.435 a 0.855 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.543sec\n",
      "Epoch 114 tr: l 0.319 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005647 13.773sec(train) 2.991sec(infer)\n",
      "Epoch 114 tst: l 0.435 a 0.855 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.536sec\n",
      "Epoch 115 tr: l 0.319 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005619 13.756sec(train) 2.609sec(infer)\n",
      "Epoch 115 tst: l 0.435 a 0.855 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.659sec\n",
      "Epoch 116 tr: l 0.319 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005591 14.217sec(train) 2.624sec(infer)\n",
      "Epoch 116 tst: l 0.435 a 0.855 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.519sec\n",
      "Epoch 117 tr: l 0.319 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005563 13.780sec(train) 3.264sec(infer)\n",
      "Epoch 117 tst: l 0.435 a 0.855 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.591sec\n",
      "Epoch 118 tr: l 0.319 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005535 13.302sec(train) 3.228sec(infer)\n",
      "Epoch 118 tst: l 0.435 a 0.855 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.656sec\n",
      "Epoch 119 tr: l 0.319 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005507 13.156sec(train) 3.111sec(infer)\n",
      "Epoch 119 tst: l 0.435 a 0.855 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.665sec\n",
      "Epoch 120 tr: l 0.319 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005480 13.667sec(train) 2.636sec(infer)\n",
      "Epoch 120 tst: l 0.435 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.673sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 121 tr: l 0.318 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005452 14.261sec(train) 2.247sec(infer)\n",
      "Epoch 121 tst: l 0.435 a 0.855 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.525sec\n",
      "Epoch 122 tr: l 0.318 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005425 14.729sec(train) 2.311sec(infer)\n",
      "Epoch 122 tst: l 0.435 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.405sec\n",
      "Epoch 123 tr: l 0.318 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005398 14.322sec(train) 2.894sec(infer)\n",
      "Epoch 123 tst: l 0.435 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.539sec\n",
      "Epoch 124 tr: l 0.318 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005371 13.430sec(train) 3.239sec(infer)\n",
      "Epoch 124 tst: l 0.435 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.666sec\n",
      "Epoch 125 tr: l 0.318 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005344 13.081sec(train) 3.258sec(infer)\n",
      "Epoch 125 tst: l 0.435 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.668sec\n",
      "Epoch 126 tr: l 0.318 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005318 13.082sec(train) 3.256sec(infer)\n",
      "Epoch 126 tst: l 0.435 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.684sec\n",
      "Epoch 127 tr: l 0.318 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005291 13.320sec(train) 2.979sec(infer)\n",
      "Epoch 127 tst: l 0.435 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.667sec\n",
      "Epoch 128 tr: l 0.318 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005264 14.367sec(train) 2.092sec(infer)\n",
      "Epoch 128 tst: l 0.435 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.666sec\n",
      "Epoch 129 tr: l 0.317 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005238 15.169sec(train) 1.965sec(infer)\n",
      "Epoch 129 tst: l 0.434 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.418sec\n",
      "Epoch 130 tr: l 0.317 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005212 14.548sec(train) 2.935sec(infer)\n",
      "Epoch 130 tst: l 0.434 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.496sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 131 tr: l 0.317 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005186 13.578sec(train) 3.188sec(infer)\n",
      "Epoch 131 tst: l 0.434 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.609sec\n",
      "Epoch 132 tr: l 0.317 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005160 13.089sec(train) 3.246sec(infer)\n",
      "Epoch 132 tst: l 0.434 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.665sec\n",
      "Epoch 133 tr: l 0.317 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005134 13.170sec(train) 3.204sec(infer)\n",
      "Epoch 133 tst: l 0.434 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.680sec\n",
      "Epoch 134 tr: l 0.317 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005108 13.580sec(train) 2.880sec(infer)\n",
      "Epoch 134 tst: l 0.434 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.648sec\n",
      "Epoch 135 tr: l 0.317 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005083 14.049sec(train) 2.538sec(infer)\n",
      "Epoch 135 tst: l 0.434 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.558sec\n",
      "Epoch 136 tr: l 0.317 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005058 14.084sec(train) 2.768sec(infer)\n",
      "Epoch 136 tst: l 0.434 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.519sec\n",
      "Epoch 137 tr: l 0.316 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005032 13.900sec(train) 2.653sec(infer)\n",
      "Epoch 137 tst: l 0.434 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.663sec\n",
      "Epoch 138 tr: l 0.316 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005007 14.068sec(train) 2.624sec(infer)\n",
      "Epoch 138 tst: l 0.434 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.550sec\n",
      "Epoch 139 tr: l 0.316 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004982 13.752sec(train) 2.994sec(infer)\n",
      "Epoch 139 tst: l 0.434 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.562sec\n",
      "Epoch 140 tr: l 0.316 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004957 13.500sec(train) 3.081sec(infer)\n",
      "Epoch 140 tst: l 0.434 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.660sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 141 tr: l 0.316 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004932 13.793sec(train) 2.586sec(infer)\n",
      "Epoch 141 tst: l 0.434 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.637sec\n",
      "Epoch 142 tr: l 0.316 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004908 14.325sec(train) 2.633sec(infer)\n",
      "Epoch 142 tst: l 0.434 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.531sec\n",
      "Epoch 143 tr: l 0.316 a 0.884 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004883 13.740sec(train) 3.236sec(infer)\n",
      "Epoch 143 tst: l 0.434 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.653sec\n",
      "Epoch 144 tr: l 0.316 a 0.885 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004859 13.131sec(train) 3.162sec(infer)\n",
      "Epoch 144 tst: l 0.434 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.662sec\n",
      "Epoch 145 tr: l 0.316 a 0.885 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004834 13.410sec(train) 2.829sec(infer)\n",
      "Epoch 145 tst: l 0.434 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.647sec\n",
      "Epoch 146 tr: l 0.315 a 0.885 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004810 14.048sec(train) 2.627sec(infer)\n",
      "Epoch 146 tst: l 0.434 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.572sec\n",
      "Epoch 147 tr: l 0.315 a 0.885 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004786 14.306sec(train) 2.411sec(infer)\n",
      "Epoch 147 tst: l 0.434 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.542sec\n",
      "Epoch 148 tr: l 0.315 a 0.885 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004762 14.567sec(train) 2.529sec(infer)\n",
      "Epoch 148 tst: l 0.434 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.444sec\n",
      "Epoch 149 tr: l 0.315 a 0.885 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004738 14.053sec(train) 2.957sec(infer)\n",
      "Epoch 149 tst: l 0.434 a 0.856 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.526sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "---train cluster Ended in 0.73 hour (2636.810 sec) \n"
     ]
    }
   ],
   "source": [
    "__.display_outputs()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-19T06:26:17.170727Z",
     "iopub.status.busy": "2025-09-19T06:26:17.170339Z",
     "iopub.status.idle": "2025-09-19T06:26:17.177157Z",
     "shell.execute_reply": "2025-09-19T06:26:17.176293Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "---------------------------------DFCA-LI, lr: 0.1, seed: 6003---------------------------------\n",
      "config: {'m': 100, 'm_test': 20, 'p': 2, 'n': 1500, 'uneven': True, 'local_model_init': True, 'Gp': 0.15, 'graph': 'er', 'agg': 'seq', 'h1': 512, 'num_epochs': 150, 'batch_size': 100, 'tau': 5, 'lr': 0.1, 'data_seed': 6003, 'train_seed': 6003, 'config_override': '', 'project_dir': 'output_dfca_gi'}\n",
      "Using device: cuda:3\n",
      "Epoch -1 tr: l 3.871 a 0.023 clct[np.int64(54), np.int64(46)] cl_acc 0.500  4.986sec\n",
      "Epoch -1 tst: l 3.870 a 0.024 clct[np.int64(10), np.int64(10)] cl_acc 0.600  2.202sec\n",
      "Epoch 0 tr: l 3.751 a 0.209 clct[np.int64(54), np.int64(46)] cl_acc 0.500  lr 0.100000 17.829sec(train) 4.049sec(infer)\n",
      "Epoch 0 tst: l 3.808 a 0.090 clct[np.int64(10), np.int64(10)] cl_acc 0.600  2.513sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 1 tr: l 3.745 a 0.176 clct[np.int64(52), np.int64(48)] cl_acc 0.500  lr 0.099500 17.718sec(train) 4.617sec(infer)\n",
      "Epoch 1 tst: l 3.779 a 0.127 clct[np.int64(9), np.int64(11)] cl_acc 0.550  2.182sec\n",
      "Epoch 2 tr: l 3.697 a 0.145 clct[np.int64(50), np.int64(50)] cl_acc 0.520  lr 0.099003 18.041sec(train) 3.549sec(infer)\n",
      "Epoch 2 tst: l 3.731 a 0.122 clct[np.int64(5), np.int64(15)] cl_acc 0.650  1.943sec\n",
      "Epoch 3 tr: l 3.559 a 0.167 clct[np.int64(49), np.int64(51)] cl_acc 0.530  lr 0.098507 18.436sec(train) 3.700sec(infer)\n",
      "Epoch 3 tst: l 3.613 a 0.148 clct[np.int64(8), np.int64(12)] cl_acc 0.500  2.606sec\n",
      "Epoch 4 tr: l 3.314 a 0.231 clct[np.int64(46), np.int64(54)] cl_acc 0.540  lr 0.098015 18.106sec(train) 4.563sec(infer)\n",
      "Epoch 4 tst: l 3.384 a 0.191 clct[np.int64(8), np.int64(12)] cl_acc 0.500  2.296sec\n",
      "Epoch 5 tr: l 3.023 a 0.284 clct[np.int64(38), np.int64(62)] cl_acc 0.520  lr 0.097525 17.976sec(train) 3.912sec(infer)\n",
      "Epoch 5 tst: l 3.103 a 0.251 clct[np.int64(6), np.int64(14)] cl_acc 0.500  2.478sec\n",
      "Epoch 6 tr: l 2.765 a 0.318 clct[np.int64(35), np.int64(65)] cl_acc 0.530  lr 0.097037 17.934sec(train) 4.411sec(infer)\n",
      "Epoch 6 tst: l 2.858 a 0.285 clct[np.int64(6), np.int64(14)] cl_acc 0.500  2.612sec\n",
      "Epoch 7 tr: l 2.514 a 0.344 clct[np.int64(22), np.int64(78)] cl_acc 0.600  lr 0.096552 18.129sec(train) 3.897sec(infer)\n",
      "Epoch 7 tst: l 2.618 a 0.314 clct[np.int64(6), np.int64(14)] cl_acc 0.500  2.274sec\n",
      "Epoch 8 tr: l 2.304 a 0.405 clct[np.int64(24), np.int64(76)] cl_acc 0.700  lr 0.096069 18.332sec(train) 3.713sec(infer)\n",
      "Epoch 8 tst: l 2.411 a 0.360 clct[np.int64(5), np.int64(15)] cl_acc 0.650  2.187sec\n",
      "Epoch 9 tr: l 2.100 a 0.434 clct[np.int64(31), np.int64(69)] cl_acc 0.770  lr 0.095589 19.004sec(train) 3.489sec(infer)\n",
      "Epoch 9 tst: l 2.201 a 0.415 clct[np.int64(6), np.int64(14)] cl_acc 0.800  2.060sec\n",
      "Epoch 10 tr: l 1.895 a 0.509 clct[np.int64(48), np.int64(52)] cl_acc 0.940  lr 0.095111 19.368sec(train) 2.922sec(infer)\n",
      "Epoch 10 tst: l 2.016 a 0.476 clct[np.int64(8), np.int64(12)] cl_acc 0.900  2.335sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 11 tr: l 1.604 a 0.581 clct[np.int64(49), np.int64(51)] cl_acc 0.990  lr 0.094635 18.624sec(train) 3.936sec(infer)\n",
      "Epoch 11 tst: l 1.727 a 0.557 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.518sec\n",
      "Epoch 12 tr: l 1.403 a 0.615 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.094162 18.676sec(train) 3.458sec(infer)\n",
      "Epoch 12 tst: l 1.497 a 0.601 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.109sec\n",
      "Epoch 13 tr: l 1.274 a 0.642 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.093691 18.938sec(train) 3.555sec(infer)\n",
      "Epoch 13 tst: l 1.366 a 0.630 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.302sec\n",
      "Epoch 14 tr: l 1.150 a 0.669 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.093223 18.751sec(train) 3.959sec(infer)\n",
      "Epoch 14 tst: l 1.224 a 0.660 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.103sec\n",
      "Epoch 15 tr: l 1.049 a 0.692 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.092757 18.787sec(train) 3.255sec(infer)\n",
      "Epoch 15 tst: l 1.140 a 0.678 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.493sec\n",
      "Epoch 16 tr: l 0.986 a 0.704 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.092293 19.137sec(train) 3.611sec(infer)\n",
      "Epoch 16 tst: l 1.085 a 0.687 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.971sec\n",
      "Epoch 17 tr: l 0.915 a 0.722 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.091832 19.025sec(train) 3.688sec(infer)\n",
      "Epoch 17 tst: l 0.991 a 0.710 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.794sec\n",
      "Epoch 18 tr: l 0.872 a 0.734 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.091372 18.325sec(train) 4.051sec(infer)\n",
      "Epoch 18 tst: l 0.975 a 0.720 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.241sec\n",
      "Epoch 19 tr: l 0.828 a 0.743 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.090916 18.192sec(train) 4.655sec(infer)\n",
      "Epoch 19 tst: l 0.924 a 0.727 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.365sec\n",
      "Epoch 20 tr: l 0.788 a 0.750 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.090461 17.848sec(train) 3.985sec(infer)\n",
      "Epoch 20 tst: l 0.884 a 0.738 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.204sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 21 tr: l 0.772 a 0.757 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.090009 17.919sec(train) 4.417sec(infer)\n",
      "Epoch 21 tst: l 0.850 a 0.747 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.597sec\n",
      "Epoch 22 tr: l 0.745 a 0.759 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.089559 17.696sec(train) 4.631sec(infer)\n",
      "Epoch 22 tst: l 0.842 a 0.744 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.721sec\n",
      "Epoch 23 tr: l 0.719 a 0.770 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.089111 18.326sec(train) 3.545sec(infer)\n",
      "Epoch 23 tst: l 0.806 a 0.758 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.147sec\n",
      "Epoch 24 tr: l 0.694 a 0.775 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.088665 18.502sec(train) 4.097sec(infer)\n",
      "Epoch 24 tst: l 0.781 a 0.763 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.612sec\n",
      "Epoch 25 tr: l 0.672 a 0.783 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.088222 17.882sec(train) 4.056sec(infer)\n",
      "Epoch 25 tst: l 0.771 a 0.767 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.317sec\n",
      "Epoch 26 tr: l 0.658 a 0.786 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.087781 17.774sec(train) 4.369sec(infer)\n",
      "Epoch 26 tst: l 0.761 a 0.770 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.628sec\n",
      "Epoch 27 tr: l 0.664 a 0.789 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.087342 17.577sec(train) 4.642sec(infer)\n",
      "Epoch 27 tst: l 0.768 a 0.767 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.433sec\n",
      "Epoch 28 tr: l 0.632 a 0.793 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.086905 17.810sec(train) 4.003sec(infer)\n",
      "Epoch 28 tst: l 0.732 a 0.778 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.354sec\n",
      "Epoch 29 tr: l 0.609 a 0.798 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.086471 17.795sec(train) 4.612sec(infer)\n",
      "Epoch 29 tst: l 0.719 a 0.779 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.255sec\n",
      "Epoch 30 tr: l 0.602 a 0.803 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.086038 18.200sec(train) 3.791sec(infer)\n",
      "Epoch 30 tst: l 0.697 a 0.788 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.833sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 31 tr: l 0.602 a 0.804 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.085608 18.563sec(train) 3.604sec(infer)\n",
      "Epoch 31 tst: l 0.715 a 0.783 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.611sec\n",
      "Epoch 32 tr: l 0.578 a 0.809 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.085180 17.980sec(train) 4.490sec(infer)\n",
      "Epoch 32 tst: l 0.678 a 0.793 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.506sec\n",
      "Epoch 33 tr: l 0.571 a 0.810 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.084754 17.919sec(train) 3.997sec(infer)\n",
      "Epoch 33 tst: l 0.677 a 0.792 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.350sec\n",
      "Epoch 34 tr: l 0.559 a 0.813 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.084331 17.740sec(train) 4.490sec(infer)\n",
      "Epoch 34 tst: l 0.661 a 0.796 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.623sec\n",
      "Epoch 35 tr: l 0.555 a 0.814 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.083909 17.966sec(train) 4.139sec(infer)\n",
      "Epoch 35 tst: l 0.664 a 0.798 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.215sec\n",
      "Epoch 36 tr: l 0.545 a 0.816 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.083489 18.279sec(train) 3.750sec(infer)\n",
      "Epoch 36 tst: l 0.650 a 0.798 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.278sec\n",
      "Epoch 37 tr: l 0.541 a 0.816 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.083072 18.695sec(train) 3.740sec(infer)\n",
      "Epoch 37 tst: l 0.648 a 0.799 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.198sec\n",
      "Epoch 38 tr: l 0.532 a 0.821 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.082657 19.272sec(train) 2.627sec(infer)\n",
      "Epoch 38 tst: l 0.634 a 0.802 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.287sec\n",
      "Epoch 39 tr: l 0.545 a 0.819 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.082243 18.834sec(train) 3.879sec(infer)\n",
      "Epoch 39 tst: l 0.674 a 0.797 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.639sec\n",
      "Epoch 40 tr: l 0.513 a 0.826 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.081832 18.754sec(train) 3.729sec(infer)\n",
      "Epoch 40 tst: l 0.630 a 0.804 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.133sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 41 tr: l 0.510 a 0.826 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.081423 18.952sec(train) 3.469sec(infer)\n",
      "Epoch 41 tst: l 0.620 a 0.806 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.433sec\n",
      "Epoch 42 tr: l 0.501 a 0.828 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.081016 18.857sec(train) 3.916sec(infer)\n",
      "Epoch 42 tst: l 0.612 a 0.808 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.272sec\n",
      "Epoch 43 tr: l 0.502 a 0.829 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.080611 18.949sec(train) 3.245sec(infer)\n",
      "Epoch 43 tst: l 0.608 a 0.810 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.538sec\n",
      "Epoch 44 tr: l 0.497 a 0.830 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.080208 19.303sec(train) 3.553sec(infer)\n",
      "Epoch 44 tst: l 0.614 a 0.809 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.823sec\n",
      "Epoch 45 tr: l 0.490 a 0.832 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.079807 19.299sec(train) 3.664sec(infer)\n",
      "Epoch 45 tst: l 0.603 a 0.811 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.698sec\n",
      "Epoch 46 tr: l 0.484 a 0.833 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.079408 18.786sec(train) 3.798sec(infer)\n",
      "Epoch 46 tst: l 0.596 a 0.813 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.126sec\n",
      "Epoch 47 tr: l 0.479 a 0.835 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.079010 18.352sec(train) 4.688sec(infer)\n",
      "Epoch 47 tst: l 0.593 a 0.813 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.261sec\n",
      "Epoch 48 tr: l 0.479 a 0.834 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.078615 17.989sec(train) 4.095sec(infer)\n",
      "Epoch 48 tst: l 0.588 a 0.816 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.153sec\n",
      "Epoch 49 tr: l 0.470 a 0.838 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.078222 17.947sec(train) 4.384sec(infer)\n",
      "Epoch 49 tst: l 0.583 a 0.817 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.585sec\n",
      "Epoch 50 tr: l 0.470 a 0.837 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.077831 17.717sec(train) 4.611sec(infer)\n",
      "Epoch 50 tst: l 0.585 a 0.818 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.061sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 51 tr: l 0.461 a 0.841 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.077442 17.936sec(train) 3.694sec(infer)\n",
      "Epoch 51 tst: l 0.577 a 0.819 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.915sec\n",
      "Epoch 52 tr: l 0.461 a 0.839 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.077055 18.573sec(train) 3.888sec(infer)\n",
      "Epoch 52 tst: l 0.576 a 0.821 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.537sec\n",
      "Epoch 53 tr: l 0.458 a 0.841 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.076670 18.110sec(train) 3.980sec(infer)\n",
      "Epoch 53 tst: l 0.574 a 0.820 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.286sec\n",
      "Epoch 54 tr: l 0.454 a 0.840 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.076286 17.848sec(train) 4.195sec(infer)\n",
      "Epoch 54 tst: l 0.591 a 0.818 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.618sec\n",
      "Epoch 55 tr: l 0.447 a 0.844 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.075905 17.624sec(train) 4.632sec(infer)\n",
      "Epoch 55 tst: l 0.566 a 0.821 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.606sec\n",
      "Epoch 56 tr: l 0.447 a 0.844 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.075525 17.723sec(train) 3.992sec(infer)\n",
      "Epoch 56 tst: l 0.561 a 0.823 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.294sec\n",
      "Epoch 57 tr: l 0.440 a 0.846 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.075148 17.830sec(train) 4.521sec(infer)\n",
      "Epoch 57 tst: l 0.560 a 0.824 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.598sec\n",
      "Epoch 58 tr: l 0.437 a 0.846 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.074772 17.836sec(train) 4.396sec(infer)\n",
      "Epoch 58 tst: l 0.554 a 0.825 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.694sec\n",
      "Epoch 59 tr: l 0.434 a 0.848 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.074398 18.449sec(train) 3.453sec(infer)\n",
      "Epoch 59 tst: l 0.554 a 0.825 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.294sec\n",
      "Epoch 60 tr: l 0.432 a 0.848 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.074026 18.445sec(train) 4.194sec(infer)\n",
      "Epoch 60 tst: l 0.552 a 0.826 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.609sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 61 tr: l 0.430 a 0.849 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.073656 18.081sec(train) 4.005sec(infer)\n",
      "Epoch 61 tst: l 0.550 a 0.827 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.307sec\n",
      "Epoch 62 tr: l 0.428 a 0.850 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.073288 18.040sec(train) 4.217sec(infer)\n",
      "Epoch 62 tst: l 0.544 a 0.829 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.635sec\n",
      "Epoch 63 tr: l 0.424 a 0.851 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.072921 18.242sec(train) 4.377sec(infer)\n",
      "Epoch 63 tst: l 0.543 a 0.831 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.274sec\n",
      "Epoch 64 tr: l 0.418 a 0.852 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.072557 18.470sec(train) 3.701sec(infer)\n",
      "Epoch 64 tst: l 0.539 a 0.830 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.475sec\n",
      "Epoch 65 tr: l 0.418 a 0.853 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.072194 18.530sec(train) 4.044sec(infer)\n",
      "Epoch 65 tst: l 0.536 a 0.831 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.206sec\n",
      "Epoch 66 tr: l 0.415 a 0.853 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.071833 18.967sec(train) 2.791sec(infer)\n",
      "Epoch 66 tst: l 0.538 a 0.832 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.994sec\n",
      "Epoch 67 tr: l 0.413 a 0.854 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.071474 19.424sec(train) 3.223sec(infer)\n",
      "Epoch 67 tst: l 0.533 a 0.832 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.601sec\n",
      "Epoch 68 tr: l 0.412 a 0.854 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.071116 18.818sec(train) 3.946sec(infer)\n",
      "Epoch 68 tst: l 0.530 a 0.834 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.134sec\n",
      "Epoch 69 tr: l 0.409 a 0.855 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.070761 18.968sec(train) 3.352sec(infer)\n",
      "Epoch 69 tst: l 0.532 a 0.832 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.239sec\n",
      "Epoch 70 tr: l 0.404 a 0.856 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.070407 18.872sec(train) 3.854sec(infer)\n",
      "Epoch 70 tst: l 0.528 a 0.834 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.257sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 71 tr: l 0.400 a 0.857 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.070055 18.928sec(train) 3.528sec(infer)\n",
      "Epoch 71 tst: l 0.526 a 0.834 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.903sec\n",
      "Epoch 72 tr: l 0.396 a 0.859 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.069705 18.865sec(train) 3.798sec(infer)\n",
      "Epoch 72 tst: l 0.525 a 0.835 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.825sec\n",
      "Epoch 73 tr: l 0.398 a 0.859 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.069356 18.903sec(train) 3.836sec(infer)\n",
      "Epoch 73 tst: l 0.523 a 0.835 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.604sec\n",
      "Epoch 74 tr: l 0.396 a 0.859 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.069009 19.047sec(train) 3.303sec(infer)\n",
      "Epoch 74 tst: l 0.520 a 0.837 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.895sec\n",
      "Epoch 75 tr: l 0.394 a 0.859 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.068664 18.466sec(train) 4.629sec(infer)\n",
      "Epoch 75 tst: l 0.520 a 0.836 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.284sec\n",
      "Epoch 76 tr: l 0.390 a 0.860 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.068321 18.057sec(train) 4.401sec(infer)\n",
      "Epoch 76 tst: l 0.517 a 0.837 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.069sec\n",
      "Epoch 77 tr: l 0.390 a 0.861 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.067979 17.929sec(train) 4.191sec(infer)\n",
      "Epoch 77 tst: l 0.514 a 0.838 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.596sec\n",
      "Epoch 78 tr: l 0.388 a 0.861 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.067639 17.789sec(train) 4.643sec(infer)\n",
      "Epoch 78 tst: l 0.513 a 0.839 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.585sec\n",
      "Epoch 79 tr: l 0.383 a 0.863 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.067301 17.704sec(train) 3.944sec(infer)\n",
      "Epoch 79 tst: l 0.510 a 0.838 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.891sec\n",
      "Epoch 80 tr: l 0.385 a 0.862 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.066965 18.113sec(train) 4.146sec(infer)\n",
      "Epoch 80 tst: l 0.512 a 0.839 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.209sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 81 tr: l 0.380 a 0.865 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.066630 18.495sec(train) 3.899sec(infer)\n",
      "Epoch 81 tst: l 0.508 a 0.839 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.184sec\n",
      "Epoch 82 tr: l 0.382 a 0.863 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.066297 18.090sec(train) 3.991sec(infer)\n",
      "Epoch 82 tst: l 0.507 a 0.841 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.616sec\n",
      "Epoch 83 tr: l 0.378 a 0.865 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.065965 17.767sec(train) 4.655sec(infer)\n",
      "Epoch 83 tst: l 0.505 a 0.840 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.618sec\n",
      "Epoch 84 tr: l 0.379 a 0.864 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.065635 17.732sec(train) 4.048sec(infer)\n",
      "Epoch 84 tst: l 0.505 a 0.840 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.305sec\n",
      "Epoch 85 tr: l 0.370 a 0.867 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.065307 17.810sec(train) 4.463sec(infer)\n",
      "Epoch 85 tst: l 0.502 a 0.841 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.630sec\n",
      "Epoch 86 tr: l 0.373 a 0.866 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064981 17.802sec(train) 4.627sec(infer)\n",
      "Epoch 86 tst: l 0.502 a 0.842 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.020sec\n",
      "Epoch 87 tr: l 0.369 a 0.867 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064656 18.046sec(train) 3.769sec(infer)\n",
      "Epoch 87 tst: l 0.501 a 0.841 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.064sec\n",
      "Epoch 88 tr: l 0.369 a 0.867 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064333 18.619sec(train) 3.884sec(infer)\n",
      "Epoch 88 tst: l 0.500 a 0.841 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.532sec\n",
      "Epoch 89 tr: l 0.366 a 0.868 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064011 18.299sec(train) 3.688sec(infer)\n",
      "Epoch 89 tst: l 0.499 a 0.842 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.338sec\n",
      "Epoch 90 tr: l 0.366 a 0.869 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.063691 18.081sec(train) 4.009sec(infer)\n",
      "Epoch 90 tst: l 0.495 a 0.843 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.645sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 91 tr: l 0.368 a 0.867 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.063372 18.258sec(train) 4.292sec(infer)\n",
      "Epoch 91 tst: l 0.499 a 0.843 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.314sec\n",
      "Epoch 92 tr: l 0.361 a 0.870 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.063056 18.532sec(train) 3.647sec(infer)\n",
      "Epoch 92 tst: l 0.491 a 0.844 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.472sec\n",
      "Epoch 93 tr: l 0.363 a 0.869 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.062740 18.570sec(train) 4.093sec(infer)\n",
      "Epoch 93 tst: l 0.496 a 0.844 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.489sec\n",
      "Epoch 94 tr: l 0.358 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.062427 18.659sec(train) 3.131sec(infer)\n",
      "Epoch 94 tst: l 0.490 a 0.844 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.863sec\n",
      "Epoch 95 tr: l 0.360 a 0.869 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.062114 19.524sec(train) 2.895sec(infer)\n",
      "Epoch 95 tst: l 0.493 a 0.844 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.287sec\n",
      "Epoch 96 tr: l 0.358 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.061804 19.515sec(train) 3.493sec(infer)\n",
      "Epoch 96 tst: l 0.494 a 0.843 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.986sec\n",
      "Epoch 97 tr: l 0.359 a 0.870 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.061495 18.997sec(train) 3.311sec(infer)\n",
      "Epoch 97 tst: l 0.488 a 0.845 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.097sec\n",
      "Epoch 98 tr: l 0.355 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.061187 18.838sec(train) 4.117sec(infer)\n",
      "Epoch 98 tst: l 0.487 a 0.846 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.217sec\n",
      "Epoch 99 tr: l 0.352 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.060881 18.727sec(train) 3.814sec(infer)\n",
      "Epoch 99 tst: l 0.485 a 0.845 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.717sec\n",
      "Epoch 100 tr: l 0.365 a 0.870 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.006058 18.621sec(train) 4.083sec(infer)\n",
      "Epoch 100 tst: l 0.475 a 0.850 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.206sec\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.869 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.006027 18.338sec(train) 4.626sec(infer)\n",
      "Epoch 101 tst: l 0.472 a 0.850 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.609sec\n",
      "Epoch 102 tr: l 0.371 a 0.869 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005997 18.559sec(train) 3.450sec(infer)\n",
      "Epoch 102 tst: l 0.471 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.617sec\n",
      "Epoch 103 tr: l 0.370 a 0.870 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005967 18.689sec(train) 4.003sec(infer)\n",
      "Epoch 103 tst: l 0.471 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.617sec\n",
      "Epoch 104 tr: l 0.370 a 0.870 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005937 17.942sec(train) 4.445sec(infer)\n",
      "Epoch 104 tst: l 0.471 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.217sec\n",
      "Epoch 105 tr: l 0.370 a 0.870 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005908 17.798sec(train) 4.124sec(infer)\n",
      "Epoch 105 tst: l 0.470 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.619sec\n",
      "Epoch 106 tr: l 0.371 a 0.870 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005878 17.855sec(train) 4.648sec(infer)\n",
      "Epoch 106 tst: l 0.469 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.626sec\n",
      "Epoch 107 tr: l 0.370 a 0.870 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005849 16.961sec(train) 4.656sec(infer)\n",
      "Epoch 107 tst: l 0.469 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.597sec\n",
      "Epoch 108 tr: l 0.369 a 0.870 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005820 17.803sec(train) 3.954sec(infer)\n",
      "Epoch 108 tst: l 0.469 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.080sec\n",
      "Epoch 109 tr: l 0.369 a 0.870 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005790 18.196sec(train) 4.288sec(infer)\n",
      "Epoch 109 tst: l 0.469 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.201sec\n",
      "Epoch 110 tr: l 0.369 a 0.870 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005762 18.398sec(train) 3.617sec(infer)\n",
      "Epoch 110 tst: l 0.468 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.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.368 a 0.870 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005733 18.367sec(train) 3.908sec(infer)\n",
      "Epoch 111 tst: l 0.468 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.639sec\n",
      "Epoch 112 tr: l 0.367 a 0.870 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005704 17.746sec(train) 4.637sec(infer)\n",
      "Epoch 112 tst: l 0.468 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.549sec\n",
      "Epoch 113 tr: l 0.367 a 0.871 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005676 17.780sec(train) 4.026sec(infer)\n",
      "Epoch 113 tst: l 0.468 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.355sec\n",
      "Epoch 114 tr: l 0.367 a 0.871 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005647 17.776sec(train) 4.643sec(infer)\n",
      "Epoch 114 tst: l 0.468 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.607sec\n",
      "Epoch 115 tr: l 0.366 a 0.871 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005619 18.020sec(train) 4.148sec(infer)\n",
      "Epoch 115 tst: l 0.468 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.249sec\n",
      "Epoch 116 tr: l 0.367 a 0.871 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005591 18.371sec(train) 3.854sec(infer)\n",
      "Epoch 116 tst: l 0.467 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.221sec\n",
      "Epoch 117 tr: l 0.366 a 0.871 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005563 18.890sec(train) 3.562sec(infer)\n",
      "Epoch 117 tst: l 0.467 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.199sec\n",
      "Epoch 118 tr: l 0.366 a 0.871 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005535 19.163sec(train) 3.305sec(infer)\n",
      "Epoch 118 tst: l 0.467 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.421sec\n",
      "Epoch 119 tr: l 0.367 a 0.871 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005507 18.352sec(train) 4.000sec(infer)\n",
      "Epoch 119 tst: l 0.467 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.615sec\n",
      "Epoch 120 tr: l 0.366 a 0.871 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005480 18.769sec(train) 3.357sec(infer)\n",
      "Epoch 120 tst: l 0.466 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.236sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 121 tr: l 0.366 a 0.871 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005452 18.996sec(train) 3.694sec(infer)\n",
      "Epoch 121 tst: l 0.466 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.432sec\n",
      "Epoch 122 tr: l 0.366 a 0.871 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005425 18.913sec(train) 3.909sec(infer)\n",
      "Epoch 122 tst: l 0.466 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.794sec\n",
      "Epoch 123 tr: l 0.366 a 0.871 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005398 18.927sec(train) 3.316sec(infer)\n",
      "Epoch 123 tst: l 0.466 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.694sec\n",
      "Epoch 124 tr: l 0.365 a 0.871 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005371 19.401sec(train) 3.674sec(infer)\n",
      "Epoch 124 tst: l 0.466 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.938sec\n",
      "Epoch 125 tr: l 0.364 a 0.871 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005344 19.150sec(train) 3.292sec(infer)\n",
      "Epoch 125 tst: l 0.466 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.913sec\n",
      "Epoch 126 tr: l 0.364 a 0.871 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005318 18.421sec(train) 4.391sec(infer)\n",
      "Epoch 126 tst: l 0.466 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.255sec\n",
      "Epoch 127 tr: l 0.365 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005291 18.250sec(train) 4.646sec(infer)\n",
      "Epoch 127 tst: l 0.466 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.887sec\n",
      "Epoch 128 tr: l 0.366 a 0.871 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005264 18.188sec(train) 4.088sec(infer)\n",
      "Epoch 128 tst: l 0.465 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.514sec\n",
      "Epoch 129 tr: l 0.364 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005238 17.925sec(train) 4.679sec(infer)\n",
      "Epoch 129 tst: l 0.465 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.583sec\n",
      "Epoch 130 tr: l 0.364 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005212 17.813sec(train) 4.105sec(infer)\n",
      "Epoch 130 tst: l 0.465 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.930sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 131 tr: l 0.363 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005186 17.240sec(train) 4.506sec(infer)\n",
      "Epoch 131 tst: l 0.465 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.609sec\n",
      "Epoch 132 tr: l 0.364 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005160 17.684sec(train) 4.646sec(infer)\n",
      "Epoch 132 tst: l 0.465 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.784sec\n",
      "Epoch 133 tr: l 0.364 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005134 18.437sec(train) 3.527sec(infer)\n",
      "Epoch 133 tst: l 0.465 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.274sec\n",
      "Epoch 134 tr: l 0.364 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005108 18.535sec(train) 4.120sec(infer)\n",
      "Epoch 134 tst: l 0.465 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.623sec\n",
      "Epoch 135 tr: l 0.364 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005083 18.055sec(train) 4.026sec(infer)\n",
      "Epoch 135 tst: l 0.465 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.329sec\n",
      "Epoch 136 tr: l 0.363 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005058 17.817sec(train) 4.517sec(infer)\n",
      "Epoch 136 tst: l 0.464 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.627sec\n",
      "Epoch 137 tr: l 0.363 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005032 17.905sec(train) 4.593sec(infer)\n",
      "Epoch 137 tst: l 0.465 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.221sec\n",
      "Epoch 138 tr: l 0.364 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005007 17.824sec(train) 4.129sec(infer)\n",
      "Epoch 138 tst: l 0.464 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.627sec\n",
      "Epoch 139 tr: l 0.363 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004982 17.908sec(train) 4.646sec(infer)\n",
      "Epoch 139 tst: l 0.464 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.235sec\n",
      "Epoch 140 tr: l 0.363 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004957 18.037sec(train) 3.468sec(infer)\n",
      "Epoch 140 tst: l 0.464 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.941sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 141 tr: l 0.363 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004932 18.749sec(train) 4.045sec(infer)\n",
      "Epoch 141 tst: l 0.464 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.645sec\n",
      "Epoch 142 tr: l 0.362 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004908 18.306sec(train) 4.249sec(infer)\n",
      "Epoch 142 tst: l 0.464 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.289sec\n",
      "Epoch 143 tr: l 0.363 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004883 18.206sec(train) 3.928sec(infer)\n",
      "Epoch 143 tst: l 0.464 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.641sec\n",
      "Epoch 144 tr: l 0.363 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004859 18.183sec(train) 4.193sec(infer)\n",
      "Epoch 144 tst: l 0.464 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.590sec\n",
      "Epoch 145 tr: l 0.362 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004834 18.606sec(train) 3.379sec(infer)\n",
      "Epoch 145 tst: l 0.463 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.265sec\n",
      "Epoch 146 tr: l 0.362 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004810 18.606sec(train) 3.844sec(infer)\n",
      "Epoch 146 tst: l 0.463 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.183sec\n",
      "Epoch 147 tr: l 0.362 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004786 19.272sec(train) 2.847sec(infer)\n",
      "Epoch 147 tst: l 0.463 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.886sec\n",
      "Epoch 148 tr: l 0.362 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004762 19.402sec(train) 3.166sec(infer)\n",
      "Epoch 148 tst: l 0.463 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.431sec\n",
      "Epoch 149 tr: l 0.361 a 0.873 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004738 18.901sec(train) 3.931sec(infer)\n",
      "Epoch 149 tst: l 0.463 a 0.853 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.166sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "---train cluster Ended in 1.03 hour (3704.384 sec) \n",
      "---------------------------------DFCA-LI, lr: 0.1, seed: 7293---------------------------------\n",
      "config: {'m': 100, 'm_test': 20, 'p': 2, 'n': 1500, 'uneven': True, 'local_model_init': True, 'Gp': 0.15, 'graph': 'er', 'agg': 'seq', 'h1': 512, 'num_epochs': 150, 'batch_size': 100, 'tau': 5, 'lr': 0.1, 'data_seed': 7293, 'train_seed': 7293, 'config_override': '', 'project_dir': 'output_dfca_gi'}\n",
      "Using device: cuda:3\n",
      "Epoch -1 tr: l 3.870 a 0.022 clct[np.int64(52), np.int64(48)] cl_acc 0.540  4.495sec\n",
      "Epoch -1 tst: l 3.870 a 0.024 clct[np.int64(14), np.int64(6)] cl_acc 0.500  2.196sec\n",
      "Epoch 0 tr: l 3.734 a 0.207 clct[np.int64(52), np.int64(48)] cl_acc 0.540  lr 0.100000 18.632sec(train) 3.758sec(infer)\n",
      "Epoch 0 tst: l 3.798 a 0.091 clct[np.int64(7), np.int64(13)] cl_acc 0.550  1.708sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 1 tr: l 3.725 a 0.183 clct[np.int64(53), np.int64(47)] cl_acc 0.530  lr 0.099500 19.169sec(train) 3.133sec(infer)\n",
      "Epoch 1 tst: l 3.785 a 0.118 clct[np.int64(7), np.int64(13)] cl_acc 0.550  2.524sec\n",
      "Epoch 2 tr: l 3.663 a 0.161 clct[np.int64(53), np.int64(47)] cl_acc 0.530  lr 0.099003 18.897sec(train) 3.962sec(infer)\n",
      "Epoch 2 tst: l 3.736 a 0.112 clct[np.int64(10), np.int64(10)] cl_acc 0.600  2.506sec\n",
      "Epoch 3 tr: l 3.529 a 0.177 clct[np.int64(51), np.int64(49)] cl_acc 0.550  lr 0.098507 18.727sec(train) 3.223sec(infer)\n",
      "Epoch 3 tst: l 3.610 a 0.137 clct[np.int64(12), np.int64(8)] cl_acc 0.700  1.704sec\n",
      "Epoch 4 tr: l 3.301 a 0.218 clct[np.int64(51), np.int64(49)] cl_acc 0.550  lr 0.098015 18.143sec(train) 4.541sec(infer)\n",
      "Epoch 4 tst: l 3.400 a 0.188 clct[np.int64(10), np.int64(10)] cl_acc 0.600  2.433sec\n",
      "Epoch 5 tr: l 3.008 a 0.288 clct[np.int64(51), np.int64(49)] cl_acc 0.610  lr 0.097525 17.904sec(train) 4.504sec(infer)\n",
      "Epoch 5 tst: l 3.115 a 0.257 clct[np.int64(11), np.int64(9)] cl_acc 0.650  2.115sec\n",
      "Epoch 6 tr: l 2.720 a 0.336 clct[np.int64(50), np.int64(50)] cl_acc 0.760  lr 0.097037 17.825sec(train) 4.007sec(infer)\n",
      "Epoch 6 tst: l 2.819 a 0.319 clct[np.int64(11), np.int64(9)] cl_acc 0.850  2.454sec\n",
      "Epoch 7 tr: l 2.417 a 0.393 clct[np.int64(52), np.int64(48)] cl_acc 0.920  lr 0.096552 17.776sec(train) 4.520sec(infer)\n",
      "Epoch 7 tst: l 2.506 a 0.373 clct[np.int64(11), np.int64(9)] cl_acc 0.950  2.108sec\n",
      "Epoch 8 tr: l 2.110 a 0.471 clct[np.int64(50), np.int64(50)] cl_acc 0.980  lr 0.096069 18.305sec(train) 3.429sec(infer)\n",
      "Epoch 8 tst: l 2.177 a 0.457 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.902sec\n",
      "Epoch 9 tr: l 1.827 a 0.506 clct[np.int64(49), np.int64(51)] cl_acc 0.990  lr 0.095589 18.669sec(train) 3.893sec(infer)\n",
      "Epoch 9 tst: l 1.911 a 0.513 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.500sec\n",
      "Epoch 10 tr: l 1.585 a 0.579 clct[np.int64(49), np.int64(51)] cl_acc 0.990  lr 0.095111 17.959sec(train) 4.555sec(infer)\n",
      "Epoch 10 tst: l 1.691 a 0.564 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.103sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 11 tr: l 1.432 a 0.593 clct[np.int64(49), np.int64(51)] cl_acc 0.990  lr 0.094635 18.035sec(train) 4.079sec(infer)\n",
      "Epoch 11 tst: l 1.509 a 0.594 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.439sec\n",
      "Epoch 12 tr: l 1.268 a 0.646 clct[np.int64(49), np.int64(51)] cl_acc 0.990  lr 0.094162 17.755sec(train) 4.616sec(infer)\n",
      "Epoch 12 tst: l 1.342 a 0.639 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.489sec\n",
      "Epoch 13 tr: l 1.138 a 0.669 clct[np.int64(49), np.int64(51)] cl_acc 0.990  lr 0.093691 17.870sec(train) 4.160sec(infer)\n",
      "Epoch 13 tst: l 1.220 a 0.656 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.168sec\n",
      "Epoch 14 tr: l 1.049 a 0.695 clct[np.int64(49), np.int64(51)] cl_acc 0.990  lr 0.093223 18.005sec(train) 4.320sec(infer)\n",
      "Epoch 14 tst: l 1.126 a 0.684 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.337sec\n",
      "Epoch 15 tr: l 0.989 a 0.700 clct[np.int64(49), np.int64(51)] cl_acc 0.990  lr 0.092757 18.114sec(train) 4.422sec(infer)\n",
      "Epoch 15 tst: l 1.059 a 0.691 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.832sec\n",
      "Epoch 16 tr: l 0.936 a 0.719 clct[np.int64(49), np.int64(51)] cl_acc 0.990  lr 0.092293 18.660sec(train) 3.333sec(infer)\n",
      "Epoch 16 tst: l 1.005 a 0.708 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.154sec\n",
      "Epoch 17 tr: l 0.897 a 0.717 clct[np.int64(49), np.int64(51)] cl_acc 0.990  lr 0.091832 18.492sec(train) 4.121sec(infer)\n",
      "Epoch 17 tst: l 0.959 a 0.714 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.510sec\n",
      "Epoch 18 tr: l 0.848 a 0.739 clct[np.int64(49), np.int64(51)] cl_acc 0.990  lr 0.091372 18.331sec(train) 4.002sec(infer)\n",
      "Epoch 18 tst: l 0.913 a 0.729 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.195sec\n",
      "Epoch 19 tr: l 0.821 a 0.741 clct[np.int64(49), np.int64(51)] cl_acc 0.990  lr 0.090916 18.389sec(train) 3.895sec(infer)\n",
      "Epoch 19 tst: l 0.881 a 0.735 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.527sec\n",
      "Epoch 20 tr: l 0.782 a 0.753 clct[np.int64(49), np.int64(51)] cl_acc 0.990  lr 0.090461 18.427sec(train) 4.062sec(infer)\n",
      "Epoch 20 tst: l 0.852 a 0.744 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.399sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 21 tr: l 0.752 a 0.758 clct[np.int64(49), np.int64(51)] cl_acc 0.990  lr 0.090009 18.907sec(train) 3.340sec(infer)\n",
      "Epoch 21 tst: l 0.829 a 0.746 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.273sec\n",
      "Epoch 22 tr: l 0.734 a 0.767 clct[np.int64(49), np.int64(51)] cl_acc 0.990  lr 0.089559 18.732sec(train) 3.904sec(infer)\n",
      "Epoch 22 tst: l 0.806 a 0.756 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.043sec\n",
      "Epoch 23 tr: l 0.711 a 0.769 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.089111 19.362sec(train) 2.868sec(infer)\n",
      "Epoch 23 tst: l 0.784 a 0.760 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.690sec\n",
      "Epoch 24 tr: l 0.697 a 0.775 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.088665 19.714sec(train) 2.981sec(infer)\n",
      "Epoch 24 tst: l 0.770 a 0.761 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.295sec\n",
      "Epoch 25 tr: l 0.687 a 0.775 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.088222 19.138sec(train) 3.849sec(infer)\n",
      "Epoch 25 tst: l 0.754 a 0.766 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.084sec\n",
      "Epoch 26 tr: l 0.662 a 0.785 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.087781 19.204sec(train) 3.386sec(infer)\n",
      "Epoch 26 tst: l 0.727 a 0.773 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.888sec\n",
      "Epoch 27 tr: l 0.637 a 0.790 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.087342 18.840sec(train) 4.210sec(infer)\n",
      "Epoch 27 tst: l 0.713 a 0.777 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.119sec\n",
      "Epoch 28 tr: l 0.634 a 0.791 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.086905 18.792sec(train) 4.013sec(infer)\n",
      "Epoch 28 tst: l 0.699 a 0.781 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.750sec\n",
      "Epoch 29 tr: l 0.614 a 0.796 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.086471 18.509sec(train) 4.146sec(infer)\n",
      "Epoch 29 tst: l 0.689 a 0.784 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.906sec\n",
      "Epoch 30 tr: l 0.610 a 0.797 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.086038 18.655sec(train) 4.286sec(infer)\n",
      "Epoch 30 tst: l 0.685 a 0.785 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.778sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 31 tr: l 0.599 a 0.799 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.085608 18.817sec(train) 3.179sec(infer)\n",
      "Epoch 31 tst: l 0.677 a 0.784 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.076sec\n",
      "Epoch 32 tr: l 0.585 a 0.805 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.085180 18.513sec(train) 4.327sec(infer)\n",
      "Epoch 32 tst: l 0.655 a 0.792 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.487sec\n",
      "Epoch 33 tr: l 0.572 a 0.807 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.084754 17.976sec(train) 4.458sec(infer)\n",
      "Epoch 33 tst: l 0.650 a 0.791 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.089sec\n",
      "Epoch 34 tr: l 0.567 a 0.810 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.084331 18.018sec(train) 4.112sec(infer)\n",
      "Epoch 34 tst: l 0.643 a 0.795 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.491sec\n",
      "Epoch 35 tr: l 0.553 a 0.813 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.083909 18.011sec(train) 4.570sec(infer)\n",
      "Epoch 35 tst: l 0.635 a 0.797 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.497sec\n",
      "Epoch 36 tr: l 0.550 a 0.814 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.083489 18.113sec(train) 3.965sec(infer)\n",
      "Epoch 36 tst: l 0.628 a 0.799 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.220sec\n",
      "Epoch 37 tr: l 0.543 a 0.815 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.083072 17.877sec(train) 4.516sec(infer)\n",
      "Epoch 37 tst: l 0.624 a 0.798 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.117sec\n",
      "Epoch 38 tr: l 0.536 a 0.818 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.082657 18.402sec(train) 4.052sec(infer)\n",
      "Epoch 38 tst: l 0.614 a 0.802 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.700sec\n",
      "Epoch 39 tr: l 0.525 a 0.821 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.082243 18.679sec(train) 3.474sec(infer)\n",
      "Epoch 39 tst: l 0.609 a 0.803 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.433sec\n",
      "Epoch 40 tr: l 0.528 a 0.820 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.081832 18.041sec(train) 4.544sec(infer)\n",
      "Epoch 40 tst: l 0.600 a 0.807 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.517sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 41 tr: l 0.513 a 0.824 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.081423 18.051sec(train) 4.049sec(infer)\n",
      "Epoch 41 tst: l 0.594 a 0.807 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.161sec\n",
      "Epoch 42 tr: l 0.509 a 0.826 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.081016 17.938sec(train) 4.421sec(infer)\n",
      "Epoch 42 tst: l 0.587 a 0.811 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.460sec\n",
      "Epoch 43 tr: l 0.501 a 0.827 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.080611 17.821sec(train) 4.511sec(infer)\n",
      "Epoch 43 tst: l 0.585 a 0.810 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.140sec\n",
      "Epoch 44 tr: l 0.495 a 0.829 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.080208 18.053sec(train) 4.047sec(infer)\n",
      "Epoch 44 tst: l 0.577 a 0.812 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.281sec\n",
      "Epoch 45 tr: l 0.489 a 0.831 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.079807 18.284sec(train) 4.373sec(infer)\n",
      "Epoch 45 tst: l 0.577 a 0.811 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.095sec\n",
      "Epoch 46 tr: l 0.487 a 0.832 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.079408 18.900sec(train) 3.129sec(infer)\n",
      "Epoch 46 tst: l 0.568 a 0.815 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.997sec\n",
      "Epoch 47 tr: l 0.478 a 0.835 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.079010 18.967sec(train) 3.772sec(infer)\n",
      "Epoch 47 tst: l 0.566 a 0.815 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.549sec\n",
      "Epoch 48 tr: l 0.474 a 0.836 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.078615 18.392sec(train) 4.182sec(infer)\n",
      "Epoch 48 tst: l 0.561 a 0.817 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.155sec\n",
      "Epoch 49 tr: l 0.471 a 0.837 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.078222 18.732sec(train) 3.526sec(infer)\n",
      "Epoch 49 tst: l 0.558 a 0.818 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.435sec\n",
      "Epoch 50 tr: l 0.472 a 0.837 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.077831 18.478sec(train) 3.945sec(infer)\n",
      "Epoch 50 tst: l 0.554 a 0.819 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.458sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 51 tr: l 0.464 a 0.840 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.077442 18.821sec(train) 3.303sec(infer)\n",
      "Epoch 51 tst: l 0.551 a 0.819 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.101sec\n",
      "Epoch 52 tr: l 0.462 a 0.839 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.077055 18.983sec(train) 3.684sec(infer)\n",
      "Epoch 52 tst: l 0.549 a 0.821 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.867sec\n",
      "Epoch 53 tr: l 0.453 a 0.842 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.076670 19.425sec(train) 3.441sec(infer)\n",
      "Epoch 53 tst: l 0.543 a 0.822 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.415sec\n",
      "Epoch 54 tr: l 0.456 a 0.841 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.076286 19.802sec(train) 2.709sec(infer)\n",
      "Epoch 54 tst: l 0.542 a 0.822 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.914sec\n",
      "Epoch 55 tr: l 0.450 a 0.841 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.075905 19.077sec(train) 4.185sec(infer)\n",
      "Epoch 55 tst: l 0.541 a 0.821 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.145sec\n",
      "Epoch 56 tr: l 0.453 a 0.840 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.075525 18.821sec(train) 3.915sec(infer)\n",
      "Epoch 56 tst: l 0.539 a 0.822 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.807sec\n",
      "Epoch 57 tr: l 0.449 a 0.844 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.075148 18.647sec(train) 4.318sec(infer)\n",
      "Epoch 57 tst: l 0.536 a 0.822 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.157sec\n",
      "Epoch 58 tr: l 0.441 a 0.844 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.074772 18.283sec(train) 4.603sec(infer)\n",
      "Epoch 58 tst: l 0.531 a 0.825 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.085sec\n",
      "Epoch 59 tr: l 0.438 a 0.847 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.074398 18.294sec(train) 4.022sec(infer)\n",
      "Epoch 59 tst: l 0.526 a 0.827 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.001sec\n",
      "Epoch 60 tr: l 0.433 a 0.848 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.074026 18.290sec(train) 4.430sec(infer)\n",
      "Epoch 60 tst: l 0.522 a 0.828 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.115sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 61 tr: l 0.428 a 0.850 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.073656 18.605sec(train) 3.498sec(infer)\n",
      "Epoch 61 tst: l 0.522 a 0.828 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.019sec\n",
      "Epoch 62 tr: l 0.430 a 0.849 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.073288 18.477sec(train) 3.774sec(infer)\n",
      "Epoch 62 tst: l 0.518 a 0.829 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.515sec\n",
      "Epoch 63 tr: l 0.421 a 0.851 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.072921 17.548sec(train) 4.359sec(infer)\n",
      "Epoch 63 tst: l 0.517 a 0.830 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.515sec\n",
      "Epoch 64 tr: l 0.422 a 0.851 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.072557 17.947sec(train) 4.604sec(infer)\n",
      "Epoch 64 tst: l 0.515 a 0.830 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.262sec\n",
      "Epoch 65 tr: l 0.423 a 0.849 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.072194 18.089sec(train) 3.986sec(infer)\n",
      "Epoch 65 tst: l 0.511 a 0.831 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.283sec\n",
      "Epoch 66 tr: l 0.419 a 0.852 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.071833 17.751sec(train) 4.596sec(infer)\n",
      "Epoch 66 tst: l 0.510 a 0.831 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.492sec\n",
      "Epoch 67 tr: l 0.416 a 0.851 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.071474 17.987sec(train) 4.287sec(infer)\n",
      "Epoch 67 tst: l 0.509 a 0.831 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.914sec\n",
      "Epoch 68 tr: l 0.412 a 0.854 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.071116 18.260sec(train) 3.806sec(infer)\n",
      "Epoch 68 tst: l 0.506 a 0.833 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.126sec\n",
      "Epoch 69 tr: l 0.408 a 0.855 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.070761 18.597sec(train) 3.899sec(infer)\n",
      "Epoch 69 tst: l 0.501 a 0.834 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.450sec\n",
      "Epoch 70 tr: l 0.408 a 0.856 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.070407 18.440sec(train) 3.570sec(infer)\n",
      "Epoch 70 tst: l 0.502 a 0.833 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.218sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 71 tr: l 0.402 a 0.857 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.070055 17.915sec(train) 4.454sec(infer)\n",
      "Epoch 71 tst: l 0.500 a 0.835 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.515sec\n",
      "Epoch 72 tr: l 0.404 a 0.857 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.069705 17.976sec(train) 4.541sec(infer)\n",
      "Epoch 72 tst: l 0.497 a 0.836 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.094sec\n",
      "Epoch 73 tr: l 0.398 a 0.859 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.069356 18.408sec(train) 3.864sec(infer)\n",
      "Epoch 73 tst: l 0.495 a 0.836 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.454sec\n",
      "Epoch 74 tr: l 0.397 a 0.858 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.069009 18.474sec(train) 4.257sec(infer)\n",
      "Epoch 74 tst: l 0.496 a 0.837 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.508sec\n",
      "Epoch 75 tr: l 0.394 a 0.860 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.068664 18.478sec(train) 3.527sec(infer)\n",
      "Epoch 75 tst: l 0.490 a 0.837 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.844sec\n",
      "Epoch 76 tr: l 0.397 a 0.859 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.068321 19.246sec(train) 3.127sec(infer)\n",
      "Epoch 76 tst: l 0.491 a 0.838 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.247sec\n",
      "Epoch 77 tr: l 0.392 a 0.860 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.067979 19.468sec(train) 3.381sec(infer)\n",
      "Epoch 77 tst: l 0.488 a 0.837 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.086sec\n",
      "Epoch 78 tr: l 0.390 a 0.861 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.067639 19.092sec(train) 3.299sec(infer)\n",
      "Epoch 78 tst: l 0.488 a 0.839 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.106sec\n",
      "Epoch 79 tr: l 0.383 a 0.863 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.067301 19.088sec(train) 3.823sec(infer)\n",
      "Epoch 79 tst: l 0.485 a 0.839 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.197sec\n",
      "Epoch 80 tr: l 0.388 a 0.862 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.066965 19.050sec(train) 3.669sec(infer)\n",
      "Epoch 80 tst: l 0.485 a 0.840 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.773sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 81 tr: l 0.380 a 0.864 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.066630 19.000sec(train) 3.665sec(infer)\n",
      "Epoch 81 tst: l 0.482 a 0.839 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.119sec\n",
      "Epoch 82 tr: l 0.381 a 0.863 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.066297 18.802sec(train) 4.326sec(infer)\n",
      "Epoch 82 tst: l 0.481 a 0.841 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.891sec\n",
      "Epoch 83 tr: l 0.377 a 0.864 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.065965 18.601sec(train) 3.500sec(infer)\n",
      "Epoch 83 tst: l 0.480 a 0.840 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.433sec\n",
      "Epoch 84 tr: l 0.378 a 0.865 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.065635 19.046sec(train) 3.703sec(infer)\n",
      "Epoch 84 tst: l 0.480 a 0.842 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.202sec\n",
      "Epoch 85 tr: l 0.379 a 0.864 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.065307 18.720sec(train) 4.293sec(infer)\n",
      "Epoch 85 tst: l 0.476 a 0.841 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.011sec\n",
      "Epoch 86 tr: l 0.376 a 0.865 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064981 18.102sec(train) 4.077sec(infer)\n",
      "Epoch 86 tst: l 0.478 a 0.841 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.400sec\n",
      "Epoch 87 tr: l 0.373 a 0.866 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064656 17.890sec(train) 4.616sec(infer)\n",
      "Epoch 87 tst: l 0.476 a 0.842 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.505sec\n",
      "Epoch 88 tr: l 0.373 a 0.866 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064333 17.897sec(train) 4.154sec(infer)\n",
      "Epoch 88 tst: l 0.473 a 0.842 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.207sec\n",
      "Epoch 89 tr: l 0.370 a 0.866 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064011 18.056sec(train) 4.255sec(infer)\n",
      "Epoch 89 tst: l 0.473 a 0.843 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.529sec\n",
      "Epoch 90 tr: l 0.368 a 0.867 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.063691 17.892sec(train) 4.590sec(infer)\n",
      "Epoch 90 tst: l 0.470 a 0.843 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.044sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 91 tr: l 0.366 a 0.869 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.063372 18.397sec(train) 3.467sec(infer)\n",
      "Epoch 91 tst: l 0.470 a 0.843 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.828sec\n",
      "Epoch 92 tr: l 0.365 a 0.868 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.063056 18.832sec(train) 3.967sec(infer)\n",
      "Epoch 92 tst: l 0.468 a 0.844 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.507sec\n",
      "Epoch 93 tr: l 0.362 a 0.870 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.062740 18.204sec(train) 4.249sec(infer)\n",
      "Epoch 93 tst: l 0.466 a 0.844 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.131sec\n",
      "Epoch 94 tr: l 0.361 a 0.869 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.062427 18.098sec(train) 4.076sec(infer)\n",
      "Epoch 94 tst: l 0.466 a 0.844 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.503sec\n",
      "Epoch 95 tr: l 0.358 a 0.871 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.062114 17.642sec(train) 4.616sec(infer)\n",
      "Epoch 95 tst: l 0.466 a 0.845 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.483sec\n",
      "Epoch 96 tr: l 0.358 a 0.870 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.061804 18.035sec(train) 4.048sec(infer)\n",
      "Epoch 96 tst: l 0.463 a 0.845 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.218sec\n",
      "Epoch 97 tr: l 0.359 a 0.871 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.061495 17.933sec(train) 4.387sec(infer)\n",
      "Epoch 97 tst: l 0.463 a 0.846 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.397sec\n",
      "Epoch 98 tr: l 0.355 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.061187 18.090sec(train) 4.398sec(infer)\n",
      "Epoch 98 tst: l 0.461 a 0.845 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.800sec\n",
      "Epoch 99 tr: l 0.355 a 0.871 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.060881 18.839sec(train) 3.206sec(infer)\n",
      "Epoch 99 tst: l 0.461 a 0.847 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.047sec\n",
      "Epoch 100 tr: l 0.366 a 0.870 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.006058 18.822sec(train) 3.918sec(infer)\n",
      "Epoch 100 tst: l 0.451 a 0.849 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.509sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 101 tr: l 0.369 a 0.870 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.006027 18.412sec(train) 3.816sec(infer)\n",
      "Epoch 101 tst: l 0.448 a 0.850 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.211sec\n",
      "Epoch 102 tr: l 0.370 a 0.870 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005997 18.496sec(train) 3.703sec(infer)\n",
      "Epoch 102 tst: l 0.447 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.509sec\n",
      "Epoch 103 tr: l 0.369 a 0.870 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005967 18.698sec(train) 3.918sec(infer)\n",
      "Epoch 103 tst: l 0.446 a 0.850 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.426sec\n",
      "Epoch 104 tr: l 0.370 a 0.870 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005937 18.979sec(train) 3.199sec(infer)\n",
      "Epoch 104 tst: l 0.446 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.061sec\n",
      "Epoch 105 tr: l 0.370 a 0.870 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005908 19.104sec(train) 3.879sec(infer)\n",
      "Epoch 105 tst: l 0.445 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.871sec\n",
      "Epoch 106 tr: l 0.370 a 0.870 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005878 19.474sec(train) 3.188sec(infer)\n",
      "Epoch 106 tst: l 0.445 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.320sec\n",
      "Epoch 107 tr: l 0.369 a 0.871 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005849 19.623sec(train) 2.832sec(infer)\n",
      "Epoch 107 tst: l 0.445 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.038sec\n",
      "Epoch 108 tr: l 0.369 a 0.871 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005820 18.877sec(train) 4.105sec(infer)\n",
      "Epoch 108 tst: l 0.445 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.124sec\n",
      "Epoch 109 tr: l 0.369 a 0.870 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005790 18.507sec(train) 3.900sec(infer)\n",
      "Epoch 109 tst: l 0.445 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.815sec\n",
      "Epoch 110 tr: l 0.369 a 0.870 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005762 18.414sec(train) 4.331sec(infer)\n",
      "Epoch 110 tst: l 0.444 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.188sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 111 tr: l 0.368 a 0.871 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005733 18.275sec(train) 4.615sec(infer)\n",
      "Epoch 111 tst: l 0.444 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.118sec\n",
      "Epoch 112 tr: l 0.368 a 0.871 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005704 17.118sec(train) 3.937sec(infer)\n",
      "Epoch 112 tst: l 0.444 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.156sec\n",
      "Epoch 113 tr: l 0.368 a 0.871 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005676 17.970sec(train) 4.632sec(infer)\n",
      "Epoch 113 tst: l 0.444 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.508sec\n",
      "Epoch 114 tr: l 0.368 a 0.871 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005647 17.638sec(train) 4.506sec(infer)\n",
      "Epoch 114 tst: l 0.444 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.020sec\n",
      "Epoch 115 tr: l 0.367 a 0.871 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005619 18.016sec(train) 3.887sec(infer)\n",
      "Epoch 115 tst: l 0.444 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.119sec\n",
      "Epoch 116 tr: l 0.367 a 0.871 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005591 18.512sec(train) 4.070sec(infer)\n",
      "Epoch 116 tst: l 0.444 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.180sec\n",
      "Epoch 117 tr: l 0.367 a 0.871 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005563 18.799sec(train) 3.274sec(infer)\n",
      "Epoch 117 tst: l 0.443 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.185sec\n",
      "Epoch 118 tr: l 0.366 a 0.871 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005535 18.349sec(train) 4.290sec(infer)\n",
      "Epoch 118 tst: l 0.443 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.501sec\n",
      "Epoch 119 tr: l 0.367 a 0.871 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005507 18.014sec(train) 4.610sec(infer)\n",
      "Epoch 119 tst: l 0.443 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.136sec\n",
      "Epoch 120 tr: l 0.365 a 0.871 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005480 18.038sec(train) 4.071sec(infer)\n",
      "Epoch 120 tst: l 0.443 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.438sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 121 tr: l 0.366 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005452 17.820sec(train) 4.639sec(infer)\n",
      "Epoch 121 tst: l 0.443 a 0.853 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.522sec\n",
      "Epoch 122 tr: l 0.366 a 0.871 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005425 17.885sec(train) 4.315sec(infer)\n",
      "Epoch 122 tst: l 0.443 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.160sec\n",
      "Epoch 123 tr: l 0.366 a 0.871 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005398 17.977sec(train) 4.148sec(infer)\n",
      "Epoch 123 tst: l 0.443 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.115sec\n",
      "Epoch 124 tr: l 0.365 a 0.871 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005371 18.478sec(train) 4.159sec(infer)\n",
      "Epoch 124 tst: l 0.443 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.118sec\n",
      "Epoch 125 tr: l 0.366 a 0.871 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005344 18.814sec(train) 3.287sec(infer)\n",
      "Epoch 125 tst: l 0.442 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.211sec\n",
      "Epoch 126 tr: l 0.366 a 0.871 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005318 18.536sec(train) 4.400sec(infer)\n",
      "Epoch 126 tst: l 0.442 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.480sec\n",
      "Epoch 127 tr: l 0.366 a 0.871 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005291 18.228sec(train) 4.045sec(infer)\n",
      "Epoch 127 tst: l 0.442 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.132sec\n",
      "Epoch 128 tr: l 0.366 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005264 18.461sec(train) 3.732sec(infer)\n",
      "Epoch 128 tst: l 0.442 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.492sec\n",
      "Epoch 129 tr: l 0.366 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005238 18.500sec(train) 4.123sec(infer)\n",
      "Epoch 129 tst: l 0.442 a 0.853 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.505sec\n",
      "Epoch 130 tr: l 0.365 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005212 18.696sec(train) 3.292sec(infer)\n",
      "Epoch 130 tst: l 0.442 a 0.853 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.026sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 131 tr: l 0.365 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005186 18.947sec(train) 3.556sec(infer)\n",
      "Epoch 131 tst: l 0.441 a 0.853 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.041sec\n",
      "Epoch 132 tr: l 0.364 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005160 19.630sec(train) 3.219sec(infer)\n",
      "Epoch 132 tst: l 0.442 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.629sec\n",
      "Epoch 133 tr: l 0.364 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005134 19.661sec(train) 2.955sec(infer)\n",
      "Epoch 133 tst: l 0.441 a 0.853 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.987sec\n",
      "Epoch 134 tr: l 0.364 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005108 19.073sec(train) 4.062sec(infer)\n",
      "Epoch 134 tst: l 0.442 a 0.853 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.153sec\n",
      "Epoch 135 tr: l 0.364 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005083 18.630sec(train) 3.691sec(infer)\n",
      "Epoch 135 tst: l 0.441 a 0.853 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.552sec\n",
      "Epoch 136 tr: l 0.363 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005058 18.646sec(train) 3.934sec(infer)\n",
      "Epoch 136 tst: l 0.441 a 0.853 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.108sec\n",
      "Epoch 137 tr: l 0.364 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005032 18.362sec(train) 4.619sec(infer)\n",
      "Epoch 137 tst: l 0.441 a 0.853 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.186sec\n",
      "Epoch 138 tr: l 0.364 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005007 18.070sec(train) 4.058sec(infer)\n",
      "Epoch 138 tst: l 0.441 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.951sec\n",
      "Epoch 139 tr: l 0.364 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004982 18.089sec(train) 4.242sec(infer)\n",
      "Epoch 139 tst: l 0.441 a 0.853 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.097sec\n",
      "Epoch 140 tr: l 0.364 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004957 18.339sec(train) 4.091sec(infer)\n",
      "Epoch 140 tst: l 0.441 a 0.853 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.896sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 141 tr: l 0.363 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004932 18.754sec(train) 3.451sec(infer)\n",
      "Epoch 141 tst: l 0.441 a 0.853 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.320sec\n",
      "Epoch 142 tr: l 0.363 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004908 18.226sec(train) 4.542sec(infer)\n",
      "Epoch 142 tst: l 0.441 a 0.853 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.520sec\n",
      "Epoch 143 tr: l 0.363 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004883 17.809sec(train) 4.202sec(infer)\n",
      "Epoch 143 tst: l 0.441 a 0.853 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.142sec\n",
      "Epoch 144 tr: l 0.363 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004859 17.987sec(train) 4.228sec(infer)\n",
      "Epoch 144 tst: l 0.441 a 0.853 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.521sec\n",
      "Epoch 145 tr: l 0.362 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004834 17.815sec(train) 4.603sec(infer)\n",
      "Epoch 145 tst: l 0.440 a 0.853 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.510sec\n",
      "Epoch 146 tr: l 0.362 a 0.873 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004810 18.032sec(train) 3.924sec(infer)\n",
      "Epoch 146 tst: l 0.440 a 0.853 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.156sec\n",
      "Epoch 147 tr: l 0.361 a 0.873 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004786 17.933sec(train) 4.411sec(infer)\n",
      "Epoch 147 tst: l 0.440 a 0.853 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.114sec\n",
      "Epoch 148 tr: l 0.363 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004762 18.689sec(train) 4.047sec(infer)\n",
      "Epoch 148 tst: l 0.440 a 0.853 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.645sec\n",
      "Epoch 149 tr: l 0.362 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004738 18.845sec(train) 3.498sec(infer)\n",
      "Epoch 149 tst: l 0.440 a 0.853 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.381sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "---train cluster Ended in 1.03 hour (3715.884 sec) \n",
      "---------------------------------DFCA-LI, lr: 0.1, seed: 7383---------------------------------\n",
      "config: {'m': 100, 'm_test': 20, 'p': 2, 'n': 1500, 'uneven': True, 'local_model_init': True, 'Gp': 0.15, 'graph': 'er', 'agg': 'seq', 'h1': 512, 'num_epochs': 150, 'batch_size': 100, 'tau': 5, 'lr': 0.1, 'data_seed': 7383, 'train_seed': 7383, 'config_override': '', 'project_dir': 'output_dfca_gi'}\n",
      "Using device: cuda:3\n",
      "Epoch -1 tr: l 3.869 a 0.023 clct[np.int64(45), np.int64(55)] cl_acc 0.530  4.208sec\n",
      "Epoch -1 tst: l 3.870 a 0.025 clct[np.int64(9), np.int64(11)] cl_acc 0.550  2.204sec\n",
      "Epoch 0 tr: l 3.753 a 0.183 clct[np.int64(46), np.int64(54)] cl_acc 0.520  lr 0.100000 18.020sec(train) 4.240sec(infer)\n",
      "Epoch 0 tst: l 3.798 a 0.097 clct[np.int64(8), np.int64(12)] cl_acc 0.500  2.532sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 1 tr: l 3.752 a 0.173 clct[np.int64(45), np.int64(55)] cl_acc 0.510  lr 0.099500 17.703sec(train) 4.610sec(infer)\n",
      "Epoch 1 tst: l 3.774 a 0.117 clct[np.int64(8), np.int64(12)] cl_acc 0.500  2.143sec\n",
      "Epoch 2 tr: l 3.692 a 0.139 clct[np.int64(45), np.int64(55)] cl_acc 0.510  lr 0.099003 18.120sec(train) 3.505sec(infer)\n",
      "Epoch 2 tst: l 3.724 a 0.115 clct[np.int64(8), np.int64(12)] cl_acc 0.500  1.817sec\n",
      "Epoch 3 tr: l 3.564 a 0.149 clct[np.int64(45), np.int64(55)] cl_acc 0.510  lr 0.098507 18.797sec(train) 3.823sec(infer)\n",
      "Epoch 3 tst: l 3.618 a 0.130 clct[np.int64(7), np.int64(13)] cl_acc 0.550  2.513sec\n",
      "Epoch 4 tr: l 3.340 a 0.197 clct[np.int64(45), np.int64(55)] cl_acc 0.510  lr 0.098015 18.365sec(train) 4.146sec(infer)\n",
      "Epoch 4 tst: l 3.408 a 0.172 clct[np.int64(6), np.int64(14)] cl_acc 0.600  2.110sec\n",
      "Epoch 5 tr: l 3.056 a 0.258 clct[np.int64(45), np.int64(55)] cl_acc 0.510  lr 0.097525 18.058sec(train) 4.008sec(infer)\n",
      "Epoch 5 tst: l 3.158 a 0.226 clct[np.int64(8), np.int64(12)] cl_acc 0.500  2.492sec\n",
      "Epoch 6 tr: l 2.765 a 0.312 clct[np.int64(44), np.int64(56)] cl_acc 0.500  lr 0.097037 17.588sec(train) 4.612sec(infer)\n",
      "Epoch 6 tst: l 2.885 a 0.278 clct[np.int64(10), np.int64(10)] cl_acc 0.600  2.515sec\n",
      "Epoch 7 tr: l 2.522 a 0.358 clct[np.int64(45), np.int64(55)] cl_acc 0.530  lr 0.096552 18.073sec(train) 4.165sec(infer)\n",
      "Epoch 7 tst: l 2.650 a 0.324 clct[np.int64(9), np.int64(11)] cl_acc 0.550  2.236sec\n",
      "Epoch 8 tr: l 2.292 a 0.383 clct[np.int64(46), np.int64(54)] cl_acc 0.560  lr 0.096069 18.113sec(train) 3.592sec(infer)\n",
      "Epoch 8 tst: l 2.427 a 0.365 clct[np.int64(11), np.int64(9)] cl_acc 0.550  2.178sec\n",
      "Epoch 9 tr: l 2.134 a 0.426 clct[np.int64(49), np.int64(51)] cl_acc 0.590  lr 0.095589 18.948sec(train) 4.130sec(infer)\n",
      "Epoch 9 tst: l 2.258 a 0.406 clct[np.int64(12), np.int64(8)] cl_acc 0.500  1.486sec\n",
      "Epoch 10 tr: l 1.931 a 0.461 clct[np.int64(47), np.int64(53)] cl_acc 0.630  lr 0.095111 19.206sec(train) 3.214sec(infer)\n",
      "Epoch 10 tst: l 2.064 a 0.436 clct[np.int64(13), np.int64(7)] cl_acc 0.650  1.461sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 11 tr: l 1.808 a 0.490 clct[np.int64(43), np.int64(57)] cl_acc 0.830  lr 0.094635 19.472sec(train) 3.726sec(infer)\n",
      "Epoch 11 tst: l 1.943 a 0.464 clct[np.int64(14), np.int64(6)] cl_acc 0.700  2.097sec\n",
      "Epoch 12 tr: l 1.567 a 0.561 clct[np.int64(48), np.int64(52)] cl_acc 0.980  lr 0.094162 18.901sec(train) 3.962sec(infer)\n",
      "Epoch 12 tst: l 1.724 a 0.527 clct[np.int64(11), np.int64(9)] cl_acc 0.950  1.809sec\n",
      "Epoch 13 tr: l 1.366 a 0.621 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.093691 18.303sec(train) 4.101sec(infer)\n",
      "Epoch 13 tst: l 1.490 a 0.593 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.411sec\n",
      "Epoch 14 tr: l 1.217 a 0.654 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.093223 18.140sec(train) 4.596sec(infer)\n",
      "Epoch 14 tst: l 1.340 a 0.634 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.508sec\n",
      "Epoch 15 tr: l 1.122 a 0.672 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.092757 17.976sec(train) 4.007sec(infer)\n",
      "Epoch 15 tst: l 1.242 a 0.653 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.227sec\n",
      "Epoch 16 tr: l 1.024 a 0.697 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.092293 18.160sec(train) 4.510sec(infer)\n",
      "Epoch 16 tst: l 1.144 a 0.681 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.512sec\n",
      "Epoch 17 tr: l 0.953 a 0.711 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.091832 17.821sec(train) 4.592sec(infer)\n",
      "Epoch 17 tst: l 1.077 a 0.692 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.781sec\n",
      "Epoch 18 tr: l 0.886 a 0.728 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.091372 18.415sec(train) 3.614sec(infer)\n",
      "Epoch 18 tst: l 1.011 a 0.707 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.981sec\n",
      "Epoch 19 tr: l 0.841 a 0.742 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.090916 18.638sec(train) 3.895sec(infer)\n",
      "Epoch 19 tst: l 0.964 a 0.720 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.524sec\n",
      "Epoch 20 tr: l 0.809 a 0.746 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.090461 18.256sec(train) 3.810sec(infer)\n",
      "Epoch 20 tst: l 0.933 a 0.726 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.196sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 21 tr: l 0.775 a 0.758 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.090009 17.818sec(train) 4.148sec(infer)\n",
      "Epoch 21 tst: l 0.888 a 0.739 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.218sec\n",
      "Epoch 22 tr: l 0.749 a 0.762 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.089559 18.153sec(train) 4.258sec(infer)\n",
      "Epoch 22 tst: l 0.871 a 0.741 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.499sec\n",
      "Epoch 23 tr: l 0.727 a 0.770 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.089111 17.977sec(train) 4.604sec(infer)\n",
      "Epoch 23 tst: l 0.841 a 0.752 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.460sec\n",
      "Epoch 24 tr: l 0.720 a 0.769 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.088665 17.951sec(train) 3.954sec(infer)\n",
      "Epoch 24 tst: l 0.870 a 0.740 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.204sec\n",
      "Epoch 25 tr: l 0.674 a 0.785 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.088222 18.062sec(train) 4.577sec(infer)\n",
      "Epoch 25 tst: l 0.796 a 0.764 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.174sec\n",
      "Epoch 26 tr: l 0.658 a 0.786 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.087781 18.443sec(train) 3.938sec(infer)\n",
      "Epoch 26 tst: l 0.782 a 0.764 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.698sec\n",
      "Epoch 27 tr: l 0.640 a 0.792 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.087342 18.985sec(train) 3.281sec(infer)\n",
      "Epoch 27 tst: l 0.765 a 0.773 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.492sec\n",
      "Epoch 28 tr: l 0.629 a 0.794 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.086905 18.535sec(train) 4.236sec(infer)\n",
      "Epoch 28 tst: l 0.758 a 0.771 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.520sec\n",
      "Epoch 29 tr: l 0.616 a 0.798 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.086471 18.361sec(train) 3.539sec(infer)\n",
      "Epoch 29 tst: l 0.740 a 0.777 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.230sec\n",
      "Epoch 30 tr: l 0.605 a 0.800 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.086038 18.630sec(train) 3.881sec(infer)\n",
      "Epoch 30 tst: l 0.731 a 0.778 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.506sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 31 tr: l 0.592 a 0.804 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.085608 18.770sec(train) 3.986sec(infer)\n",
      "Epoch 31 tst: l 0.717 a 0.782 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.178sec\n",
      "Epoch 32 tr: l 0.583 a 0.807 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.085180 19.040sec(train) 3.390sec(infer)\n",
      "Epoch 32 tst: l 0.707 a 0.785 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.193sec\n",
      "Epoch 33 tr: l 0.573 a 0.808 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.084754 18.998sec(train) 3.744sec(infer)\n",
      "Epoch 33 tst: l 0.700 a 0.787 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.949sec\n",
      "Epoch 34 tr: l 0.567 a 0.811 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.084331 19.504sec(train) 2.799sec(infer)\n",
      "Epoch 34 tst: l 0.693 a 0.790 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.577sec\n",
      "Epoch 35 tr: l 0.554 a 0.814 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.083909 19.762sec(train) 2.993sec(infer)\n",
      "Epoch 35 tst: l 0.681 a 0.791 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.142sec\n",
      "Epoch 36 tr: l 0.545 a 0.817 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.083489 18.995sec(train) 4.211sec(infer)\n",
      "Epoch 36 tst: l 0.678 a 0.793 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.124sec\n",
      "Epoch 37 tr: l 0.536 a 0.819 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.083072 18.660sec(train) 3.722sec(infer)\n",
      "Epoch 37 tst: l 0.667 a 0.797 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.828sec\n",
      "Epoch 38 tr: l 0.529 a 0.823 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.082657 18.468sec(train) 4.468sec(infer)\n",
      "Epoch 38 tst: l 0.660 a 0.798 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.151sec\n",
      "Epoch 39 tr: l 0.524 a 0.824 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.082243 18.170sec(train) 4.601sec(infer)\n",
      "Epoch 39 tst: l 0.649 a 0.801 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.831sec\n",
      "Epoch 40 tr: l 0.516 a 0.824 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.081832 18.056sec(train) 3.925sec(infer)\n",
      "Epoch 40 tst: l 0.650 a 0.800 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.170sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 41 tr: l 0.518 a 0.824 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.081423 18.231sec(train) 4.426sec(infer)\n",
      "Epoch 41 tst: l 0.645 a 0.802 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.144sec\n",
      "Epoch 42 tr: l 0.514 a 0.825 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.081016 18.555sec(train) 3.578sec(infer)\n",
      "Epoch 42 tst: l 0.639 a 0.803 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.931sec\n",
      "Epoch 43 tr: l 0.502 a 0.830 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.080611 18.596sec(train) 3.706sec(infer)\n",
      "Epoch 43 tst: l 0.631 a 0.807 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.504sec\n",
      "Epoch 44 tr: l 0.497 a 0.830 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.080208 18.050sec(train) 4.578sec(infer)\n",
      "Epoch 44 tst: l 0.627 a 0.806 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.486sec\n",
      "Epoch 45 tr: l 0.491 a 0.833 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.079807 18.081sec(train) 3.923sec(infer)\n",
      "Epoch 45 tst: l 0.621 a 0.809 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.214sec\n",
      "Epoch 46 tr: l 0.483 a 0.834 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.079408 17.805sec(train) 4.509sec(infer)\n",
      "Epoch 46 tst: l 0.617 a 0.810 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.519sec\n",
      "Epoch 47 tr: l 0.479 a 0.836 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.079010 17.755sec(train) 4.599sec(infer)\n",
      "Epoch 47 tst: l 0.617 a 0.811 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.102sec\n",
      "Epoch 48 tr: l 0.474 a 0.838 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.078615 17.936sec(train) 4.084sec(infer)\n",
      "Epoch 48 tst: l 0.605 a 0.813 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.202sec\n",
      "Epoch 49 tr: l 0.466 a 0.838 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.078222 18.061sec(train) 4.296sec(infer)\n",
      "Epoch 49 tst: l 0.606 a 0.815 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.112sec\n",
      "Epoch 50 tr: l 0.467 a 0.840 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.077831 18.585sec(train) 3.444sec(infer)\n",
      "Epoch 50 tst: l 0.598 a 0.816 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.980sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 51 tr: l 0.464 a 0.840 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.077442 18.647sec(train) 3.816sec(infer)\n",
      "Epoch 51 tst: l 0.604 a 0.814 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.505sec\n",
      "Epoch 52 tr: l 0.456 a 0.842 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.077055 18.131sec(train) 4.529sec(infer)\n",
      "Epoch 52 tst: l 0.592 a 0.819 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.426sec\n",
      "Epoch 53 tr: l 0.454 a 0.842 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.076670 18.349sec(train) 3.820sec(infer)\n",
      "Epoch 53 tst: l 0.590 a 0.817 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.251sec\n",
      "Epoch 54 tr: l 0.451 a 0.841 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.076286 18.450sec(train) 4.337sec(infer)\n",
      "Epoch 54 tst: l 0.591 a 0.818 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.525sec\n",
      "Epoch 55 tr: l 0.450 a 0.843 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.075905 18.430sec(train) 3.963sec(infer)\n",
      "Epoch 55 tst: l 0.584 a 0.820 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.143sec\n",
      "Epoch 56 tr: l 0.445 a 0.845 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.075525 18.704sec(train) 3.524sec(infer)\n",
      "Epoch 56 tst: l 0.582 a 0.820 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.110sec\n",
      "Epoch 57 tr: l 0.443 a 0.844 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.075148 19.273sec(train) 3.453sec(infer)\n",
      "Epoch 57 tst: l 0.583 a 0.821 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.126sec\n",
      "Epoch 58 tr: l 0.440 a 0.847 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.074772 19.632sec(train) 2.489sec(infer)\n",
      "Epoch 58 tst: l 0.578 a 0.822 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.117sec\n",
      "Epoch 59 tr: l 0.431 a 0.848 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.074398 19.355sec(train) 3.565sec(infer)\n",
      "Epoch 59 tst: l 0.576 a 0.823 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.343sec\n",
      "Epoch 60 tr: l 0.428 a 0.851 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.074026 19.046sec(train) 3.910sec(infer)\n",
      "Epoch 60 tst: l 0.569 a 0.824 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.726sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 61 tr: l 0.424 a 0.851 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.073656 19.161sec(train) 3.403sec(infer)\n",
      "Epoch 61 tst: l 0.568 a 0.826 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.071sec\n",
      "Epoch 62 tr: l 0.420 a 0.853 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.073288 18.897sec(train) 4.196sec(infer)\n",
      "Epoch 62 tst: l 0.563 a 0.826 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.152sec\n",
      "Epoch 63 tr: l 0.419 a 0.852 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.072921 18.625sec(train) 3.920sec(infer)\n",
      "Epoch 63 tst: l 0.565 a 0.826 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.802sec\n",
      "Epoch 64 tr: l 0.415 a 0.855 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.072557 18.703sec(train) 4.075sec(infer)\n",
      "Epoch 64 tst: l 0.557 a 0.827 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.754sec\n",
      "Epoch 65 tr: l 0.415 a 0.853 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.072194 18.860sec(train) 4.057sec(infer)\n",
      "Epoch 65 tst: l 0.562 a 0.827 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.944sec\n",
      "Epoch 66 tr: l 0.410 a 0.856 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.071833 18.866sec(train) 3.276sec(infer)\n",
      "Epoch 66 tst: l 0.553 a 0.828 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.180sec\n",
      "Epoch 67 tr: l 0.412 a 0.855 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.071474 18.381sec(train) 4.384sec(infer)\n",
      "Epoch 67 tst: l 0.555 a 0.829 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.539sec\n",
      "Epoch 68 tr: l 0.406 a 0.857 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.071116 18.050sec(train) 4.480sec(infer)\n",
      "Epoch 68 tst: l 0.552 a 0.829 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.093sec\n",
      "Epoch 69 tr: l 0.408 a 0.856 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.070761 18.165sec(train) 4.051sec(infer)\n",
      "Epoch 69 tst: l 0.553 a 0.830 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.495sec\n",
      "Epoch 70 tr: l 0.403 a 0.858 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.070407 17.875sec(train) 4.600sec(infer)\n",
      "Epoch 70 tst: l 0.546 a 0.830 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.539sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 71 tr: l 0.402 a 0.858 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.070055 17.799sec(train) 4.170sec(infer)\n",
      "Epoch 71 tst: l 0.549 a 0.832 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.194sec\n",
      "Epoch 72 tr: l 0.399 a 0.860 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.069705 18.109sec(train) 4.190sec(infer)\n",
      "Epoch 72 tst: l 0.539 a 0.834 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.120sec\n",
      "Epoch 73 tr: l 0.399 a 0.859 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.069356 18.384sec(train) 4.070sec(infer)\n",
      "Epoch 73 tst: l 0.551 a 0.831 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.096sec\n",
      "Epoch 74 tr: l 0.393 a 0.861 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.069009 18.670sec(train) 3.355sec(infer)\n",
      "Epoch 74 tst: l 0.536 a 0.835 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.196sec\n",
      "Epoch 75 tr: l 0.395 a 0.860 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.068664 18.429sec(train) 4.544sec(infer)\n",
      "Epoch 75 tst: l 0.541 a 0.834 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.512sec\n",
      "Epoch 76 tr: l 0.387 a 0.863 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.068321 18.130sec(train) 4.423sec(infer)\n",
      "Epoch 76 tst: l 0.532 a 0.836 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.130sec\n",
      "Epoch 77 tr: l 0.387 a 0.862 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.067979 18.025sec(train) 4.088sec(infer)\n",
      "Epoch 77 tst: l 0.536 a 0.835 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.407sec\n",
      "Epoch 78 tr: l 0.382 a 0.864 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.067639 18.072sec(train) 4.605sec(infer)\n",
      "Epoch 78 tst: l 0.530 a 0.837 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.533sec\n",
      "Epoch 79 tr: l 0.381 a 0.864 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.067301 18.079sec(train) 3.904sec(infer)\n",
      "Epoch 79 tst: l 0.532 a 0.836 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.150sec\n",
      "Epoch 80 tr: l 0.376 a 0.866 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.066965 18.473sec(train) 3.997sec(infer)\n",
      "Epoch 80 tst: l 0.526 a 0.837 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.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.380 a 0.865 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.066630 19.109sec(train) 3.570sec(infer)\n",
      "Epoch 81 tst: l 0.530 a 0.837 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.895sec\n",
      "Epoch 82 tr: l 0.375 a 0.867 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.066297 19.261sec(train) 3.300sec(infer)\n",
      "Epoch 82 tst: l 0.522 a 0.839 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.324sec\n",
      "Epoch 83 tr: l 0.373 a 0.866 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.065965 18.580sec(train) 4.059sec(infer)\n",
      "Epoch 83 tst: l 0.531 a 0.837 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.520sec\n",
      "Epoch 84 tr: l 0.371 a 0.867 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.065635 18.896sec(train) 3.475sec(infer)\n",
      "Epoch 84 tst: l 0.521 a 0.839 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.205sec\n",
      "Epoch 85 tr: l 0.374 a 0.866 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.065307 18.999sec(train) 3.572sec(infer)\n",
      "Epoch 85 tst: l 0.525 a 0.839 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.428sec\n",
      "Epoch 86 tr: l 0.367 a 0.867 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064981 18.911sec(train) 3.910sec(infer)\n",
      "Epoch 86 tst: l 0.520 a 0.839 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.206sec\n",
      "Epoch 87 tr: l 0.371 a 0.867 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064656 19.026sec(train) 3.101sec(infer)\n",
      "Epoch 87 tst: l 0.519 a 0.840 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.519sec\n",
      "Epoch 88 tr: l 0.367 a 0.867 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064333 19.335sec(train) 3.613sec(infer)\n",
      "Epoch 88 tst: l 0.520 a 0.840 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.770sec\n",
      "Epoch 89 tr: l 0.365 a 0.869 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064011 19.685sec(train) 3.272sec(infer)\n",
      "Epoch 89 tst: l 0.517 a 0.841 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.615sec\n",
      "Epoch 90 tr: l 0.364 a 0.868 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.063691 19.152sec(train) 3.457sec(infer)\n",
      "Epoch 90 tst: l 0.518 a 0.842 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.074sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 91 tr: l 0.360 a 0.870 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.063372 18.712sec(train) 4.570sec(infer)\n",
      "Epoch 91 tst: l 0.513 a 0.841 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.138sec\n",
      "Epoch 92 tr: l 0.363 a 0.870 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.063056 18.551sec(train) 4.082sec(infer)\n",
      "Epoch 92 tst: l 0.514 a 0.843 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.961sec\n",
      "Epoch 93 tr: l 0.358 a 0.871 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.062740 18.199sec(train) 4.366sec(infer)\n",
      "Epoch 93 tst: l 0.513 a 0.842 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.476sec\n",
      "Epoch 94 tr: l 0.356 a 0.871 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.062427 16.862sec(train) 4.597sec(infer)\n",
      "Epoch 94 tst: l 0.513 a 0.843 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.379sec\n",
      "Epoch 95 tr: l 0.356 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.062114 17.831sec(train) 3.981sec(infer)\n",
      "Epoch 95 tst: l 0.508 a 0.843 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.220sec\n",
      "Epoch 96 tr: l 0.355 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.061804 17.994sec(train) 4.599sec(infer)\n",
      "Epoch 96 tst: l 0.518 a 0.842 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.502sec\n",
      "Epoch 97 tr: l 0.354 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.061495 17.554sec(train) 4.524sec(infer)\n",
      "Epoch 97 tst: l 0.505 a 0.845 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.925sec\n",
      "Epoch 98 tr: l 0.351 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.061187 18.185sec(train) 3.780sec(infer)\n",
      "Epoch 98 tst: l 0.512 a 0.842 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.124sec\n",
      "Epoch 99 tr: l 0.350 a 0.873 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.060881 18.713sec(train) 3.913sec(infer)\n",
      "Epoch 99 tst: l 0.502 a 0.845 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.334sec\n",
      "Epoch 100 tr: l 0.364 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.006058 18.491sec(train) 3.501sec(infer)\n",
      "Epoch 100 tst: l 0.493 a 0.848 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.242sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 101 tr: l 0.367 a 0.871 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.006027 18.152sec(train) 4.336sec(infer)\n",
      "Epoch 101 tst: l 0.488 a 0.849 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.552sec\n",
      "Epoch 102 tr: l 0.369 a 0.871 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005997 17.992sec(train) 4.657sec(infer)\n",
      "Epoch 102 tst: l 0.486 a 0.850 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.293sec\n",
      "Epoch 103 tr: l 0.369 a 0.871 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005967 17.976sec(train) 4.058sec(infer)\n",
      "Epoch 103 tst: l 0.485 a 0.850 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.314sec\n",
      "Epoch 104 tr: l 0.368 a 0.871 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005937 17.904sec(train) 4.619sec(infer)\n",
      "Epoch 104 tst: l 0.485 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.522sec\n",
      "Epoch 105 tr: l 0.367 a 0.871 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005908 18.134sec(train) 4.319sec(infer)\n",
      "Epoch 105 tst: l 0.484 a 0.850 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.037sec\n",
      "Epoch 106 tr: l 0.366 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005878 18.374sec(train) 3.774sec(infer)\n",
      "Epoch 106 tst: l 0.484 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.120sec\n",
      "Epoch 107 tr: l 0.368 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005849 18.977sec(train) 3.711sec(infer)\n",
      "Epoch 107 tst: l 0.484 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.318sec\n",
      "Epoch 108 tr: l 0.367 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005820 19.143sec(train) 3.112sec(infer)\n",
      "Epoch 108 tst: l 0.483 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.210sec\n",
      "Epoch 109 tr: l 0.366 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005790 18.587sec(train) 4.043sec(infer)\n",
      "Epoch 109 tst: l 0.483 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.541sec\n",
      "Epoch 110 tr: l 0.366 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005762 18.656sec(train) 3.955sec(infer)\n",
      "Epoch 110 tst: l 0.482 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.100sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 111 tr: l 0.365 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005733 18.883sec(train) 3.397sec(infer)\n",
      "Epoch 111 tst: l 0.482 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.453sec\n",
      "Epoch 112 tr: l 0.364 a 0.873 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005704 18.973sec(train) 3.914sec(infer)\n",
      "Epoch 112 tst: l 0.482 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.383sec\n",
      "Epoch 113 tr: l 0.365 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005676 18.912sec(train) 3.336sec(infer)\n",
      "Epoch 113 tst: l 0.482 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.593sec\n",
      "Epoch 114 tr: l 0.365 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005647 19.428sec(train) 3.352sec(infer)\n",
      "Epoch 114 tst: l 0.481 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.765sec\n",
      "Epoch 115 tr: l 0.366 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005619 19.647sec(train) 3.426sec(infer)\n",
      "Epoch 115 tst: l 0.481 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.792sec\n",
      "Epoch 116 tr: l 0.364 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005591 19.220sec(train) 3.279sec(infer)\n",
      "Epoch 116 tst: l 0.482 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.839sec\n",
      "Epoch 117 tr: l 0.364 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005563 18.631sec(train) 4.510sec(infer)\n",
      "Epoch 117 tst: l 0.481 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.143sec\n",
      "Epoch 118 tr: l 0.364 a 0.873 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005535 18.392sec(train) 4.453sec(infer)\n",
      "Epoch 118 tst: l 0.481 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.802sec\n",
      "Epoch 119 tr: l 0.363 a 0.873 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005507 18.394sec(train) 4.128sec(infer)\n",
      "Epoch 119 tst: l 0.481 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.448sec\n",
      "Epoch 120 tr: l 0.364 a 0.873 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005480 18.094sec(train) 4.594sec(infer)\n",
      "Epoch 120 tst: l 0.481 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.525sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 121 tr: l 0.364 a 0.873 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005452 17.949sec(train) 4.090sec(infer)\n",
      "Epoch 121 tst: l 0.481 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.983sec\n",
      "Epoch 122 tr: l 0.363 a 0.873 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005425 18.187sec(train) 4.111sec(infer)\n",
      "Epoch 122 tst: l 0.480 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.122sec\n",
      "Epoch 123 tr: l 0.363 a 0.873 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005398 18.543sec(train) 3.921sec(infer)\n",
      "Epoch 123 tst: l 0.480 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.076sec\n",
      "Epoch 124 tr: l 0.362 a 0.873 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005371 18.514sec(train) 3.508sec(infer)\n",
      "Epoch 124 tst: l 0.480 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.258sec\n",
      "Epoch 125 tr: l 0.362 a 0.873 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005344 18.139sec(train) 4.587sec(infer)\n",
      "Epoch 125 tst: l 0.480 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.528sec\n",
      "Epoch 126 tr: l 0.364 a 0.873 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005318 17.995sec(train) 4.294sec(infer)\n",
      "Epoch 126 tst: l 0.480 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.187sec\n",
      "Epoch 127 tr: l 0.362 a 0.873 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005291 17.802sec(train) 4.181sec(infer)\n",
      "Epoch 127 tst: l 0.480 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.491sec\n",
      "Epoch 128 tr: l 0.361 a 0.873 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005264 17.694sec(train) 4.581sec(infer)\n",
      "Epoch 128 tst: l 0.480 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.524sec\n",
      "Epoch 129 tr: l 0.362 a 0.873 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005238 17.828sec(train) 4.074sec(infer)\n",
      "Epoch 129 tst: l 0.480 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.128sec\n",
      "Epoch 130 tr: l 0.361 a 0.873 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005212 18.039sec(train) 3.886sec(infer)\n",
      "Epoch 130 tst: l 0.480 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.832sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 131 tr: l 0.361 a 0.873 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005186 18.657sec(train) 3.825sec(infer)\n",
      "Epoch 131 tst: l 0.479 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.246sec\n",
      "Epoch 132 tr: l 0.362 a 0.873 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005160 18.778sec(train) 3.888sec(infer)\n",
      "Epoch 132 tst: l 0.479 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.102sec\n",
      "Epoch 133 tr: l 0.362 a 0.873 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005134 18.531sec(train) 3.872sec(infer)\n",
      "Epoch 133 tst: l 0.479 a 0.853 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.464sec\n",
      "Epoch 134 tr: l 0.361 a 0.873 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005108 18.197sec(train) 4.214sec(infer)\n",
      "Epoch 134 tst: l 0.479 a 0.853 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.520sec\n",
      "Epoch 135 tr: l 0.362 a 0.873 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005083 18.507sec(train) 3.488sec(infer)\n",
      "Epoch 135 tst: l 0.479 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.221sec\n",
      "Epoch 136 tr: l 0.362 a 0.873 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005058 18.891sec(train) 3.764sec(infer)\n",
      "Epoch 136 tst: l 0.479 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.529sec\n",
      "Epoch 137 tr: l 0.362 a 0.873 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005032 18.758sec(train) 3.839sec(infer)\n",
      "Epoch 137 tst: l 0.479 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.885sec\n",
      "Epoch 138 tr: l 0.361 a 0.873 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005007 19.299sec(train) 3.083sec(infer)\n",
      "Epoch 138 tst: l 0.479 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.761sec\n",
      "Epoch 139 tr: l 0.360 a 0.874 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004982 19.713sec(train) 3.322sec(infer)\n",
      "Epoch 139 tst: l 0.479 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.962sec\n",
      "Epoch 140 tr: l 0.360 a 0.874 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004957 19.686sec(train) 3.005sec(infer)\n",
      "Epoch 140 tst: l 0.479 a 0.853 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.837sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 141 tr: l 0.361 a 0.874 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004932 18.927sec(train) 3.845sec(infer)\n",
      "Epoch 141 tst: l 0.478 a 0.853 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.160sec\n",
      "Epoch 142 tr: l 0.361 a 0.874 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004908 18.796sec(train) 4.419sec(infer)\n",
      "Epoch 142 tst: l 0.478 a 0.853 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.931sec\n",
      "Epoch 143 tr: l 0.359 a 0.874 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004883 18.594sec(train) 3.928sec(infer)\n",
      "Epoch 143 tst: l 0.478 a 0.853 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.926sec\n",
      "Epoch 144 tr: l 0.359 a 0.874 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004859 18.447sec(train) 4.595sec(infer)\n",
      "Epoch 144 tst: l 0.478 a 0.853 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.305sec\n",
      "Epoch 145 tr: l 0.359 a 0.874 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004834 18.176sec(train) 4.307sec(infer)\n",
      "Epoch 145 tst: l 0.478 a 0.853 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.809sec\n",
      "Epoch 146 tr: l 0.359 a 0.874 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004810 18.235sec(train) 3.872sec(infer)\n",
      "Epoch 146 tst: l 0.478 a 0.853 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.135sec\n",
      "Epoch 147 tr: l 0.360 a 0.874 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004786 18.565sec(train) 3.926sec(infer)\n",
      "Epoch 147 tst: l 0.478 a 0.853 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.257sec\n",
      "Epoch 148 tr: l 0.358 a 0.874 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004762 18.675sec(train) 3.498sec(infer)\n",
      "Epoch 148 tst: l 0.478 a 0.853 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.190sec\n",
      "Epoch 149 tr: l 0.359 a 0.874 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004738 18.039sec(train) 4.608sec(infer)\n",
      "Epoch 149 tst: l 0.478 a 0.853 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.548sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "---train cluster Ended in 1.03 hour (3722.107 sec) \n",
      "---------------------------------DFCA-LI, lr: 0.1, seed: 6930---------------------------------\n",
      "config: {'m': 100, 'm_test': 20, 'p': 2, 'n': 1500, 'uneven': True, 'local_model_init': True, 'Gp': 0.15, 'graph': 'er', 'agg': 'seq', 'h1': 512, 'num_epochs': 150, 'batch_size': 100, 'tau': 5, 'lr': 0.1, 'data_seed': 6930, 'train_seed': 6930, 'config_override': '', 'project_dir': 'output_dfca_gi'}\n",
      "Using device: cuda:3\n",
      "Epoch -1 tr: l 3.864 a 0.023 clct[np.int64(51), np.int64(49)] cl_acc 0.510  4.081sec\n",
      "Epoch -1 tst: l 3.872 a 0.023 clct[np.int64(12), np.int64(8)] cl_acc 0.500  1.971sec\n",
      "Epoch 0 tr: l 3.745 a 0.193 clct[np.int64(50), np.int64(50)] cl_acc 0.520  lr 0.100000 18.654sec(train) 4.495sec(infer)\n",
      "Epoch 0 tst: l 3.815 a 0.083 clct[np.int64(14), np.int64(6)] cl_acc 0.600  1.784sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 1 tr: l 3.723 a 0.179 clct[np.int64(51), np.int64(49)] cl_acc 0.510  lr 0.099500 18.798sec(train) 3.405sec(infer)\n",
      "Epoch 1 tst: l 3.795 a 0.114 clct[np.int64(12), np.int64(8)] cl_acc 0.500  1.860sec\n",
      "Epoch 2 tr: l 3.667 a 0.137 clct[np.int64(52), np.int64(48)] cl_acc 0.520  lr 0.099003 18.711sec(train) 4.065sec(infer)\n",
      "Epoch 2 tst: l 3.749 a 0.108 clct[np.int64(15), np.int64(5)] cl_acc 0.650  2.448sec\n",
      "Epoch 3 tr: l 3.515 a 0.159 clct[np.int64(52), np.int64(48)] cl_acc 0.520  lr 0.098507 18.048sec(train) 4.691sec(infer)\n",
      "Epoch 3 tst: l 3.624 a 0.123 clct[np.int64(15), np.int64(5)] cl_acc 0.650  2.107sec\n",
      "Epoch 4 tr: l 3.283 a 0.214 clct[np.int64(54), np.int64(46)] cl_acc 0.520  lr 0.098015 18.029sec(train) 4.152sec(infer)\n",
      "Epoch 4 tst: l 3.400 a 0.175 clct[np.int64(14), np.int64(6)] cl_acc 0.600  2.453sec\n",
      "Epoch 5 tr: l 3.016 a 0.274 clct[np.int64(56), np.int64(44)] cl_acc 0.520  lr 0.097525 17.799sec(train) 4.716sec(infer)\n",
      "Epoch 5 tst: l 3.142 a 0.225 clct[np.int64(15), np.int64(5)] cl_acc 0.550  2.369sec\n",
      "Epoch 6 tr: l 2.764 a 0.322 clct[np.int64(55), np.int64(45)] cl_acc 0.530  lr 0.097037 17.951sec(train) 4.121sec(infer)\n",
      "Epoch 6 tst: l 2.891 a 0.285 clct[np.int64(15), np.int64(5)] cl_acc 0.650  2.181sec\n",
      "Epoch 7 tr: l 2.510 a 0.370 clct[np.int64(54), np.int64(46)] cl_acc 0.580  lr 0.096552 18.081sec(train) 4.562sec(infer)\n",
      "Epoch 7 tst: l 2.649 a 0.337 clct[np.int64(13), np.int64(7)] cl_acc 0.550  2.309sec\n",
      "Epoch 8 tr: l 2.274 a 0.407 clct[np.int64(55), np.int64(45)] cl_acc 0.650  lr 0.096069 17.945sec(train) 4.452sec(infer)\n",
      "Epoch 8 tst: l 2.404 a 0.375 clct[np.int64(13), np.int64(7)] cl_acc 0.650  1.708sec\n",
      "Epoch 9 tr: l 2.062 a 0.462 clct[np.int64(54), np.int64(46)] cl_acc 0.800  lr 0.095589 18.494sec(train) 3.429sec(infer)\n",
      "Epoch 9 tst: l 2.174 a 0.424 clct[np.int64(12), np.int64(8)] cl_acc 0.900  2.126sec\n",
      "Epoch 10 tr: l 1.844 a 0.503 clct[np.int64(53), np.int64(47)] cl_acc 0.950  lr 0.095111 18.427sec(train) 4.208sec(infer)\n",
      "Epoch 10 tst: l 1.966 a 0.470 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.492sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 11 tr: l 1.554 a 0.583 clct[np.int64(50), np.int64(50)] cl_acc 0.980  lr 0.094635 18.219sec(train) 4.229sec(infer)\n",
      "Epoch 11 tst: l 1.638 a 0.566 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.222sec\n",
      "Epoch 12 tr: l 1.337 a 0.633 clct[np.int64(50), np.int64(50)] cl_acc 0.980  lr 0.094162 18.040sec(train) 4.371sec(infer)\n",
      "Epoch 12 tst: l 1.438 a 0.618 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.493sec\n",
      "Epoch 13 tr: l 1.206 a 0.655 clct[np.int64(50), np.int64(50)] cl_acc 0.980  lr 0.093691 17.635sec(train) 3.999sec(infer)\n",
      "Epoch 13 tst: l 1.283 a 0.648 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.035sec\n",
      "Epoch 14 tr: l 1.112 a 0.674 clct[np.int64(50), np.int64(50)] cl_acc 0.980  lr 0.093223 19.029sec(train) 3.353sec(infer)\n",
      "Epoch 14 tst: l 1.186 a 0.669 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.914sec\n",
      "Epoch 15 tr: l 1.023 a 0.689 clct[np.int64(50), np.int64(50)] cl_acc 0.980  lr 0.092757 18.931sec(train) 4.187sec(infer)\n",
      "Epoch 15 tst: l 1.104 a 0.680 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.856sec\n",
      "Epoch 16 tr: l 0.982 a 0.704 clct[np.int64(49), np.int64(51)] cl_acc 0.990  lr 0.092293 19.027sec(train) 3.690sec(infer)\n",
      "Epoch 16 tst: l 1.058 a 0.692 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.330sec\n",
      "Epoch 17 tr: l 0.911 a 0.719 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.091832 19.241sec(train) 3.328sec(infer)\n",
      "Epoch 17 tst: l 0.981 a 0.711 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.869sec\n",
      "Epoch 18 tr: l 0.868 a 0.734 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.091372 19.013sec(train) 4.189sec(infer)\n",
      "Epoch 18 tst: l 0.938 a 0.724 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.159sec\n",
      "Epoch 19 tr: l 0.811 a 0.746 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.090916 18.244sec(train) 3.932sec(infer)\n",
      "Epoch 19 tst: l 0.901 a 0.731 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.022sec\n",
      "Epoch 20 tr: l 0.786 a 0.752 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.090461 18.145sec(train) 4.671sec(infer)\n",
      "Epoch 20 tst: l 0.869 a 0.740 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.512sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 21 tr: l 0.752 a 0.760 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.090009 18.035sec(train) 4.563sec(infer)\n",
      "Epoch 21 tst: l 0.841 a 0.748 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.118sec\n",
      "Epoch 22 tr: l 0.732 a 0.763 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.089559 18.095sec(train) 4.242sec(infer)\n",
      "Epoch 22 tst: l 0.819 a 0.750 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.475sec\n",
      "Epoch 23 tr: l 0.706 a 0.772 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.089111 17.896sec(train) 4.737sec(infer)\n",
      "Epoch 23 tst: l 0.802 a 0.757 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.296sec\n",
      "Epoch 24 tr: l 0.685 a 0.779 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.088665 17.891sec(train) 3.863sec(infer)\n",
      "Epoch 24 tst: l 0.775 a 0.763 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.806sec\n",
      "Epoch 25 tr: l 0.669 a 0.783 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.088222 18.661sec(train) 3.936sec(infer)\n",
      "Epoch 25 tst: l 0.760 a 0.771 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.281sec\n",
      "Epoch 26 tr: l 0.652 a 0.788 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.087781 18.444sec(train) 4.046sec(infer)\n",
      "Epoch 26 tst: l 0.749 a 0.770 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.084sec\n",
      "Epoch 27 tr: l 0.632 a 0.792 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.087342 18.110sec(train) 4.190sec(infer)\n",
      "Epoch 27 tst: l 0.730 a 0.777 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.493sec\n",
      "Epoch 28 tr: l 0.619 a 0.797 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.086905 17.913sec(train) 4.771sec(infer)\n",
      "Epoch 28 tst: l 0.715 a 0.781 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.454sec\n",
      "Epoch 29 tr: l 0.605 a 0.799 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.086471 17.937sec(train) 4.054sec(infer)\n",
      "Epoch 29 tst: l 0.705 a 0.784 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.176sec\n",
      "Epoch 30 tr: l 0.592 a 0.804 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.086038 17.847sec(train) 4.567sec(infer)\n",
      "Epoch 30 tst: l 0.696 a 0.786 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.484sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 31 tr: l 0.588 a 0.803 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.085608 17.843sec(train) 4.640sec(infer)\n",
      "Epoch 31 tst: l 0.695 a 0.788 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.808sec\n",
      "Epoch 32 tr: l 0.576 a 0.807 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.085180 18.427sec(train) 3.780sec(infer)\n",
      "Epoch 32 tst: l 0.683 a 0.789 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.051sec\n",
      "Epoch 33 tr: l 0.564 a 0.811 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.084754 18.904sec(train) 3.761sec(infer)\n",
      "Epoch 33 tst: l 0.672 a 0.795 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.356sec\n",
      "Epoch 34 tr: l 0.556 a 0.813 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.084331 18.978sec(train) 3.222sec(infer)\n",
      "Epoch 34 tst: l 0.663 a 0.795 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.184sec\n",
      "Epoch 35 tr: l 0.548 a 0.815 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.083909 18.646sec(train) 4.052sec(infer)\n",
      "Epoch 35 tst: l 0.657 a 0.799 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.496sec\n",
      "Epoch 36 tr: l 0.542 a 0.816 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.083489 18.685sec(train) 4.055sec(infer)\n",
      "Epoch 36 tst: l 0.650 a 0.799 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.050sec\n",
      "Epoch 37 tr: l 0.536 a 0.818 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.083072 18.922sec(train) 3.428sec(infer)\n",
      "Epoch 37 tst: l 0.644 a 0.801 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.373sec\n",
      "Epoch 38 tr: l 0.530 a 0.819 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.082657 18.917sec(train) 3.992sec(infer)\n",
      "Epoch 38 tst: l 0.635 a 0.804 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.256sec\n",
      "Epoch 39 tr: l 0.518 a 0.823 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.082243 19.028sec(train) 3.367sec(infer)\n",
      "Epoch 39 tst: l 0.629 a 0.805 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.547sec\n",
      "Epoch 40 tr: l 0.514 a 0.824 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.081832 19.387sec(train) 3.542sec(infer)\n",
      "Epoch 40 tst: l 0.624 a 0.807 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.719sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 41 tr: l 0.504 a 0.827 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.081423 19.703sec(train) 3.513sec(infer)\n",
      "Epoch 41 tst: l 0.618 a 0.807 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.552sec\n",
      "Epoch 42 tr: l 0.502 a 0.828 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.081016 19.306sec(train) 3.544sec(infer)\n",
      "Epoch 42 tst: l 0.616 a 0.810 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.981sec\n",
      "Epoch 43 tr: l 0.493 a 0.831 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.080611 18.728sec(train) 4.658sec(infer)\n",
      "Epoch 43 tst: l 0.609 a 0.809 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.100sec\n",
      "Epoch 44 tr: l 0.487 a 0.832 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.080208 18.237sec(train) 4.200sec(infer)\n",
      "Epoch 44 tst: l 0.604 a 0.814 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.901sec\n",
      "Epoch 45 tr: l 0.479 a 0.834 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.079807 18.307sec(train) 4.522sec(infer)\n",
      "Epoch 45 tst: l 0.599 a 0.812 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.401sec\n",
      "Epoch 46 tr: l 0.477 a 0.834 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.079408 17.866sec(train) 4.685sec(infer)\n",
      "Epoch 46 tst: l 0.593 a 0.816 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.223sec\n",
      "Epoch 47 tr: l 0.470 a 0.837 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.079010 18.044sec(train) 4.109sec(infer)\n",
      "Epoch 47 tst: l 0.590 a 0.816 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.028sec\n",
      "Epoch 48 tr: l 0.466 a 0.837 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.078615 18.431sec(train) 4.318sec(infer)\n",
      "Epoch 48 tst: l 0.587 a 0.818 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.070sec\n",
      "Epoch 49 tr: l 0.466 a 0.838 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.078222 18.585sec(train) 3.342sec(infer)\n",
      "Epoch 49 tst: l 0.584 a 0.819 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.156sec\n",
      "Epoch 50 tr: l 0.461 a 0.838 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.077831 18.431sec(train) 4.111sec(infer)\n",
      "Epoch 50 tst: l 0.580 a 0.820 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.467sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 51 tr: l 0.455 a 0.841 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.077442 17.740sec(train) 4.712sec(infer)\n",
      "Epoch 51 tst: l 0.576 a 0.821 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.184sec\n",
      "Epoch 52 tr: l 0.450 a 0.842 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.077055 18.011sec(train) 4.152sec(infer)\n",
      "Epoch 52 tst: l 0.573 a 0.823 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.335sec\n",
      "Epoch 53 tr: l 0.443 a 0.846 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.076670 17.692sec(train) 4.735sec(infer)\n",
      "Epoch 53 tst: l 0.569 a 0.824 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.469sec\n",
      "Epoch 54 tr: l 0.443 a 0.844 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.076286 17.728sec(train) 4.330sec(infer)\n",
      "Epoch 54 tst: l 0.566 a 0.825 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.181sec\n",
      "Epoch 55 tr: l 0.441 a 0.845 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.075905 17.859sec(train) 4.263sec(infer)\n",
      "Epoch 55 tst: l 0.564 a 0.824 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.165sec\n",
      "Epoch 56 tr: l 0.437 a 0.846 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.075525 18.327sec(train) 4.320sec(infer)\n",
      "Epoch 56 tst: l 0.560 a 0.826 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.987sec\n",
      "Epoch 57 tr: l 0.431 a 0.849 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.075148 18.939sec(train) 3.222sec(infer)\n",
      "Epoch 57 tst: l 0.557 a 0.826 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.170sec\n",
      "Epoch 58 tr: l 0.431 a 0.848 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.074772 18.768sec(train) 4.293sec(infer)\n",
      "Epoch 58 tst: l 0.558 a 0.827 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.454sec\n",
      "Epoch 59 tr: l 0.424 a 0.851 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.074398 18.331sec(train) 3.947sec(infer)\n",
      "Epoch 59 tst: l 0.551 a 0.827 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.151sec\n",
      "Epoch 60 tr: l 0.423 a 0.849 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.074026 18.364sec(train) 3.842sec(infer)\n",
      "Epoch 60 tst: l 0.553 a 0.829 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.465sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 61 tr: l 0.419 a 0.853 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.073656 18.368sec(train) 4.049sec(infer)\n",
      "Epoch 61 tst: l 0.545 a 0.830 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.439sec\n",
      "Epoch 62 tr: l 0.417 a 0.852 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.073288 18.903sec(train) 3.302sec(infer)\n",
      "Epoch 62 tst: l 0.546 a 0.831 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.012sec\n",
      "Epoch 63 tr: l 0.413 a 0.855 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.072921 18.974sec(train) 3.763sec(infer)\n",
      "Epoch 63 tst: l 0.541 a 0.831 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.919sec\n",
      "Epoch 64 tr: l 0.409 a 0.854 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.072557 19.706sec(train) 2.908sec(infer)\n",
      "Epoch 64 tst: l 0.542 a 0.831 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.459sec\n",
      "Epoch 65 tr: l 0.407 a 0.856 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.072194 19.839sec(train) 2.967sec(infer)\n",
      "Epoch 65 tst: l 0.536 a 0.832 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.072sec\n",
      "Epoch 66 tr: l 0.405 a 0.855 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.071833 19.024sec(train) 4.281sec(infer)\n",
      "Epoch 66 tst: l 0.536 a 0.832 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.099sec\n",
      "Epoch 67 tr: l 0.403 a 0.858 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.071474 18.702sec(train) 3.778sec(infer)\n",
      "Epoch 67 tst: l 0.533 a 0.833 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.799sec\n",
      "Epoch 68 tr: l 0.399 a 0.857 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.071116 18.505sec(train) 4.592sec(infer)\n",
      "Epoch 68 tst: l 0.532 a 0.834 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.100sec\n",
      "Epoch 69 tr: l 0.398 a 0.859 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.070761 18.369sec(train) 4.605sec(infer)\n",
      "Epoch 69 tst: l 0.530 a 0.835 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.712sec\n",
      "Epoch 70 tr: l 0.396 a 0.859 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.070407 18.129sec(train) 4.165sec(infer)\n",
      "Epoch 70 tst: l 0.527 a 0.835 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.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.394 a 0.859 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.070055 18.257sec(train) 4.478sec(infer)\n",
      "Epoch 71 tst: l 0.526 a 0.836 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.067sec\n",
      "Epoch 72 tr: l 0.394 a 0.860 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.069705 18.442sec(train) 3.375sec(infer)\n",
      "Epoch 72 tst: l 0.523 a 0.837 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.016sec\n",
      "Epoch 73 tr: l 0.389 a 0.861 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.069356 18.664sec(train) 4.081sec(infer)\n",
      "Epoch 73 tst: l 0.522 a 0.837 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.524sec\n",
      "Epoch 74 tr: l 0.385 a 0.862 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.069009 18.139sec(train) 4.701sec(infer)\n",
      "Epoch 74 tst: l 0.521 a 0.838 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.102sec\n",
      "Epoch 75 tr: l 0.386 a 0.862 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.068664 18.071sec(train) 4.053sec(infer)\n",
      "Epoch 75 tst: l 0.521 a 0.838 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.464sec\n",
      "Epoch 76 tr: l 0.382 a 0.863 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.068321 16.896sec(train) 4.599sec(infer)\n",
      "Epoch 76 tst: l 0.519 a 0.839 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.479sec\n",
      "Epoch 77 tr: l 0.380 a 0.864 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.067979 18.034sec(train) 4.168sec(infer)\n",
      "Epoch 77 tst: l 0.515 a 0.839 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.197sec\n",
      "Epoch 78 tr: l 0.377 a 0.865 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.067639 18.058sec(train) 4.498sec(infer)\n",
      "Epoch 78 tst: l 0.514 a 0.840 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.518sec\n",
      "Epoch 79 tr: l 0.377 a 0.865 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.067301 17.976sec(train) 4.709sec(infer)\n",
      "Epoch 79 tst: l 0.511 a 0.841 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.139sec\n",
      "Epoch 80 tr: l 0.373 a 0.866 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.066965 18.105sec(train) 4.128sec(infer)\n",
      "Epoch 80 tst: l 0.513 a 0.841 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.257sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 81 tr: l 0.371 a 0.867 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.066630 18.085sec(train) 4.569sec(infer)\n",
      "Epoch 81 tst: l 0.508 a 0.841 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.126sec\n",
      "Epoch 82 tr: l 0.370 a 0.866 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.066297 18.751sec(train) 3.363sec(infer)\n",
      "Epoch 82 tst: l 0.510 a 0.842 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.951sec\n",
      "Epoch 83 tr: l 0.366 a 0.869 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.065965 19.026sec(train) 3.797sec(infer)\n",
      "Epoch 83 tst: l 0.504 a 0.842 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.477sec\n",
      "Epoch 84 tr: l 0.367 a 0.867 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.065635 18.408sec(train) 4.332sec(infer)\n",
      "Epoch 84 tst: l 0.509 a 0.842 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.064sec\n",
      "Epoch 85 tr: l 0.363 a 0.870 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.065307 18.367sec(train) 3.638sec(infer)\n",
      "Epoch 85 tst: l 0.500 a 0.843 clct[np.int64(10), np.int64(10)] cl_acc 1.000  2.373sec\n",
      "Epoch 86 tr: l 0.368 a 0.867 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064981 18.347sec(train) 2.869sec(infer)\n",
      "Epoch 86 tst: l 0.505 a 0.843 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.849sec\n",
      "Epoch 87 tr: l 0.364 a 0.870 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064656 15.136sec(train) 2.737sec(infer)\n",
      "Epoch 87 tst: l 0.500 a 0.843 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.771sec\n",
      "Epoch 88 tr: l 0.363 a 0.869 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064333 15.294sec(train) 2.728sec(infer)\n",
      "Epoch 88 tst: l 0.501 a 0.845 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.329sec\n",
      "Epoch 89 tr: l 0.359 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064011 15.853sec(train) 2.215sec(infer)\n",
      "Epoch 89 tst: l 0.498 a 0.844 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.260sec\n",
      "Epoch 90 tr: l 0.357 a 0.870 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.063691 16.278sec(train) 2.185sec(infer)\n",
      "Epoch 90 tst: l 0.500 a 0.845 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.460sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 91 tr: l 0.354 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.063372 15.678sec(train) 2.803sec(infer)\n",
      "Epoch 91 tst: l 0.494 a 0.845 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.431sec\n",
      "Epoch 92 tr: l 0.355 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.063056 15.121sec(train) 3.125sec(infer)\n",
      "Epoch 92 tst: l 0.496 a 0.846 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.440sec\n",
      "Epoch 93 tr: l 0.353 a 0.873 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.062740 14.914sec(train) 3.327sec(infer)\n",
      "Epoch 93 tst: l 0.493 a 0.846 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.358sec\n",
      "Epoch 94 tr: l 0.349 a 0.873 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.062427 14.616sec(train) 3.498sec(infer)\n",
      "Epoch 94 tst: l 0.494 a 0.846 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.546sec\n",
      "Epoch 95 tr: l 0.347 a 0.874 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.062114 14.331sec(train) 3.468sec(infer)\n",
      "Epoch 95 tst: l 0.493 a 0.846 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.644sec\n",
      "Epoch 96 tr: l 0.347 a 0.874 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.061804 14.391sec(train) 3.219sec(infer)\n",
      "Epoch 96 tst: l 0.493 a 0.845 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.474sec\n",
      "Epoch 97 tr: l 0.347 a 0.875 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.061495 15.009sec(train) 2.741sec(infer)\n",
      "Epoch 97 tst: l 0.490 a 0.848 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.707sec\n",
      "Epoch 98 tr: l 0.345 a 0.875 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.061187 14.853sec(train) 3.109sec(infer)\n",
      "Epoch 98 tst: l 0.490 a 0.846 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.869sec\n",
      "Epoch 99 tr: l 0.341 a 0.875 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.060881 14.354sec(train) 3.446sec(infer)\n",
      "Epoch 99 tst: l 0.489 a 0.848 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.848sec\n",
      "Epoch 100 tr: l 0.357 a 0.873 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.006058 14.183sec(train) 3.483sec(infer)\n",
      "Epoch 100 tst: l 0.479 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.824sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 101 tr: l 0.361 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.006027 14.285sec(train) 3.457sec(infer)\n",
      "Epoch 101 tst: l 0.476 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.852sec\n",
      "Epoch 102 tr: l 0.364 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005997 14.228sec(train) 3.498sec(infer)\n",
      "Epoch 102 tst: l 0.475 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.841sec\n",
      "Epoch 103 tr: l 0.361 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005967 14.373sec(train) 3.468sec(infer)\n",
      "Epoch 103 tst: l 0.473 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.454sec\n",
      "Epoch 104 tr: l 0.363 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005937 14.600sec(train) 3.038sec(infer)\n",
      "Epoch 104 tst: l 0.473 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.449sec\n",
      "Epoch 105 tr: l 0.360 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005908 15.219sec(train) 2.879sec(infer)\n",
      "Epoch 105 tst: l 0.472 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.847sec\n",
      "Epoch 106 tr: l 0.360 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005878 14.857sec(train) 3.421sec(infer)\n",
      "Epoch 106 tst: l 0.472 a 0.853 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.846sec\n",
      "Epoch 107 tr: l 0.361 a 0.873 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005849 14.512sec(train) 3.339sec(infer)\n",
      "Epoch 107 tst: l 0.472 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.861sec\n",
      "Epoch 108 tr: l 0.361 a 0.873 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005820 14.728sec(train) 3.197sec(infer)\n",
      "Epoch 108 tst: l 0.471 a 0.853 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.868sec\n",
      "Epoch 109 tr: l 0.361 a 0.873 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005790 14.781sec(train) 3.063sec(infer)\n",
      "Epoch 109 tst: l 0.471 a 0.853 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.838sec\n",
      "Epoch 110 tr: l 0.360 a 0.873 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005762 15.040sec(train) 2.864sec(infer)\n",
      "Epoch 110 tst: l 0.471 a 0.853 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.447sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 111 tr: l 0.360 a 0.873 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005733 15.562sec(train) 2.297sec(infer)\n",
      "Epoch 111 tst: l 0.471 a 0.853 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.559sec\n",
      "Epoch 112 tr: l 0.359 a 0.873 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005704 15.867sec(train) 2.255sec(infer)\n",
      "Epoch 112 tst: l 0.470 a 0.853 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.816sec\n",
      "Epoch 113 tr: l 0.360 a 0.873 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005676 15.371sec(train) 2.681sec(infer)\n",
      "Epoch 113 tst: l 0.470 a 0.853 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.736sec\n",
      "Epoch 114 tr: l 0.359 a 0.873 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005647 15.281sec(train) 2.715sec(infer)\n",
      "Epoch 114 tst: l 0.470 a 0.853 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.579sec\n",
      "Epoch 115 tr: l 0.359 a 0.873 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005619 15.409sec(train) 2.711sec(infer)\n",
      "Epoch 115 tst: l 0.470 a 0.853 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.474sec\n",
      "Epoch 116 tr: l 0.359 a 0.873 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005591 15.267sec(train) 2.907sec(infer)\n",
      "Epoch 116 tst: l 0.470 a 0.853 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.451sec\n",
      "Epoch 117 tr: l 0.358 a 0.873 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005563 15.008sec(train) 3.094sec(infer)\n",
      "Epoch 117 tst: l 0.470 a 0.854 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.200sec\n",
      "Epoch 118 tr: l 0.357 a 0.874 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005535 15.253sec(train) 2.964sec(infer)\n",
      "Epoch 118 tst: l 0.470 a 0.853 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.041sec\n",
      "Epoch 119 tr: l 0.359 a 0.873 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005507 15.354sec(train) 2.780sec(infer)\n",
      "Epoch 119 tst: l 0.469 a 0.853 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.591sec\n",
      "Epoch 120 tr: l 0.359 a 0.873 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005480 14.859sec(train) 3.163sec(infer)\n",
      "Epoch 120 tst: l 0.469 a 0.853 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.821sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 121 tr: l 0.358 a 0.873 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005452 14.294sec(train) 3.435sec(infer)\n",
      "Epoch 121 tst: l 0.469 a 0.854 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.828sec\n",
      "Epoch 122 tr: l 0.358 a 0.874 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005425 14.311sec(train) 3.317sec(infer)\n",
      "Epoch 122 tst: l 0.469 a 0.854 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.843sec\n",
      "Epoch 123 tr: l 0.358 a 0.874 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005398 14.097sec(train) 3.484sec(infer)\n",
      "Epoch 123 tst: l 0.469 a 0.854 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.840sec\n",
      "Epoch 124 tr: l 0.357 a 0.874 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005371 14.240sec(train) 3.487sec(infer)\n",
      "Epoch 124 tst: l 0.469 a 0.854 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.841sec\n",
      "Epoch 125 tr: l 0.356 a 0.874 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005344 14.146sec(train) 3.456sec(infer)\n",
      "Epoch 125 tst: l 0.468 a 0.853 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.444sec\n",
      "Epoch 126 tr: l 0.357 a 0.874 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005318 14.712sec(train) 2.957sec(infer)\n",
      "Epoch 126 tst: l 0.468 a 0.854 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.507sec\n",
      "Epoch 127 tr: l 0.357 a 0.874 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005291 14.832sec(train) 2.930sec(infer)\n",
      "Epoch 127 tst: l 0.468 a 0.854 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.828sec\n",
      "Epoch 128 tr: l 0.357 a 0.874 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005264 14.486sec(train) 3.418sec(infer)\n",
      "Epoch 128 tst: l 0.468 a 0.854 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.855sec\n",
      "Epoch 129 tr: l 0.356 a 0.874 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005238 14.305sec(train) 3.469sec(infer)\n",
      "Epoch 129 tst: l 0.468 a 0.854 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.868sec\n",
      "Epoch 130 tr: l 0.357 a 0.874 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005212 14.291sec(train) 3.469sec(infer)\n",
      "Epoch 130 tst: l 0.467 a 0.854 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.847sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 131 tr: l 0.356 a 0.874 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005186 14.463sec(train) 3.335sec(infer)\n",
      "Epoch 131 tst: l 0.467 a 0.854 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.831sec\n",
      "Epoch 132 tr: l 0.356 a 0.874 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005160 14.637sec(train) 3.363sec(infer)\n",
      "Epoch 132 tst: l 0.467 a 0.854 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.489sec\n",
      "Epoch 133 tr: l 0.356 a 0.874 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005134 15.115sec(train) 2.836sec(infer)\n",
      "Epoch 133 tst: l 0.467 a 0.854 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.455sec\n",
      "Epoch 134 tr: l 0.356 a 0.874 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005108 15.724sec(train) 2.710sec(infer)\n",
      "Epoch 134 tst: l 0.467 a 0.854 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.813sec\n",
      "Epoch 135 tr: l 0.356 a 0.874 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005083 15.019sec(train) 2.994sec(infer)\n",
      "Epoch 135 tst: l 0.467 a 0.854 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.805sec\n",
      "Epoch 136 tr: l 0.356 a 0.874 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005058 14.931sec(train) 2.929sec(infer)\n",
      "Epoch 136 tst: l 0.467 a 0.854 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.841sec\n",
      "Epoch 137 tr: l 0.356 a 0.874 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005032 15.089sec(train) 2.778sec(infer)\n",
      "Epoch 137 tst: l 0.467 a 0.854 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.827sec\n",
      "Epoch 138 tr: l 0.355 a 0.874 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005007 15.301sec(train) 2.743sec(infer)\n",
      "Epoch 138 tst: l 0.467 a 0.854 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.749sec\n",
      "Epoch 139 tr: l 0.355 a 0.874 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004982 15.317sec(train) 2.595sec(infer)\n",
      "Epoch 139 tst: l 0.466 a 0.854 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.220sec\n",
      "Epoch 140 tr: l 0.355 a 0.874 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004957 15.896sec(train) 2.176sec(infer)\n",
      "Epoch 140 tst: l 0.466 a 0.854 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.195sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 141 tr: l 0.354 a 0.875 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004932 16.142sec(train) 2.166sec(infer)\n",
      "Epoch 141 tst: l 0.467 a 0.854 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.402sec\n",
      "Epoch 142 tr: l 0.354 a 0.874 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004908 15.541sec(train) 2.867sec(infer)\n",
      "Epoch 142 tst: l 0.466 a 0.854 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.476sec\n",
      "Epoch 143 tr: l 0.354 a 0.875 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004883 15.118sec(train) 3.163sec(infer)\n",
      "Epoch 143 tst: l 0.466 a 0.854 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.485sec\n",
      "Epoch 144 tr: l 0.353 a 0.875 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004859 14.678sec(train) 3.431sec(infer)\n",
      "Epoch 144 tst: l 0.466 a 0.854 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.444sec\n",
      "Epoch 145 tr: l 0.354 a 0.875 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004834 14.410sec(train) 3.472sec(infer)\n",
      "Epoch 145 tst: l 0.466 a 0.854 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.668sec\n",
      "Epoch 146 tr: l 0.353 a 0.875 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004810 14.298sec(train) 3.453sec(infer)\n",
      "Epoch 146 tst: l 0.466 a 0.854 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.650sec\n",
      "Epoch 147 tr: l 0.354 a 0.875 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004786 14.337sec(train) 3.192sec(infer)\n",
      "Epoch 147 tst: l 0.466 a 0.854 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.454sec\n",
      "Epoch 148 tr: l 0.354 a 0.875 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004762 14.898sec(train) 2.756sec(infer)\n",
      "Epoch 148 tst: l 0.465 a 0.854 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.734sec\n",
      "Epoch 149 tr: l 0.353 a 0.875 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004738 14.840sec(train) 3.085sec(infer)\n",
      "Epoch 149 tst: l 0.465 a 0.854 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.859sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "---train cluster Ended in 0.94 hour (3401.964 sec) \n",
      "---------------------------------DFCA-LI, lr: 0.1, seed: 6753---------------------------------\n",
      "config: {'m': 100, 'm_test': 20, 'p': 2, 'n': 1500, 'uneven': True, 'local_model_init': True, 'Gp': 0.15, 'graph': 'er', 'agg': 'seq', 'h1': 512, 'num_epochs': 150, 'batch_size': 100, 'tau': 5, 'lr': 0.1, 'data_seed': 6753, 'train_seed': 6753, 'config_override': '', 'project_dir': 'output_dfca_gi'}\n",
      "Using device: cuda:3\n",
      "Epoch -1 tr: l 3.866 a 0.023 clct[np.int64(42), np.int64(58)] cl_acc 0.540  3.482sec\n",
      "Epoch -1 tst: l 3.871 a 0.023 clct[np.int64(12), np.int64(8)] cl_acc 0.500  1.683sec\n",
      "Epoch 0 tr: l 3.750 a 0.197 clct[np.int64(44), np.int64(56)] cl_acc 0.540  lr 0.100000 14.408sec(train) 3.493sec(infer)\n",
      "Epoch 0 tst: l 3.798 a 0.090 clct[np.int64(7), np.int64(13)] cl_acc 0.550  1.866sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 1 tr: l 3.731 a 0.190 clct[np.int64(45), np.int64(55)] cl_acc 0.530  lr 0.099500 14.217sec(train) 3.462sec(infer)\n",
      "Epoch 1 tst: l 3.764 a 0.119 clct[np.int64(9), np.int64(11)] cl_acc 0.650  1.625sec\n",
      "Epoch 2 tr: l 3.697 a 0.155 clct[np.int64(47), np.int64(53)] cl_acc 0.510  lr 0.099003 14.464sec(train) 3.096sec(infer)\n",
      "Epoch 2 tst: l 3.722 a 0.126 clct[np.int64(8), np.int64(12)] cl_acc 0.600  1.538sec\n",
      "Epoch 3 tr: l 3.557 a 0.173 clct[np.int64(46), np.int64(54)] cl_acc 0.500  lr 0.098507 14.959sec(train) 2.824sec(infer)\n",
      "Epoch 3 tst: l 3.619 a 0.148 clct[np.int64(9), np.int64(11)] cl_acc 0.550  1.903sec\n",
      "Epoch 4 tr: l 3.318 a 0.220 clct[np.int64(46), np.int64(54)] cl_acc 0.500  lr 0.098015 14.507sec(train) 3.301sec(infer)\n",
      "Epoch 4 tst: l 3.416 a 0.175 clct[np.int64(10), np.int64(10)] cl_acc 0.700  1.941sec\n",
      "Epoch 5 tr: l 3.046 a 0.265 clct[np.int64(47), np.int64(53)] cl_acc 0.510  lr 0.097525 14.187sec(train) 3.508sec(infer)\n",
      "Epoch 5 tst: l 3.156 a 0.222 clct[np.int64(10), np.int64(10)] cl_acc 0.600  1.938sec\n",
      "Epoch 6 tr: l 2.761 a 0.314 clct[np.int64(52), np.int64(48)] cl_acc 0.560  lr 0.097037 14.215sec(train) 3.497sec(infer)\n",
      "Epoch 6 tst: l 2.900 a 0.271 clct[np.int64(11), np.int64(9)] cl_acc 0.650  1.938sec\n",
      "Epoch 7 tr: l 2.488 a 0.348 clct[np.int64(57), np.int64(43)] cl_acc 0.610  lr 0.096552 14.023sec(train) 3.496sec(infer)\n",
      "Epoch 7 tst: l 2.633 a 0.315 clct[np.int64(12), np.int64(8)] cl_acc 0.700  1.925sec\n",
      "Epoch 8 tr: l 2.295 a 0.393 clct[np.int64(55), np.int64(45)] cl_acc 0.750  lr 0.096069 14.089sec(train) 3.465sec(infer)\n",
      "Epoch 8 tst: l 2.410 a 0.376 clct[np.int64(12), np.int64(8)] cl_acc 0.900  1.870sec\n",
      "Epoch 9 tr: l 2.021 a 0.467 clct[np.int64(50), np.int64(50)] cl_acc 0.920  lr 0.095589 14.246sec(train) 3.357sec(infer)\n",
      "Epoch 9 tst: l 2.143 a 0.437 clct[np.int64(11), np.int64(9)] cl_acc 0.950  1.542sec\n",
      "Epoch 10 tr: l 1.796 a 0.516 clct[np.int64(49), np.int64(51)] cl_acc 0.970  lr 0.095111 14.733sec(train) 2.859sec(infer)\n",
      "Epoch 10 tst: l 1.915 a 0.493 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.672sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 11 tr: l 1.537 a 0.579 clct[np.int64(50), np.int64(50)] cl_acc 0.980  lr 0.094635 15.107sec(train) 3.005sec(infer)\n",
      "Epoch 11 tst: l 1.678 a 0.565 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.953sec\n",
      "Epoch 12 tr: l 1.370 a 0.612 clct[np.int64(49), np.int64(51)] cl_acc 0.990  lr 0.094162 14.690sec(train) 3.400sec(infer)\n",
      "Epoch 12 tst: l 1.485 a 0.597 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.927sec\n",
      "Epoch 13 tr: l 1.245 a 0.630 clct[np.int64(49), np.int64(51)] cl_acc 0.990  lr 0.093691 14.559sec(train) 3.246sec(infer)\n",
      "Epoch 13 tst: l 1.348 a 0.626 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.926sec\n",
      "Epoch 14 tr: l 1.129 a 0.672 clct[np.int64(49), np.int64(51)] cl_acc 0.990  lr 0.093223 14.700sec(train) 3.140sec(infer)\n",
      "Epoch 14 tst: l 1.220 a 0.664 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.921sec\n",
      "Epoch 15 tr: l 1.046 a 0.681 clct[np.int64(49), np.int64(51)] cl_acc 0.990  lr 0.092757 14.928sec(train) 3.023sec(infer)\n",
      "Epoch 15 tst: l 1.133 a 0.674 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.779sec\n",
      "Epoch 16 tr: l 0.980 a 0.698 clct[np.int64(49), np.int64(51)] cl_acc 0.990  lr 0.092293 15.008sec(train) 2.561sec(infer)\n",
      "Epoch 16 tst: l 1.096 a 0.683 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.520sec\n",
      "Epoch 17 tr: l 0.909 a 0.716 clct[np.int64(49), np.int64(51)] cl_acc 0.990  lr 0.091832 15.565sec(train) 2.197sec(infer)\n",
      "Epoch 17 tst: l 1.002 a 0.705 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.664sec\n",
      "Epoch 18 tr: l 0.858 a 0.735 clct[np.int64(49), np.int64(51)] cl_acc 0.990  lr 0.091372 15.715sec(train) 2.309sec(infer)\n",
      "Epoch 18 tst: l 0.948 a 0.721 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.299sec\n",
      "Epoch 19 tr: l 0.810 a 0.742 clct[np.int64(49), np.int64(51)] cl_acc 0.990  lr 0.090916 14.415sec(train) 3.452sec(infer)\n",
      "Epoch 19 tst: l 0.923 a 0.729 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.927sec\n",
      "Epoch 20 tr: l 0.793 a 0.751 clct[np.int64(49), np.int64(51)] cl_acc 0.990  lr 0.090461 14.264sec(train) 3.485sec(infer)\n",
      "Epoch 20 tst: l 0.914 a 0.738 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.939sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 21 tr: l 0.767 a 0.754 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.090009 14.230sec(train) 3.490sec(infer)\n",
      "Epoch 21 tst: l 0.857 a 0.741 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.921sec\n",
      "Epoch 22 tr: l 0.738 a 0.763 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.089559 14.260sec(train) 3.486sec(infer)\n",
      "Epoch 22 tst: l 0.891 a 0.748 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.917sec\n",
      "Epoch 23 tr: l 0.712 a 0.767 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.089111 14.027sec(train) 3.492sec(infer)\n",
      "Epoch 23 tst: l 0.801 a 0.754 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.624sec\n",
      "Epoch 24 tr: l 0.688 a 0.776 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.088665 14.586sec(train) 3.104sec(infer)\n",
      "Epoch 24 tst: l 0.805 a 0.761 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.528sec\n",
      "Epoch 25 tr: l 0.666 a 0.781 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.088222 14.965sec(train) 2.791sec(infer)\n",
      "Epoch 25 tst: l 0.769 a 0.765 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.880sec\n",
      "Epoch 26 tr: l 0.654 a 0.787 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.087781 14.599sec(train) 3.236sec(infer)\n",
      "Epoch 26 tst: l 0.754 a 0.774 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.928sec\n",
      "Epoch 27 tr: l 0.635 a 0.790 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.087342 14.109sec(train) 3.497sec(infer)\n",
      "Epoch 27 tst: l 0.732 a 0.775 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.925sec\n",
      "Epoch 28 tr: l 0.622 a 0.795 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.086905 14.263sec(train) 3.471sec(infer)\n",
      "Epoch 28 tst: l 0.720 a 0.780 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.933sec\n",
      "Epoch 29 tr: l 0.610 a 0.799 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.086471 14.271sec(train) 3.501sec(infer)\n",
      "Epoch 29 tst: l 0.705 a 0.780 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.960sec\n",
      "Epoch 30 tr: l 0.599 a 0.799 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.086038 14.537sec(train) 3.356sec(infer)\n",
      "Epoch 30 tst: l 0.717 a 0.782 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.756sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 31 tr: l 0.587 a 0.801 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.085608 14.808sec(train) 2.971sec(infer)\n",
      "Epoch 31 tst: l 0.698 a 0.782 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.531sec\n",
      "Epoch 32 tr: l 0.572 a 0.808 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.085180 15.344sec(train) 2.456sec(infer)\n",
      "Epoch 32 tst: l 0.717 a 0.788 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.885sec\n",
      "Epoch 33 tr: l 0.573 a 0.807 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.084754 15.242sec(train) 2.956sec(infer)\n",
      "Epoch 33 tst: l 0.663 a 0.790 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.946sec\n",
      "Epoch 34 tr: l 0.573 a 0.809 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.084331 14.609sec(train) 3.015sec(infer)\n",
      "Epoch 34 tst: l 0.705 a 0.790 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.911sec\n",
      "Epoch 35 tr: l 0.552 a 0.812 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.083909 14.960sec(train) 2.880sec(infer)\n",
      "Epoch 35 tst: l 0.659 a 0.795 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.917sec\n",
      "Epoch 36 tr: l 0.537 a 0.817 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.083489 15.110sec(train) 2.824sec(infer)\n",
      "Epoch 36 tst: l 0.644 a 0.797 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.818sec\n",
      "Epoch 37 tr: l 0.528 a 0.819 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.083072 15.367sec(train) 2.793sec(infer)\n",
      "Epoch 37 tst: l 0.634 a 0.800 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.521sec\n",
      "Epoch 38 tr: l 0.522 a 0.822 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.082657 15.587sec(train) 2.456sec(infer)\n",
      "Epoch 38 tst: l 0.626 a 0.802 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.214sec\n",
      "Epoch 39 tr: l 0.531 a 0.823 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.082243 16.024sec(train) 2.009sec(infer)\n",
      "Epoch 39 tst: l 0.675 a 0.802 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.394sec\n",
      "Epoch 40 tr: l 0.510 a 0.825 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.081832 15.676sec(train) 2.506sec(infer)\n",
      "Epoch 40 tst: l 0.624 a 0.804 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.538sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 41 tr: l 0.506 a 0.826 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.081423 14.945sec(train) 3.212sec(infer)\n",
      "Epoch 41 tst: l 0.673 a 0.805 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.514sec\n",
      "Epoch 42 tr: l 0.500 a 0.828 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.081016 14.736sec(train) 3.459sec(infer)\n",
      "Epoch 42 tst: l 0.609 a 0.810 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.537sec\n",
      "Epoch 43 tr: l 0.495 a 0.829 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.080611 14.447sec(train) 3.454sec(infer)\n",
      "Epoch 43 tst: l 0.597 a 0.808 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.627sec\n",
      "Epoch 44 tr: l 0.487 a 0.830 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.080208 14.230sec(train) 3.477sec(infer)\n",
      "Epoch 44 tst: l 0.613 a 0.808 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.915sec\n",
      "Epoch 45 tr: l 0.485 a 0.832 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.079807 14.198sec(train) 3.477sec(infer)\n",
      "Epoch 45 tst: l 0.591 a 0.811 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.655sec\n",
      "Epoch 46 tr: l 0.479 a 0.834 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.079408 14.246sec(train) 3.178sec(infer)\n",
      "Epoch 46 tst: l 0.636 a 0.813 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.510sec\n",
      "Epoch 47 tr: l 0.474 a 0.836 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.079010 14.972sec(train) 2.761sec(infer)\n",
      "Epoch 47 tst: l 0.581 a 0.813 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.841sec\n",
      "Epoch 48 tr: l 0.467 a 0.837 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.078615 14.636sec(train) 3.168sec(infer)\n",
      "Epoch 48 tst: l 0.587 a 0.818 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.912sec\n",
      "Epoch 49 tr: l 0.466 a 0.839 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.078222 14.217sec(train) 3.481sec(infer)\n",
      "Epoch 49 tst: l 0.574 a 0.814 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.935sec\n",
      "Epoch 50 tr: l 0.459 a 0.840 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.077831 14.253sec(train) 3.513sec(infer)\n",
      "Epoch 50 tst: l 0.589 a 0.820 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.932sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 51 tr: l 0.453 a 0.842 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.077442 14.180sec(train) 3.508sec(infer)\n",
      "Epoch 51 tst: l 0.567 a 0.817 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.932sec\n",
      "Epoch 52 tr: l 0.453 a 0.842 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.077055 14.303sec(train) 3.503sec(infer)\n",
      "Epoch 52 tst: l 0.605 a 0.819 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.875sec\n",
      "Epoch 53 tr: l 0.450 a 0.843 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.076670 14.207sec(train) 3.328sec(infer)\n",
      "Epoch 53 tst: l 0.589 a 0.817 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.555sec\n",
      "Epoch 54 tr: l 0.456 a 0.842 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.076286 14.625sec(train) 2.907sec(infer)\n",
      "Epoch 54 tst: l 0.556 a 0.821 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.601sec\n",
      "Epoch 55 tr: l 0.445 a 0.844 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.075905 15.084sec(train) 2.962sec(infer)\n",
      "Epoch 55 tst: l 0.593 a 0.819 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.908sec\n",
      "Epoch 56 tr: l 0.436 a 0.846 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.075525 14.745sec(train) 3.299sec(infer)\n",
      "Epoch 56 tst: l 0.560 a 0.823 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.933sec\n",
      "Epoch 57 tr: l 0.438 a 0.847 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.075148 13.796sec(train) 1.977sec(infer)\n",
      "Epoch 57 tst: l 0.548 a 0.822 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.149sec\n",
      "Epoch 58 tr: l 0.433 a 0.847 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.074772 10.003sec(train) 1.883sec(infer)\n",
      "Epoch 58 tst: l 0.553 a 0.825 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.168sec\n",
      "Epoch 59 tr: l 0.431 a 0.848 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.074398 9.990sec(train) 1.870sec(infer)\n",
      "Epoch 59 tst: l 0.555 a 0.822 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.162sec\n",
      "Epoch 60 tr: l 0.428 a 0.848 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.074026 10.043sec(train) 1.852sec(infer)\n",
      "Epoch 60 tst: l 0.540 a 0.824 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.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.424 a 0.851 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.073656 10.155sec(train) 1.795sec(infer)\n",
      "Epoch 61 tst: l 0.538 a 0.827 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.166sec\n",
      "Epoch 62 tr: l 0.419 a 0.851 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.073288 10.166sec(train) 1.778sec(infer)\n",
      "Epoch 62 tst: l 0.535 a 0.827 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.152sec\n",
      "Epoch 63 tr: l 0.425 a 0.852 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.072921 10.227sec(train) 1.753sec(infer)\n",
      "Epoch 63 tst: l 0.602 a 0.825 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.171sec\n",
      "Epoch 64 tr: l 0.414 a 0.852 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.072557 10.259sec(train) 1.735sec(infer)\n",
      "Epoch 64 tst: l 0.531 a 0.828 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.183sec\n",
      "Epoch 65 tr: l 0.407 a 0.854 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.072194 10.348sec(train) 1.729sec(infer)\n",
      "Epoch 65 tst: l 0.560 a 0.823 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.182sec\n",
      "Epoch 66 tr: l 0.407 a 0.855 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.071833 10.308sec(train) 1.727sec(infer)\n",
      "Epoch 66 tst: l 0.523 a 0.829 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.152sec\n",
      "Epoch 67 tr: l 0.402 a 0.855 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.071474 10.291sec(train) 1.671sec(infer)\n",
      "Epoch 67 tst: l 0.528 a 0.829 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.137sec\n",
      "Epoch 68 tr: l 0.411 a 0.856 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.071116 10.333sec(train) 1.617sec(infer)\n",
      "Epoch 68 tst: l 0.517 a 0.831 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.117sec\n",
      "Epoch 69 tr: l 0.401 a 0.856 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.070761 10.464sec(train) 1.547sec(infer)\n",
      "Epoch 69 tst: l 0.566 a 0.829 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.151sec\n",
      "Epoch 70 tr: l 0.393 a 0.858 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.070407 10.507sec(train) 1.541sec(infer)\n",
      "Epoch 70 tst: l 0.514 a 0.833 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.099sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 71 tr: l 0.393 a 0.859 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.070055 10.536sec(train) 1.460sec(infer)\n",
      "Epoch 71 tst: l 0.519 a 0.833 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.118sec\n",
      "Epoch 72 tr: l 0.389 a 0.860 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.069705 10.585sec(train) 1.486sec(infer)\n",
      "Epoch 72 tst: l 0.511 a 0.834 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.090sec\n",
      "Epoch 73 tr: l 0.388 a 0.859 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.069356 10.572sec(train) 1.437sec(infer)\n",
      "Epoch 73 tst: l 0.529 a 0.833 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.073sec\n",
      "Epoch 74 tr: l 0.386 a 0.860 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.069009 10.697sec(train) 1.441sec(infer)\n",
      "Epoch 74 tst: l 0.515 a 0.834 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.059sec\n",
      "Epoch 75 tr: l 0.384 a 0.862 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.068664 10.763sec(train) 1.407sec(infer)\n",
      "Epoch 75 tst: l 0.510 a 0.834 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.049sec\n",
      "Epoch 76 tr: l 0.387 a 0.862 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.068321 10.789sec(train) 1.418sec(infer)\n",
      "Epoch 76 tst: l 0.567 a 0.835 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.950sec\n",
      "Epoch 77 tr: l 0.379 a 0.863 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.067979 10.887sec(train) 1.380sec(infer)\n",
      "Epoch 77 tst: l 0.519 a 0.836 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.849sec\n",
      "Epoch 78 tr: l 0.378 a 0.863 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.067639 10.812sec(train) 1.248sec(infer)\n",
      "Epoch 78 tst: l 0.505 a 0.837 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.778sec\n",
      "Epoch 79 tr: l 0.375 a 0.864 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.067301 10.693sec(train) 1.425sec(infer)\n",
      "Epoch 79 tst: l 0.505 a 0.837 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.789sec\n",
      "Epoch 80 tr: l 0.376 a 0.864 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.066965 10.303sec(train) 1.888sec(infer)\n",
      "Epoch 80 tst: l 0.504 a 0.837 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.648sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 81 tr: l 0.379 a 0.865 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.066630 10.068sec(train) 2.017sec(infer)\n",
      "Epoch 81 tst: l 0.497 a 0.838 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.815sec\n",
      "Epoch 82 tr: l 0.371 a 0.866 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.066297 9.681sec(train) 2.032sec(infer)\n",
      "Epoch 82 tst: l 0.508 a 0.839 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.159sec\n",
      "Epoch 83 tr: l 0.372 a 0.864 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.065965 9.597sec(train) 2.058sec(infer)\n",
      "Epoch 83 tst: l 0.497 a 0.838 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.110sec\n",
      "Epoch 84 tr: l 0.365 a 0.866 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.065635 9.471sec(train) 2.073sec(infer)\n",
      "Epoch 84 tst: l 0.504 a 0.839 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.134sec\n",
      "Epoch 85 tr: l 0.371 a 0.866 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.065307 9.488sec(train) 2.052sec(infer)\n",
      "Epoch 85 tst: l 0.493 a 0.839 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.164sec\n",
      "Epoch 86 tr: l 0.362 a 0.868 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064981 9.480sec(train) 2.050sec(infer)\n",
      "Epoch 86 tst: l 0.497 a 0.841 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.153sec\n",
      "Epoch 87 tr: l 0.360 a 0.867 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064656 9.523sec(train) 2.070sec(infer)\n",
      "Epoch 87 tst: l 0.492 a 0.839 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.161sec\n",
      "Epoch 88 tr: l 0.361 a 0.870 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064333 9.504sec(train) 2.063sec(infer)\n",
      "Epoch 88 tst: l 0.488 a 0.841 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.172sec\n",
      "Epoch 89 tr: l 0.365 a 0.867 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.064011 9.560sec(train) 2.067sec(infer)\n",
      "Epoch 89 tst: l 0.496 a 0.841 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.161sec\n",
      "Epoch 90 tr: l 0.361 a 0.870 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.063691 9.574sec(train) 1.991sec(infer)\n",
      "Epoch 90 tst: l 0.488 a 0.840 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.148sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 91 tr: l 0.365 a 0.867 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.063372 9.684sec(train) 1.993sec(infer)\n",
      "Epoch 91 tst: l 0.506 a 0.841 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.175sec\n",
      "Epoch 92 tr: l 0.353 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.063056 9.821sec(train) 1.948sec(infer)\n",
      "Epoch 92 tst: l 0.487 a 0.840 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.163sec\n",
      "Epoch 93 tr: l 0.354 a 0.870 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.062740 9.966sec(train) 1.921sec(infer)\n",
      "Epoch 93 tst: l 0.492 a 0.842 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.174sec\n",
      "Epoch 94 tr: l 0.350 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.062427 10.067sec(train) 1.923sec(infer)\n",
      "Epoch 94 tst: l 0.483 a 0.842 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.162sec\n",
      "Epoch 95 tr: l 0.350 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.062114 10.138sec(train) 1.863sec(infer)\n",
      "Epoch 95 tst: l 0.485 a 0.843 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.159sec\n",
      "Epoch 96 tr: l 0.347 a 0.874 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.061804 10.144sec(train) 1.839sec(infer)\n",
      "Epoch 96 tst: l 0.478 a 0.844 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.156sec\n",
      "Epoch 97 tr: l 0.347 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.061495 10.108sec(train) 1.821sec(infer)\n",
      "Epoch 97 tst: l 0.502 a 0.843 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.155sec\n",
      "Epoch 98 tr: l 0.339 a 0.875 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.061187 10.259sec(train) 1.772sec(infer)\n",
      "Epoch 98 tst: l 0.479 a 0.845 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.177sec\n",
      "Epoch 99 tr: l 0.350 a 0.873 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.060881 10.205sec(train) 1.734sec(infer)\n",
      "Epoch 99 tst: l 0.477 a 0.844 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.173sec\n",
      "Epoch 100 tr: l 0.358 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.006058 10.266sec(train) 1.706sec(infer)\n",
      "Epoch 100 tst: l 0.465 a 0.848 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.167sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 101 tr: l 0.367 a 0.871 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.006027 10.283sec(train) 1.710sec(infer)\n",
      "Epoch 101 tst: l 0.462 a 0.849 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.155sec\n",
      "Epoch 102 tr: l 0.365 a 0.871 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005997 10.257sec(train) 1.636sec(infer)\n",
      "Epoch 102 tst: l 0.461 a 0.849 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.127sec\n",
      "Epoch 103 tr: l 0.367 a 0.870 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005967 10.379sec(train) 1.661sec(infer)\n",
      "Epoch 103 tst: l 0.460 a 0.850 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.136sec\n",
      "Epoch 104 tr: l 0.370 a 0.871 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005937 10.357sec(train) 1.657sec(infer)\n",
      "Epoch 104 tst: l 0.459 a 0.850 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.125sec\n",
      "Epoch 105 tr: l 0.364 a 0.871 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005908 10.360sec(train) 1.621sec(infer)\n",
      "Epoch 105 tst: l 0.460 a 0.850 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.149sec\n",
      "Epoch 106 tr: l 0.367 a 0.871 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005878 10.375sec(train) 1.557sec(infer)\n",
      "Epoch 106 tst: l 0.459 a 0.850 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.138sec\n",
      "Epoch 107 tr: l 0.364 a 0.871 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005849 10.456sec(train) 1.524sec(infer)\n",
      "Epoch 107 tst: l 0.459 a 0.850 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.104sec\n",
      "Epoch 108 tr: l 0.364 a 0.871 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005820 10.561sec(train) 1.509sec(infer)\n",
      "Epoch 108 tst: l 0.459 a 0.850 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.141sec\n",
      "Epoch 109 tr: l 0.363 a 0.871 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005790 10.556sec(train) 1.524sec(infer)\n",
      "Epoch 109 tst: l 0.459 a 0.850 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.127sec\n",
      "Epoch 110 tr: l 0.365 a 0.871 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005762 10.575sec(train) 1.475sec(infer)\n",
      "Epoch 110 tst: l 0.458 a 0.850 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.130sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 111 tr: l 0.368 a 0.871 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005733 10.540sec(train) 1.489sec(infer)\n",
      "Epoch 111 tst: l 0.458 a 0.850 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.121sec\n",
      "Epoch 112 tr: l 0.362 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005704 10.569sec(train) 1.410sec(infer)\n",
      "Epoch 112 tst: l 0.459 a 0.850 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.123sec\n",
      "Epoch 113 tr: l 0.363 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005676 10.614sec(train) 1.474sec(infer)\n",
      "Epoch 113 tst: l 0.457 a 0.850 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.109sec\n",
      "Epoch 114 tr: l 0.363 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005647 10.606sec(train) 1.451sec(infer)\n",
      "Epoch 114 tst: l 0.458 a 0.850 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.082sec\n",
      "Epoch 115 tr: l 0.362 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005619 10.607sec(train) 1.460sec(infer)\n",
      "Epoch 115 tst: l 0.458 a 0.850 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.094sec\n",
      "Epoch 116 tr: l 0.361 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005591 10.547sec(train) 1.442sec(infer)\n",
      "Epoch 116 tst: l 0.458 a 0.850 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.097sec\n",
      "Epoch 117 tr: l 0.362 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005563 10.649sec(train) 1.442sec(infer)\n",
      "Epoch 117 tst: l 0.457 a 0.850 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.104sec\n",
      "Epoch 118 tr: l 0.361 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005535 10.670sec(train) 1.428sec(infer)\n",
      "Epoch 118 tst: l 0.457 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.080sec\n",
      "Epoch 119 tr: l 0.365 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005507 10.740sec(train) 1.451sec(infer)\n",
      "Epoch 119 tst: l 0.457 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.075sec\n",
      "Epoch 120 tr: l 0.367 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005480 10.700sec(train) 1.411sec(infer)\n",
      "Epoch 120 tst: l 0.457 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.024sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 121 tr: l 0.362 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005452 10.788sec(train) 1.397sec(infer)\n",
      "Epoch 121 tst: l 0.456 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.005sec\n",
      "Epoch 122 tr: l 0.363 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005425 10.896sec(train) 1.376sec(infer)\n",
      "Epoch 122 tst: l 0.456 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.856sec\n",
      "Epoch 123 tr: l 0.361 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005398 10.787sec(train) 1.200sec(infer)\n",
      "Epoch 123 tst: l 0.456 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.791sec\n",
      "Epoch 124 tr: l 0.363 a 0.873 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005371 10.534sec(train) 1.565sec(infer)\n",
      "Epoch 124 tst: l 0.456 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.754sec\n",
      "Epoch 125 tr: l 0.361 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005344 10.169sec(train) 1.983sec(infer)\n",
      "Epoch 125 tst: l 0.456 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  0.623sec\n",
      "Epoch 126 tr: l 0.365 a 0.872 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005318 9.969sec(train) 2.051sec(infer)\n",
      "Epoch 126 tst: l 0.456 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.056sec\n",
      "Epoch 127 tr: l 0.358 a 0.873 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005291 9.614sec(train) 2.036sec(infer)\n",
      "Epoch 127 tst: l 0.457 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.162sec\n",
      "Epoch 128 tr: l 0.365 a 0.873 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005264 9.538sec(train) 2.049sec(infer)\n",
      "Epoch 128 tst: l 0.455 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.159sec\n",
      "Epoch 129 tr: l 0.360 a 0.873 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005238 9.577sec(train) 2.093sec(infer)\n",
      "Epoch 129 tst: l 0.455 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.128sec\n",
      "Epoch 130 tr: l 0.362 a 0.873 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005212 9.575sec(train) 2.069sec(infer)\n",
      "Epoch 130 tst: l 0.455 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.171sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "Epoch 131 tr: l 0.359 a 0.873 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005186 9.433sec(train) 2.080sec(infer)\n",
      "Epoch 131 tst: l 0.456 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.152sec\n",
      "Epoch 132 tr: l 0.362 a 0.873 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005160 9.382sec(train) 2.073sec(infer)\n",
      "Epoch 132 tst: l 0.455 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.165sec\n",
      "Epoch 133 tr: l 0.359 a 0.873 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005134 9.352sec(train) 2.068sec(infer)\n",
      "Epoch 133 tst: l 0.455 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.146sec\n",
      "Epoch 134 tr: l 0.358 a 0.873 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005108 9.489sec(train) 2.040sec(infer)\n",
      "Epoch 134 tst: l 0.455 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.156sec\n",
      "Epoch 135 tr: l 0.361 a 0.873 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005083 9.725sec(train) 1.982sec(infer)\n",
      "Epoch 135 tst: l 0.455 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.177sec\n",
      "Epoch 136 tr: l 0.362 a 0.873 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005058 9.853sec(train) 1.992sec(infer)\n",
      "Epoch 136 tst: l 0.455 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.150sec\n",
      "Epoch 137 tr: l 0.357 a 0.873 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005032 9.831sec(train) 1.915sec(infer)\n",
      "Epoch 137 tst: l 0.455 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.152sec\n",
      "Epoch 138 tr: l 0.364 a 0.873 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.005007 9.950sec(train) 1.834sec(infer)\n",
      "Epoch 138 tst: l 0.454 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.160sec\n",
      "Epoch 139 tr: l 0.359 a 0.873 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004982 10.004sec(train) 1.787sec(infer)\n",
      "Epoch 139 tst: l 0.454 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.164sec\n",
      "Epoch 140 tr: l 0.358 a 0.873 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004957 10.177sec(train) 1.744sec(infer)\n",
      "Epoch 140 tst: l 0.454 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.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.361 a 0.873 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004932 10.296sec(train) 1.864sec(infer)\n",
      "Epoch 141 tst: l 0.454 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.154sec\n",
      "Epoch 142 tr: l 0.361 a 0.873 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004908 10.108sec(train) 1.806sec(infer)\n",
      "Epoch 142 tst: l 0.454 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.171sec\n",
      "Epoch 143 tr: l 0.359 a 0.874 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004883 10.212sec(train) 1.626sec(infer)\n",
      "Epoch 143 tst: l 0.454 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.116sec\n",
      "Epoch 144 tr: l 0.360 a 0.873 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004859 10.347sec(train) 1.653sec(infer)\n",
      "Epoch 144 tst: l 0.454 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.135sec\n",
      "Epoch 145 tr: l 0.358 a 0.874 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004834 10.465sec(train) 1.531sec(infer)\n",
      "Epoch 145 tst: l 0.454 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.072sec\n",
      "Epoch 146 tr: l 0.359 a 0.873 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004810 10.503sec(train) 1.481sec(infer)\n",
      "Epoch 146 tst: l 0.454 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.094sec\n",
      "Epoch 147 tr: l 0.359 a 0.873 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004786 10.601sec(train) 1.443sec(infer)\n",
      "Epoch 147 tst: l 0.453 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.088sec\n",
      "Epoch 148 tr: l 0.356 a 0.874 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004762 10.593sec(train) 1.450sec(infer)\n",
      "Epoch 148 tst: l 0.454 a 0.851 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.049sec\n",
      "Epoch 149 tr: l 0.362 a 0.874 clct[np.int64(50), np.int64(50)] cl_acc 1.000  lr 0.004738 10.723sec(train) 1.400sec(infer)\n",
      "Epoch 149 tst: l 0.453 a 0.852 clct[np.int64(10), np.int64(10)] cl_acc 1.000  1.041sec\n",
      "result written at output_dfca_gi/results.pickle\n",
      "checkpoint written at output_dfca_gi/checkpoint.pt\n",
      "---train cluster Ended in 0.65 hour (2349.461 sec) \n"
     ]
    }
   ],
   "source": [
    "___.display_outputs()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Plots"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-19T06:26:17.183347Z",
     "iopub.status.busy": "2025-09-19T06:26:17.182589Z",
     "iopub.status.idle": "2025-09-19T06:26:18.163580Z",
     "shell.execute_reply": "2025-09-19T06:26:18.162564Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "DFCA-GI Acc:  [np.float64(85.71666666666667), np.float64(85.43333333333332), np.float64(85.38333333333334), np.float64(85.69166666666666), np.float64(85.57333333333334)]\n",
      "DFCA-LI Acc:  [np.float64(85.27166666666666), np.float64(85.34333333333333), np.float64(85.29333333333334), np.float64(85.44166666666668), np.float64(85.15833333333333)]\n",
      "IFCA Acc:  [np.float64(85.84333333333333), np.float64(85.67333333333333), np.float64(85.75333333333333), np.float64(85.57333333333334), np.float64(85.56666666666666)]\n",
      "DFedAvgM Acc:  [np.float64(75.41333333333333), np.float64(72.25666666666667), np.float64(74.56), np.float64(74.82333333333332), np.float64(74.90333333333334)]\n",
      "DFCA-GI Avg Acc (%):  [0.8555966666666667]\n",
      "DFCA-LI Avg Acc (%):  [0.8530166666666668]\n",
      "IFCA Avg Acc (%):  [0.8568200000000001]\n",
      "DFedAvgM Avg Acc (%):  [0.7439133333333333]\n",
      "DFCA-GI Std:  0.13365128756082625\n",
      "DFCA-LI Std:  0.09257429448826901\n",
      "IFCA Std:  0.10611524133904787\n",
      "DFedAvgM Std:  1.102588066525497\n"
     ]
    },
    {
     "data": {
      "image/png": "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nDmz2Gvn5+eLM2fO1Pv69T369OkjPnr0qMRrzpkzR3R0dDTqmqNHj9a5hqHP6u+//xZ9fHwMXsvX11e8ePGiye91Ue+++67O9b/55ptizxk9erRRn31ERITe+Pft2ye+/vrrevcV9/e7ualUKtHT01MnhhdeeEHv8d9//73emC9cuFAu8Rn6O720Fi5cqHON999/vxwiJjIOhwISWYGCggK88MIL2Lp1q1HH5+bmYt68ebh8+TI2bdqkM05+1apV+Pjjj8sjVKvw999/4/nnnzd6jH9ycjLGjx+Pixcv4vvvv9fZ//bbbxc79NNYlelzGT16dIn/87tnzx4MHDgQ+/fv1zsX46uvvsK0adOMvueWLVtw8eJFHD161OD8xCdt374d586dgyiKRt+nMsjIyECPHj10utUVJYoiPvvsM8jlcnzyySc6+/Py8tC/f3/s27fP6Pv+888/aNGiBf7991+EhYXp7M/Ozka/fv1w6NAho69pLHXVIj8/3+AxcXFxePHFF3Hx4kUoFIoy3U/f3KL27duX6ZolmT59ulGVwR07dpitotq6dWssXbpUa9utW7d05k6pj9WnTZs2erefPHkSzZo1K3uQ5UTf5/n3339jwYIFFoiGiHOsiKzChx9+qDepksvlCAoKgoODAyIjI5GTk6O1//fff8e8efN0xs//+OOPeu8TEBAAHx8f5ObmIi4uDsnJyQZjUv8DnZiYqLeDlL5/wCvDxP5bt25h+PDhepMqJycnhIaGIiEhATExMTr7f/jhBzRq1AgTJ07UbEtJScG6det0jlUP93J1dUVmZiYePXqE7OzsYmMzx+diLuqkysnJCbVr10ZsbKzeYVqHDh3CN998g/fff19r+9atWzF9+nS91/b394eXlxcePnyI1NRUrX03b97E0KFDjR42FR4ernnu4uKC4OBgpKam4tGjR0adb6xDhw6VuM5OcHCw0d3U1G2uAcDHxwf+/v6IiIhARkaGzrHz58/HoEGD0K5dO63tb7/9tsGkKiQkBE5OTrh586ZOIhMfH48BAwbg0qVLcHR01No3ZswYg0mVjY0N6tSpA1tbWzx69EjvL+7FKdpooE6dOhBFEXfv3tU57vr16/jrr7/KNBcqKSlJZxigQqFAy5YtTb6mMYomVb6+vvDz89P7ZychIcGo4a/GcHZ21tl24cIFvcfWqlVL7/ag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AIC7AS7ShuvXjT43bEgYHLwcNE0siIiIiCqrVq1aAQDOnDlj9HA+tStXrgAAPD090atXL4PHnTlzxvQAiYrBxMoKeBUmVje87aQNpahY2djZoMWYFgCAs0vPmjs0IiIiIrMZNGgQACArKwvLli0r1blKpdQzPycnByqV/lE6WVlZXLuKyg0TKyvg7yQlVpe9CjeUIrECpDWtAGiaWBARERFVRq+88goCAwMBALNnz8ahQ4cMHvvw4UOt7+vVqwdASp42bdqkc3xBQQFef/11zTpZRObGxMoK1HCREqsLnrnShlIMBQSkJha1nqoFUSXi1t8cDkhERESVk729PdasWQMbGxtkZWWhV69eGDduHLZt24bw8HAcP34cK1aswLBhw1CnTh2tc1988UXY2Umje8aOHYsZM2Zg3759OHPmDFatWoX27dtjw4YN6Ny5syVeGlUD7ApoBWq5SYnVRY80aUNUFJCaCrgZ3z49uGsw7h+5j0cnH6HNxDblESYRERFRmXXv3h07duzASy+9hOTkZKxYsQIrVqwo8bygoCAsXrwYr7/+OnJycvDFF1/giy++0Dpm+PDhGD9+fLFzsIhMxYqVFQh18wMAJNokQ1Sv61DKqlVge6ms/vDkwxKOJCIiIrKsPn364O7du5g/fz46deoELy8vyOVyuLq6olWrVpg6dSpOnTqlc97YsWNx+PBhPPfcc/Dx8YFCoUBAQAD69u2L3377DRs3boRcLrfAK6LqQBDZwF9LWloa3NzckJqaCldXV0uHAwC4lJiHZj/aAxCRu68TbA8fA1avBkaNMvoamXGZWOC3ABCA6cnTYe9mX34BExERVQI5OTmIiIhAaGgo7O357x5RdWbq3welyQ1YsbICAU4KQCatYZUWXLgw8K3SzZVy8nWCe4g7IAJRZzhpk4iIiIjInJhYWQFPO0CQ+QAAHgUULhJ882apr6MeDvjo5COzxUZEREREREysrIJMEKCwkRKr295O0kYmVkRERERElQYTKyvhYCt1BrziqZA23LoFlHJ6XFD7IABSAwtOrSMiIiIiMh8mVlbCxU6qWF12VgEyGZCRAcTElOoa/i39IbORITM2kwsFExERERGZERMrK+HhIFWsHuUmASEh0sZSDgdUOCjg11xq3c7hgERERERE5sPEykp4OUqJVWJ2HFC/vrSxlJ0BAa5nRURERERU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8nSmXHt1dUe55ulNPmenyrX9fh1qT7S2d3O5llouS9Bm6NAyPoknbxvpncp7ktrUVj1a3tj91t77FKSbcDphYEVERETUjZregG9oddCb9MoPRdRlnD1MREREREQUJwZWREREREREcWJgRUREREREFCcGVkRERERERHFiYEVERERERBQnBlZERERERERxYmBFREREREQUJwZWREREREREcWJgRUREREREFCcGVkRERERERHFiYEVERERERBQnBlZERERERERxYmBFREREREQUJwZWREREREREcTInugE9jYgAAOrr6xPcEiIiIiIiSqRITBCJEdrCwKoFt9sNABg0aFCCW0JERERERD2B2+1Gampqm3kM0pHwqw9RVRWlpaVITk6GwWBIdHNQX1+PQYMG4ciRI0hJSUl0c/oE9nlisN8Tg/2eGOz3xGC/Jwb7PTHY791DROB2u5Gbmwujse27qDhi1YLRaMTAgQMT3YxWUlJS+I/iFGOfJwb7PTHY74nBfk8M9ntisN8Tg/0ev/ZGqiK4eAUREREREVGcGFgRERERERHFiYFVD2ez2bBw4ULYbLZEN6XPYJ8nBvs9MdjvicF+Twz2e2Kw3xOD/X7qcfEKIiIiIiKiOHHEioiIiIiIKE4MrIiIiIiIiOLEwIqIiIiIiChODKyIiIiIiIjixMCqB3K73Vi0aBHGjh2LpKQkpKam4txzz8UzzzyDYDCY6Oaddo4fP46//vWvmDt3Ls444wy4XC7YbDYMHDgQV199NVasWNFuHbwm3efJJ5+EwWDQt7aw3+NTX1+PxYsXY9KkSejfv7/+c3/xxRdj0aJFqK2tjVqO/d51q1atwnXXXYchQ4bAbrfD4XBg2LBhuOmmm7B27do2y7LfW/N6vfjwww/xm9/8Btdccw2GDBmi/79j0aJFHaqjoqICDzzwAEaOHAmHw4GMjAxMnjwZL7/8MjqyfteBAwcwf/58DB06FHa7Hf3798e0adPwzjvvxPnpeq54+r2kpAQvvPACZs+ejeHDh8PhcMDhcGDo0KGYM2cOPv300w61Id7rdjrqjp/3lu644w69jvz8/Hbz98V+71ZCPcrBgwclPz9fAAgAcTqdYrPZ9Nfjx4+X6urqRDfztGI2m/X+AyB2u11cLlezc9OnT5eGhoao5XlNus/u3bvFbrc36/tY2O/x+fTTTyUrK0vv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s9lilr/yyiuxbds23HbbbcjPz4ff70d6ejouu+wyLF++HH/5y1/0BWCo+e/cUCjU7u/cWCsuxnvdqGvY7/EziDRZHoqIiIiIiIg6jSNWREREREREcWJgRUREREREFCcGVkRERERERHFiYEVERERERBQnBlZERERERERxYmBFREREREQUJwZWREREREREcWJgRUREREREFCcGVkRERERERHFiYEVERERERBQnBlZEREQJNnXqVBgMBkydOjXRTSEioi5iYEVERERERBQnBlZERERERERxYmBFREREREQUJwZWREREREREcWJgRUREREREFCcGVkRE1COsWbMGt9xyC4YNGwan04mUlBSMHTsWCxYsQGlpadQyixYtgsFggMFgAADU1tZi4cKFGDNmDJKSkpCRkYGLL74Yb775ZofacPDgQdx3330YM2YMkpOT4XQ6UVhYiPnz52P79u0dqsPtduOZZ57B97//fWRnZ8NqtSIlJQXjx4/H3XffjfXr17dbR0lJCe6//34MHz4cDocD/fr1w7Rp0/Dhhx92qA1ERJQAQkRElEA+n09uuOEGARBzc7lc8t5777Uqu3DhQj1PUVGRFBQUxKzjuuuuk1AoFLMdr7zyithstpjlTSaTPPHEE21+llWrVklmZmabnyXar94pU6YIAJkyZYp88cUXbdbx1FNPdb6TiYjopOOIFRERJYyIYNasWVi6dCkAYObMmXj11Vexfv16fPnll/jd736HwYMHo6GhAbNmzcKmTZti1nX99dejuLgYd9xxB1avXo2NGzfiz3/+M0aMGAEAWLZsGRYsWBC17MqVK/GTn/wEgUAASUlJWLhwIdatW4cvv/wSzzzzDDIzM6EoCh5++GH86U9/ilrHmjVrMH36dBw7dgwmkwk/+clPsGLFCmzevBnr16/HSy+9hGuuuQYWiyXmZygrK8PVV18No9GIJ598El988QU2bNiAZ599FmlpaQCAhx56CN99911HupeIiE6lREd2RETUdy1ZskQAiMVikQ8//DBqnurqahkzZowAkAsuuKBZWtMRKwDyxhtvtCpfX18vZ511lgAQo9Eo27dvb5YeDAYlNzdXAEhSUpJs2bKlVR0HDx6UnJwcASBOp1Oqqqqapft8Pr0Op9Mpa9asifmZDx8+3OpcZMQKgAwZMkSOHj3aKs+6devEYDAIAPn5z38es34iIkoMjlgREVFCiAgWL14MAPj5z3+OK664Imq+9PR0PPXUUwCA9evXY9++fVHzzZgxA3PmzGl1Pjk5GUuWLAEAqKqKF198sVn6ihUr9Hu4Hn30UZx99tmt6hgyZIjeBq/Xi7/+9a/N0v/+97/rdTzxxBOYOnVq1DYCwKBBg2KmAcAf/vAH5OXltTp/4YUX4nvf+x4AYN26dW3WQUREpx4DKyIiSoidO3fiwIEDAIBZs2a1mfeiiy7Sj7/88suoeX7605/GLH/eeedhzJgxAIDVq1c3S4u8NhgMmDdvXsw6Zs+ejdTU1Kh1vP/++wAAl8uF2267LWYd7UlLS8MPfvCDmOkTJ04EABQVFXX5PYiI6ORgYEVERAnR9H6p888/X1/dL9qWlJSk5y0vL49a37nnntvm+5133nkAgL179yIYDOrnd+zYAQAYOnQo+vfvH7O81WrF+PHjm5WJ2LJlCwAt8HE6nW22oy2FhYUwGmP/as7IyACgrTxIREQ9CwMrIiJKiMrKyi6V83q9Uc8PGDCgzXJZWVkAtCmINTU1+vnq6uoOlQeA7OzsZmUijh07BgDIyclpt462tBeURYIuVVXjeh8iIup+5kQ3gIiI+iZFUfTjf/7zn8jPz+9QuVgBUORZVl0Vb3kiIurbGFgREVFC9OvXTz9OS0vDmWeeGVd9FRUVbS4MUVFRAUALoNLT0/Xzkel1kfS2RKYhRspEZGZm4ujRoygrK+t0u4mIqHfgVEAiIkqIyP1KgLbaX7w2btzYofTCwkJYrVb9fCSgKy4uRlVVVczyoVBIv5eqZRA4YcIEANp9Y7GmKhIRUe/GwIqIiBJiwoQJGDhwIABgyZIl8Pv9cdX3yiuvxEzbuHGjvuDEpZde2iwt8lpEWi2j3tTy5ctRV1cXtY6ZM2cC0O7/iiztTkREfQsDKyIiSgij0YiHH34YgLZ8+M0334xAIBAzf319PZ5//vmY6e+99x6WLVvW6rzH48H8+fP194wcR1x99dXIzc0FAPznf/4ntm/f3qqOI0eO4MEHHwSgLTDRcmn3uXPn6s+eeuSRR7B27dqY7Tx69GjMNCIiOn3xHisiIkqYO+64A6tWrcKKFSvw9ttv45tvvsH8+fNx3nnnITU1FfX19di9ezc+++wzvPfee7Db7fjZz34Wta5zzjkHN954I9auXYtZs2YhJSUF27Ztw+LFi7Fnzx4AwF133YVx48Y1K2e1WrFkyRLMnDkT9fX1uOCCC7BgwQJccsklMJlM+Pe//40nn3xSX8Xw6aefRmZmZrM67HY7Xn31VVx++eXwer249NJL8eMf/xhXX301Bg4ciEAggN27d+ODDz7Ae++912YASUREpyeDiEiiG0FERH1XKBTCPffcgxdffBHt/UoaOnRos4fjLlq0CI8//jgAbdTrkksuQXFxcdSy1157LZYuXQqzOfrfFF955RXMnz8/ZtBjMpnw61//Gg899FDM9n388ceYM2dOs+Xco2n5OadOnYq1a9diypQp+Oyzz2KWa/p5+eubiKhn4VRAIiJKKIvFghdeeAHffvst7r77bowdOxapqakwmUxITU3F2WefjVtvvRXLly/Hrl27YtYzdOhQbN68GQ8//DBGjx4Np9OJ1NRUXHTRRXjttdewfPnymEEVANxyyy3YvXs37rnnHowePRoulwsOhwMFBQW47bbbsGXLljaDKgCYNm0aioqK8MQTT2DSpEno168fTCYTUlJSMGHCBNx7773YsGFDl/uKiIh6Lo5YERHRaYsjOERE1FNwxIqIiIiIiChODKyIiIiIiIjixMCKiIiIiIgoTgysiIiIiIiI4sTAioiIiIiIKE5cFZCIiIiIiChOHLEiIiIiIiKKEwMrIiIiIiKiODGwIiIiIiIiihMDKyIiIiIiojgxsCIiIiIiIooTAysiIiIiIqI4MbAiIiIiIiKKEwMrIiIiIiKiOP3/1295uzpjGSgAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 1000x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA1YAAAH3CAYAAAC4g84JAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjMsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvZiW1igAAAAlwSFlzAAAPYQAAD2EBqD+naQAAxi1JREFUeJzs3Xd4VNXWx/HvpPdGCIFQktClKkUQFUQEURGxiyLFrnj12rEB6sVe3mtBvRdBUUCsNEEvCIhI701qQklCCKT3Nu8fhwyEmYSUSSaT/D7PM08m5+yzz5ohCVnZe69tMpvNZkRERERERKTKXBwdgIiIiIiIiLNTYiUiIiIiIlJNSqxERERERESqSYmViIiIiIhINSmxEhERERERqSYlViIiIiIiItWkxEpERERERKSalFiJiIiIiIhUkxIrERERERGRalJiJSI2jRkzBpPJVOoxYMAAR4clIk4uNjbW6meLyWRixYoVDovp2WefLRVLkyZNyMnJsWoXGRlpFfekSZNqP2Ap07vvvlvq3ycgIIDjx487OixpIJRYiVSDrf9kq/MYM2aMo1+SU7KVBJpMJmJjYx0dmtQzK1asqNb3uCOTB7Ft7969vP/++6WOPfHEE3h7ezsoIsdYuXIljz76KF26dCE0NBRPT0+aNWtGnz59mDhxInv37q2R++bm5rJu3To+/vhjxo4dS5cuXXBzc6vyH/YefPBBGjVqZPk8IyODp59+ukZiFzmXm6MDEBEREXGUCRMmUFBQYPk8ODiYhx9+2IER1a64uDjuu+8+Fi9ebHUuISGBhIQE1q1bx5QpU3jkkUd466238PDwsNv9O3XqxKFDh+zWn6+vL4899hgvv/yy5dg333zDk08+Sffu3e12HxFbNGIlIjZFRUXRo0ePUo/27ds7OiwREbvZtGkTP/30U6ljDz74IP7+/g6KqHbFxsZy+eWX20yqzlVYWMj//d//ccMNN5CXl2e3GIqKiuzWV4lHH3201Iij2WzmpZdesvt9RM6lESuRaujatSuhoaE2z8XHx5OQkGB1vF27dmX+px0VFWXX+Kpj4sSJTJw40dFhiDiFpk2b0qxZs/O2ayi/sDuLN9980+rY3Xff7YBIal9RURG33367zdGikJAQmjZtyqFDh6zWmi1evJgXX3yRt99+u8Zi8/DwID8/v8rXBwUFMWzYMObOnWs5tmjRInbv3s0FF1xgjxBFbFJiJVIN8+fPL/PcpEmTmDx5stXxzz77TEUgROqZ+++/X0UMnExcXBw//vhjqWMXXnghHTp0cFBEtevzzz9n3bp1VsdffvllXnrpJdzc3EhLS+POO+9k0aJFpdq8//77jB49ms6dO1c7jlatWtGjRw969uxJz5496dGjB0888QRffvlltfodOXJkqcTKbDbz4YcfMnXq1OqGLFImTQUUqSPOVynrf//7H7fffjutWrXCy8vLaiH8rl27+PLLL3nssce44oor6Ny5MxEREXh7e+Pl5UVYWBgXXXQRY8eO5eeffy61psCWilYFPF/cmzdv5r777qN169Z4e3sTFBRE3759+eCDD6r1F8nakJuby4wZMxg5ciTt27cnODgYd3d3QkND6dKlC/feey/z5s2juLj4vH0VFhYyZ84cRo4cSZcuXQgKCsLd3R1/f38iIyPp2bMnt9xyC6+99hq///67zYpkJVauXMkjjzxC7969ady4MV5eXnh5eREREUG3bt245ppreO655/jpp584efJktd6DSZMmWf3bRkZGAsZfvP/73/9y5ZVXEh4ejpeXFy1btmTUqFE2f2ErS0pKCv/3f//HiBEjiIqKIiAgwLJwfsCAAbzyyivEx8eX20d1v38cacCAAWUWsklOTubVV1+lR48eBAcH4+vrS8eOHXnyySc5duxYhe+xc+dOJkyYwGWXXUazZs3w8vLC19eXFi1aMHjwYF577bVK9Qdw8OBBXnnlFa6++mpatWpFQECA5WugV69e3HPPPXzzzTdkZGRUqt9du3bx8MMP06ZNmxr9mTFz5kyraWgjR460S98zZsyw+fUIxvfNtGnTGDRoEE2bNrUUaqhtH330kdWxvn37MnnyZNzcjL+7BwYG8tVXX+Hj41OqXVFREZ9++qld4li5ciU//PADEyZM4KqrriIkJMQu/Q4dOpTg4OBSx+bMmUNubq5d+hexySwiNWLixIlmwOqxfPlym+1jYmJstl+2bJn53nvvPW9fjRo1stmmrEe7du3M69atKzP+0aNHW13Tv3//SsX95JNPml1cXMqMoU+fPubU1NRqvtO2YwXMMTExVe5z9uzZ5rCwsAq/l6tXry6zr71795o7dOhQqX+fiRMnWvWTkZFhvv766yvVj61/s8qw9XXcqlUr89GjR80XXXRRmfc1mUzmCRMmlNt3UVGRecqUKWZfX9/zvg5PT0/zxIkTzUVFRTb7qu73T0UtX768wv9eFdW/f3+r/kaPHm3+/fffzU2aNCnzPfHz8zP/8MMP5fZ94sQJ84gRIyr0teLu7m7+xz/+Yc7NzS23z5MnT5pvv/32cr+3z35Mnz691PVl/VstX77cPGXKFLO7u3uN/8wwm83mCy+80Kr/LVu2lHtNq1atKvRvP336dJvxnzhxwty7d2+b52rTtm3bbMbw4Ycf2mx/4403WrUNCQkxFxcX10h8Ff3/53xs/bxcsGCB/QMWOU1TAUXquGeffZaNGzfavd99+/YxePBg1qxZQ8eOHe3e/z/+8Q927dpVbpu1a9fyxBNPMG3aNLvfvzpeeuklXnvttQq337dvH/379+frr7/mtttuK3UuPz+f66+/3i6lih999NFyp5/WlszMTAYOHMj+/fvLbGM2m3n99ddxdXXl1VdftTpfVFTETTfdxLx58yp0z7y8PCZPnszOnTuZO3cuLi4Vm3BRU98/NW3Lli189913ZGdnl9kmMzOT2267jYULFzJkyBCr84cPH+bSSy+t8EhUQUEB//73v1m/fj3Lli2zGqUAOHDgAP379z/vCGJVTJw4kT/++KPcNvb6mXH8+HG2bNlS6piPj49dpraV55prrqnQ1+PkyZNZsGCBXe55//33c//995c6tnbtWptte/ToYfN4z549raZNJicnc+DAAdq2bWuXOGvCxRdfbPUz85dffuG6665zUERS3ymxEqnjzv5POCwsjCZNmpCYmMiJEyfKvMbLy4tmzZrh6+uLq6srKSkpHDlyBLPZXKpdWloaTz31lNX8eXsoSarc3d1p27YtSUlJJCUlWbX76quveO2112jatKndY6iK2bNnl5lUNW7cmPDwcA4fPkx6enqpc4WFhYwePZoOHTrQrVs3y/H//e9/NpOqkilTXl5epKWlcezYsXKrY6WmpvLNN99YHS+ZmhcQEEBWVhZxcXHlTiO0h1OnTnHq1CngzHsSExNDZmamVdspU6YwbNgwevfuXer4008/bTOpcnV1pXnz5nh7exMbG2s1beeHH35g8uTJNtcv2lKV75+qqEhMo0ePZsaMGRXqb/v27ZbnkZGR+Pj4sG/fPgoLC0u1KywsZNy4cfz999+lCmMUFBRw3XXX2UyqXF1dadeuHfn5+Rw8eNDq/Nq1axk3bhxz5swpdTwzM5MhQ4aUmVT5+fnRqlUrioqKOHz4cKW/DkuSqtr4mbFmzRqrYz169LBMgaspZ389lvy7Hj161Gq6ZExMDJs2bbLLPW39e23bts1m25YtW9o83rx5c5vHt23bVucTq3P99ddfDohEGgqtsRJxAi1btmTZsmUkJiayfft2EhMT2bZtG+3atbO0ufrqq/niiy84cOAA2dnZHDx4kO3bt7NlyxZiY2M5deoU//znP636/uWXX2psV/orr7ySI0eOsGvXLhISEnjwwQet2hQWFrJ06dIauX9l5eXl8eyzz1od9/LyYs6cOZb3/+TJkzaTL1vX796926rdmDFjOHXqFHv37mXbtm3ExsaSnZ3Nxo0beffdd7n88stxdXUtdc3+/fut1sV169aNuLg4Dh06xNatW9m/fz+ZmZns27ePadOmcfPNN9scdbAHd3d3vvrqq1Lvia1NOIuLi3n99ddLHdu3bx8ffvihVdtx48Zx7NgxYmNj2bNnDydOnODxxx+3avfWW29VasSkIt8/dVHz5s1Zv349MTEx7Nq1i2PHjnHVVVdZtYuPj+eLL74odey///0vO3futGo7ZMgQjh07xu7duzlw4AC7du2yOWL97bffWo1qvPPOOzYryEVERPDTTz+RkpLCzp072bNnD2lpaSxdupRhw4ZVav1Qbf3MsJVYdOrUqVp9VtSAAQPYt2+f5d81NTWV3377rVbuXaKstZdlrW86e8PdivRTV9gagdy1a5fVHyhE7MbRcxFF6it7rbHy9PQ079mzxy4xFRUVmYODg63uYWudRnXXWPn7+5tTUlJKtc3Pzzf7+flZtX322Wer9brstcZqwYIFNvt5++23bba/8847bbY/duyYpc1bb71ldX727NnnjaWwsLDU5+vXr7fq54EHHqh0P5VV1tfxyy+/bLP9wIEDrdq6urqaMzIyLG2effZZqzb9+vUrMwZba7lef/31Um1q4/vHbC57jVVFHqNHj7bZp601VoD5999/t2qbmppqDgkJsWp78cUXl2rXo0cPqzbh4eGl/h1K/P333zbXS917772l2jVr1syqTWBgoPngwYPlvmfnrtmqCz8zRo0aZdXnCy+8cN7rqrvGqn379uacnJzz3qesn2lVediKb8iQITbblrWGcenSpTbbn/t9aC/2WmOVn59vM+5Dhw7ZP2gRs9ZYidR5N998c4XL/8bFxTF37lxWrFjB3r17SUxMJCsr67wVAOPi4uwRaimjR48mKCio1DF3d3eio6NLTXMCoypcXfD7779bHTOZTNxzzz0229977702p+f9/vvvjBo1CoDu3btbnX/ooYdYvXo13bt3p3379rRv357GjRuXanPuiFXHjh2t9nb5z3/+Q1paGpdccomln5YtW5YaITi3H3sp6z0ZM2aM1ftYVFTEhg0buOKKKwBsjjYcOnSInj172uwzNjbW6tiyZct47rnnzhtnZb5/qqMi+1hVZp+6qKgoy/t1tsDAQG644QarEarNmzeTl5eHp6cnqampVuuHAG6//Xb8/Pysjrdv357LLruMlStXljp+9r/jzp07bY4SPvjgg0RHR5f7Wjw9Pcs9X6I2f2bYGmkpa1TGnp566im8vLzO227GjBkVnjZqT+Zzpouf73hdV1J59dyplqdOnapT+0ZK/aHESqSOs/XL1bnMZjOvvvoqU6ZMIS8vr9L3SE1NrUJk5bvwwgttHrf1i11VYq4JR44csTrWsmVLq5K9Jc5eS3W2o0ePWp4PHDiQbt26lZp6lJqaalXqOCQkhD59+jB06FBGjhxpNSXHz8+P+++/v9R1xcXFzJkzp9RaGG9vby666CKuvPJKRo0aRZs2bcp5xVUTFBRU5lqMLl262Dx+9nty+PBhq/MJCQk2N9Qui60+bKnI94892Hsfq65du5Z5ztZ7XFBQQGJiIi1btuTYsWM2twAo6+u15Ny5idXZ67PKer8HDhxYZp+VVZs/M2xdXxubN9fW1+P5BAYG2jyen5+Pt7e31fGy3u9zE+G6KCAgwCqxqul1qNJwaY2VSB1X1qLhs02ZMoWJEydW+ZeN8oomVFVERITN4zW9OLw60tLSrI6V98tWWefOTlRdXV1ZtGjReTeFTk5O5pdffuHRRx+ldevWNgs7vPfeezz44IPlVsTLyclh9erVvPLKK3To0IGXX3653PtWha1fdEuU9Z6c/YuNPRL5kuIZ51OR75+6qCpfdyXvsa2v46r0mZ+fb6lKWNa/mb32HILa/ZlhaxTt3II0NaGufD2GhobaPF7W91VZx8vqpy6x9f1gK3kUsYe6+xuOiADnn0aTlZXFlClTrI537tyZN954g969exMaGmqZHtayZctSowc1pay4HbERZkXZ+itueZublnXu3L/iRkREsHz5cjZs2MD8+fP566+/+Pvvv0lISLA5xSY1NZU77riDffv2lfpFzN3dnalTpzJhwgS+//57/vjjD3bu3Mnhw4dtLsYuKiri1VdfpVu3btx0001lvo7KslX9r0RZ78nZv7gHBQVVe9F7Rf8YUNFpaHVNdd7jskYjKvu17OHhYSl+UtbIRHJycpl9VlZt/sywNe3Pnq+lLBX9eqzpcuu2piiDMWpvK/kr6/+MsvqpK/Lz821+L9nzDwIiZ1NiJeLk1qxZY3Ovm++++85qbUleXp7dy0zXJ7amtx05coSUlBSb0wHLKlncokULm8d79epFr169LJ/n5eVx6NAh/vzzT5599tlS60ZycnKYO3cuTzzxhM04n3jiCcu5oqIijh07xubNm5k0aZLVepQvv/zSrolVamoqR48etfk6d+zYYfOas9u2atXKKrEaP368zUqBDdW5/4Zns/Uee3h40KRJE8AYFXFxcbGaDljW12tZ587+BTsyMtLmdb///juDBw8us9+6ytb6moqOgtaGmi63bqsMOcCmTZu45JJLbB4/V6NGjWpkqrE92UqWXV1dy/wZLVJdmgoo4uTKSpTOLYYAMG3atDqznqkusrVexGw2l7kZ6X//+9/z9pObm2tzvQsYf73u2LEj9913H3fffbfV+QMHDpT6PCsry2Y/rq6utGrVihEjRtjcS+ncfuzh3OIJJWwtuHdzcyu1j9WVV15p1eb777+3uWeRLb///nuZ093qi0OHDlmteQJjWtNPP/1kdfyiiy6yjIYEBQXZXK80Z84cm3+937t3L6tWrbI6fvbXcadOnWwW5/jss89sFhc527l7kdUFttawnW9D8/qka9euNsvLz5492+pYcnIyv/76q9XxO+64w2bfkZGRmEymUg97rj+sDFtbDnTq1Al3d3cHRCMNgRIrESdX1rSfF1980ZJEFRcXM336dJ588snaDM3pXHXVVTb/kvnSSy/x7bffWqbtFRQUMGXKFJsVAQcPHlxqrcjatWtp2bIlTz31FL/99pvNtSp///23zU2aPTw8Sn0eHh7O6NGj+fbbb23+FTo5OZnp06eftx97KHn9Je9JyR5etiorDhs2DF9fX8vnY8eOtapWePz4cQYNGsSvv/5qNT0yKyuLP//8kxdeeIH27dtz5ZVX1plKkjVp1KhRpUYKEhMTufXWW22+9nN/yR03bpxVm+PHj3PLLbeU2rduz5493HjjjTaT/3P7OHc6GRijl5dffjnz588vNT2zsLCQP/74gxEjRvDtt9+W8yodo2/fvlbHNm/eXCPrTeuqRx55xOrYmjVrmDhxomVqcWpqKqNGjbKaFeHq6mpzj7G6Zt26dVbHbI3IidiLpgKKOLm+ffvi7u5uVVL9008/ZdasWbRs2ZKEhIQ6Nc2ltlx//fUVSipmzZpFu3bt8PT05PXXX+euu+4qdT43N5fbb7+df/zjH4SHh3P48GGbIyaenp688cYbVsfj4uJ49913effddwFjNDE0NBQPDw9OnTpVqvra2c4tP56ZmclXX33FV199BRhrasLDw/H19SUjI6PMtVZllTGvjvz8fO666y6eeOIJmjRpQmxsrM11Oi4uLlZl0Tt06MD48eP5v//7v1LHt2/fztVXX42Pjw8RERF4enqSkpJCfHx8nS/3/Pnnn7Nw4cLzths5cqTN6Z22HD16lJ49exIVFYW3tzf79u2z+e/brFkzxo4dW+rYvffey8cff2y1QfWSJUto0aIF7dq1Iz8/v8zRzFtuucUq+XjyySf56quvrDYJPnr0KMOHD8ff359WrVpRVFTEkSNHLCOsw4cPr9DrrU0RERF06dKl1LTKrKwsdu3aVW5FxtpSG+XW77//fmbMmMH69etLHX/llVf46KOPaNasGQcPHrRZQe+f//yn3TZUfuCBB6ymGtoaBd20aZPVz7IePXrw2Wefldm3rcRq6NChVQtUpAKUWIk4uZCQEB5++GGrX1LBqHJ19lSIESNGsGnTJptlxeujstb7nOvsv8beeeed7Ny502aCdOLEiTKnXrq6uvLFF1+UWTL6bElJSeed9ta+ffvzrovKyMgotyABgJeXV4V/ka+oJk2a0KJFCzZu3FjuewLw/PPPl5oGWOKdd94hJiaG+fPnW53Lzs5m//79do25plW0XPyll15aof769u3L3r17SU5OJiYmpsx2bm5ufPHFF1ZV/Tw8PFi4cCGXXnqp1ehmYWGhVcJ1tl69etkc+fTz8+PXX3+lf//+NkdMMzIybE69qqtuueUWq58Ry5YtqxOJVW1wdXXl22+/ZeDAgVZfY8nJyWUW8xg6dCivvvqq3eLYu3dvhdaTZWZmWrUrr0Jpfn6+1RTXwMBArrrqqqoFKlIBmgooUg+89dZb3HDDDeW2GT58OF9//XWdrspXV7z++uvMnDmzwqWE27Rpw/Llyxk5cqTVuarM5e/Vqxe//vqrVUngyvbVtGlTFi5cyAUXXFDpGMrj5eXFkiVLyi0hbzKZeO6558r8BczNzY2ffvqJN998s1L7B3l6enLjjTeWubdYfdGuXTt+++23MotGgPFL5bfffsuQIUNsno+KimLLli1cf/31Fbqnm5sbjzzyCH/88UepqZtna9OmDdu2beO2224rt+y/M7j77rutXsOsWbMcFI1jREZGsmrVKq6++urztnVzc+Mf//gHP//8c4U2OXa0X375xWrq9e23365S61KjNGIlUg94eHjw448/MnfuXL744gs2bdpEeno6jRs3plu3bowZM4Zbb73V0WE6lbvuuoubbrqJ2bNn89tvv7Fp0yaSkpLIysoiICCA8PBwLr74YoYNG8bw4cPL/CWzX79+HD9+nBUrVrB+/Xp27NhBTEwMiYmJZGdn4+bmhr+/P5GRkfTo0YMbbriBIUOG2EyAU1JSWLVqFWvXrmXr1q0cPHiQuLg4MjMzMZvN+Pr60rx5czp37szVV1/NbbfdVmO/RDRq1Ijff/+dr7/+mpkzZ7J9+3ZSUlIICwtjwIABjB8/vszKYyVcXFx45plneOihh5g1axbLly9n8+bNJCUlkZGRgZeXFyEhIbRp04auXbsyYMAArrjiijLXFdY3PXr0YPv27Xz88cf88MMPHDhwgLy8PFq2bMk111zDE088cd59kcLCwpg3bx7bt2/nm2++4c8//+TQoUOkpKTg4uJCSEgIHTp0oH///owePbrMjZ/PFhoaypw5c/jXv/7FN998w+rVq9mzZw8pKSnk5+cTFhZGeHg4vXr14qqrrqqzIwStWrXihhtu4Mcff7Qc27hxI/v27aNdu3YOjKx2RUREsHjxYlasWMF3333HypUrSUhIICMjg5CQEFq1asXgwYO56667aN++vaPDrTBbSfKjjz7qgEikITGZ6/rEdRERcZhJkyZZVRps1arVeSvBScUNGDDAqgLg6NGja3yNjcCGDRuspqq+8MILvPbaaw6KSOwhJSWFiIiIUuvDrr322gqtgxSpDucexxcRERGpol69ellNo546dep51y5K3fbhhx+WSqpMJpNd14WJlEWJlYiIiDRYb7zxRqn1i8nJyUydOtWBEUl1ZGVl8e9//7vUsTvvvLNChYVEqkuJlYiIiDRY7du355///GepY++9957NMuNS93366aelthfx9/fnrbfecmBE0pAosRIREZEG7c0338RsNlsex48fV/U4J/Xkk0+W+rdMT0+nadOmjg5LGgglViIiIiIiItVU76oCvvHGG0yYMMHyeT17eSIiIiIiUgfVq8Rq7969dO/endzcXMuxyr684uJi4uPj8ff310aqIiIiIiINmNlsJiMjg2bNmp13Y/R6s0FwcXEx48aNIzc3l759+7JmzZoq9RMfH0+LFi3sHJ2IiIiIiDiro0ePnndT9nqTWH344Yf89ddf3HnnnbRp06bKiZW/vz9gvHkBAQH2DFFERERERJxIeno6LVq0sOQI5akXiVVMTAwvvPACjRo14v333+fjjz+ucl8l0/8CAgKUWImIiIiISIWWCNWLxOq+++4jKyuLTz75hMaNGzs6HBERERERaWCcvtz6f/7zH5YtW8agQYO4++67HR2OiIiIiIg0QE49YhUXF8fTTz+Nt7c3n332WZX6yMvLIy8vz/J5enq6vcITEREREZEGwqlHrB544AHS0tKYNGkS0dHRVerj9ddfJzAw0PJQRUAREREREaksp02svv76axYtWkT37t154oknqtzPhAkTSEtLszyOHj1qxyhFRERERKQhcMqpgImJiTz++OO4urryn//8Bze3qr8MT09PPD097RidiIiIiIg0NE6ZWD333HOcOnWKhx56iA4dOpCZmVnqfH5+vuV5yTkPDw88PDxqNU4REREREWkYTGaz2ezoICprwIABrFy5slLXPPbYY3zwwQfnbZeenk5gYCBpaWnax0pEREREpAGrTG7gtGusRERERERE6gqnTKxWrFiB2Wwu8zFx4kRL25JjFRmtEhERERERqQqnXGMlIiIiUhXFxcUUFhZSXFzs6FBEpIa5uLjg7u6OyWSqlfspsRIREZF6Ly0tjfT0dLKzs5VUiTQg7u7u+Pv7Exoaiqura43eS4mViIiI1Ftms5nExERSUlLw8fEhNDQULy8vXFxcau2v2CJS+8xmM0VFRWRmZpKamkpOTg4tWrSo0eTKKasC1qQ6VRXw3Xfhiy/g/vvhscccG4uIiIgTSk5OJjExkfDwcIKDgx0djog4QE5ODkeOHCEoKIgmTZpU6lpVBawnftv0P9i9mz8Xfevo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sLrmySefpHPnzqxevbpaMUrDohErJxLoFWh5nluQRn6RGfz9obGxToqDB6vUb8mIlSoDioiISHV16tSJXbt28cwzz9C2bVs8PT0JDQ3liiuuYNasWUyfPt1u9xo9ejQHDx7khRdeoEePHgQFBeHq6kpwcDB9+vTh+eefZ8mSJVbXvfzyyyxatIjBgwcTHByMh4cHzZs358Ybb+S3337jnXfesVuM0nCYzKoXWUp6ejqBgYGkpaURUIXRn5oW8HoAGfkZuIdtIWFsNxp5meCSS2DNGpg7F265pdJ9xq2P478X/xffJr48dfypGohaRESk9uXm5hITE0NUVBReXl6ODkdEHKiqPw8qkxtoxMrJlFQGLFXAonVr42MVR6waX2CMeGUlZpGVVHaFHBERERERsU2JlZOxrLMqTiWj4JzKgFVMrDz8PAiONhI2rbMSEREREak8JVZOpqQyoNmcSnpJpdKSEasqllwHCOscBiixEhERERGpCiVWTubMJsGpZzYJruZUQICwLkqsRERERESqSomVkwnxCjGeFKeQce4mwceOQW5ulfq1jFjtUGIlIiIiIlJZTp1Ybd68mcmTJ3P99dfToUMHGjVqhLu7O40aNaJfv37861//Ijk52dFh2lWp4hUlmwSHhhpl181miImpUr9nTwVUoUgRERERkcpx6sTqiy++YNKkSSxYsIC9e/eSnZ2Nt7c3ycnJ/PXXX7z44ou0b9+eNWvWODpUuylZY4X5rKqAJlO1C1g0atcIF3cX8jPyST+abodIRUREREQaDqdOrHr37s3bb7/NmjVrSElJIScnh/T0dDIyMvjyyy9p3LgxJ0+e5IYbbiAtLc3R4drF2SNWlqqAUO0CFq4eroS2DwUgcUditWIUEREREWlo3BwdQHXcfffdNo/7+flx9913Ex4ezpAhQzhx4gQLFy7kzjvvrOUI7c8yYlV8VlVAsFsBixM7T3Bi5wnaXduu6kGKiIiIiDQwTj1idT59+vSxPD927JgDI7Gfs6sClhqxKpkKaI+S6ypgISIiIiJSKfU6sVq1apXleeuSER0nV3ofKxtTAaszYqW9rEREREREqsSppwLakpeXR0JCAgsXLuTll18GoE2bNgwbNszBkdnHmRGrFNLOngpYMmIVGwuFheBW+X/akr2sTu45SXFhMS5u9TrvFhERERGxm3qTWHl5eZGX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1lmFdzNGvjQdUERERMT+fv75Z0uxjD59+jg4GqkqJVZOKsgryPI8KTvVdiN7VQbseroyoApYiIiIiFTagQMHyjwXGxvLE088AUCTJk0YMmRIbYUldqbiFU7KzcUNT7cA8grTScpOASKsG9l7xEqJlYiIiEildejQgWuuuYbrrruOTp064evry4kTJ1i+fDmffvopqampALzzzju4uenXc2elfzkn5u0eTF5hOqdykm03KEmsDh6EvDzw9KzSfSyVAXckYi42Y3JRGVARERGRiioqKmLBggUsWLDA5nkXFxdee+017rrrrlqOTOxJiZUT8/MIIjXnMKm5qbYbNG1qlFlPT4f9+6Fz5yrdp1HbRrh6ulKQVUDKoRRC2oRUPWgRERGRBmbBggUsXryYv/76i8TERE6dOoWnpycREREMGDCARx55hM5V/D1N6g4lVk7M39MoYJGWm2K7gclk7Ge1fr0xHbCK37Aubi6EdQ4jYVMCx7cdV2IlIiIiUgnXXXcd1113naPDkBqm4hVOLPD0JsEZeWUkVmC3dVYl+1mpMqCIiIiIiDUlVk4s+HRlwMz8CiRW1dgkGM5aZ6UCFiIiIiIiVpRYObFGp/eyyimo+RErVQYUERERESmbEisnFupjrHXKrUhitXcvFBdX+V4lUwFTY1PJTcutcj8iIiIiIvWREisnFuYbBEB+YSpms9l2o6go8PCAnBw4fLjK9/IO8SageQAAJ3acqHI/IiIiIiL1kRIrJ9bMrxEA5uJUcorKaOTmBu3aGc+rW8Di9Dqr49uOV6sfEREREZH6RomVEwv3NdZYUZxKWn4ZI1ZglFwHVQYUEREREakhSqycWIi3scbKbE4lPb+chvYqua7KgCIiIiIiNimxcmLB3mdGrDIKyhmxsnNlwBM7TlBcVPVCGCIiIiIi9Y0SKycWfHqDYMyZJOeWM2R1dmJVVpGLCghpE4KblxsF2QWkHCqnEqGIiIiISAOjxMqJBZ3eIBggIaOcRKd9ezCZICUFTlS9op+LmwthncMATQcUERERETmbEisn5uriipurUQI9MTu57Ibe3hAZaTxXZUAREREREbtTYuXkPN2CADiRdZ6peZ06GR937KjW/UoqA57Yrr2sRERERERKKLFycl7uxjqrUznnSawuusj4uGlTte6nESsRERGprhkzZmAymTCZTMTGxlarr0WL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//333/z5558APP/886VKxZ/t7FG/srRr146ePXtaStiXJFbff/+9pQy5rU2Ez34tSUnl/85Y3vkZM2aUOSrV0Kl4RT0Q4GXsT5CUVYERKzizzqqaBSyadGuCi7sL2SezSTucVq2+RERExLmdPY1vw4YN5bY933l78PDwsBRoWL16dZX68PLyshRMqM5r2rVrl+V5eXtEbdy4sUJxlSROO3fuZPv27cCZaYCtW7e2WX3Py8vLUm1v03l+B6xoHFKaEqt6oJG3Mef3VHYlE6tt26CgoMr3dfN0o0kXYz6xyq6LiIg0bD169LCMWs2cObPM0ae4uDh+++23Wonp+uuvB4wRo5JpcpVVslZpx44dbNmypcx2X3zxRZnnzl7rlZWVVWa7Tz/9tEIx3X777ZYpg9988w3Hjh2zlCC3NVpV4sorrwRgy5YtpZK9c51bcl4qRolVPdDY11hgmJprXT3Gptatwd8f8vJgz55q3btZL2M6YNyGuGr1IyIiIs7N09OTsWPHArB161bLnkxnKyws5L777rNMWatpjz32mGXfqbFjx5abTAAsWrTIMgJU4oEHHrAsd7j//vttJkbffPMNv/zyS5n9lox6AWVOo5s6dSrz5s0rN74S4eHhDBw4EIDZs2cza9YsSyJbXmJ1//33W17LfffdZ7NAxg8//MBPP/1UoTikNCVW9UBTP2PEKiOvgiNWLi5n9rOy0zorFbAQERGRl19+mebNmwPw7LPPMnLkSJYsWcLmzZuZM2cOl1xyCYsXLy63nLc9NWnShC+//BKTyURCQgI9e/bkoYceYv78+WzevJl169bxww8/8Oyzz9K6dWuuu+46jhw5UqqPbt268cgjjwDGFLmePXsyY8YMNm3axO+//85DDz3E3XffXe5ruvDCCy1rvD777DNuu+02Fi5cyKZNm5g3bx633HILDz/8MP369avwaytJoI4ePcrrr78OGGXSy1vb1qNHD+677z7A2K+rV69efPnll2zatInly5fz6KOPctttt5UqHa819BVX68UrDh48yMmTJ4mMjDxvWUqpmOb+xohVTn4FR6zASKxWrjTWWY0ZU+V7l4xYxW+Mx1xsxuSibz4REZGGKjAwkCVLljBo0CCOHz/O7NmzmT17dqk2Y8aMoX///pbRrZp24403Mm/ePMaMGUNycjKffvppmVPuXFxcbO6V9d57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XfPHH38A0K5du0rfr7CwkN69e/PJJ59w8OBBcnJyyMzMJCYmhnvuuQeAxYsX88ADD1TjVTmXpn7GiFVm3smqdeDiAsOHG8+rMeLX/OLmAJzYeYL8zPwq9yMiIiIi4izsllgNHDiQxx57DLPZTGxsLD/99BMnTxq/4L/99tuEhoaWap+bm2sZzbr88ssrfb/ff/+ddevW8dBDDxEdHW05HhkZyX//+19LQvX1119z9OjRarwy59HC30iscvKruMYK4IYbjI/z5kEVF/b6N/MnoHkA5mIzCZsTqh6LiIiIiIiTsGst7Pfff5/58+czatQoBg0axN13383SpUt56KGHrNrOnz+fgIAAWrZsybBhwyp9ryuuuKLc8yWjVgAbN26sdP/OqGWgUSgiv/AkxeYqVju64goICIDERFi3rsqxlEwHPLbuWJX7EBERERFxFnZbY1Xiuuuu47rrrjtvu1tvvZVbb73V3re38PLysjwvKiqqsfvUJa2DGp9+VkRqbioh3iGV78TDA669FmbPNqYD9u1bpVgi+kSw58c9WmclIiIiIg1Cvd29dcWKFZbnXbp0cVwgtaiprxeYjB2lEzOrsElwiZL9xn76CU6X0a+s5n2MdVbH1mrESkRERETqvxpPrAoLC0lKSiIpKalUFb+alJqayuuvvw4YmxC3b9++zLZ5eXmkp6eXejirRp4mcDHWssWkVbEyIBjVAD084MABOKd8fkU169EMk6uJjLgM0o8573sqIiIiIlIRNZJY7dmzh0cffZSOHTvi5eVFeHg44eHheHl50bFjR/7xj3+we/fumrg1xcXFjBo1ioSEBLy8vPjoo4/Kbf/6668TGBhoebRo0aJG4qoNXm4mXF1LEqtqjFj5+8OgQcbzKlYHdPdxp0lXY82XRq1EREREpL6ze2I1YcIEunbtyieffMLevXspLi7GbDZjNpspLi5m7969fPzxx3Tr1o3nn3/e3rfnscceY+HChQB8/PHHdO3a9bzxpqWlWR7OXkHQy91YZ3U0vRojVnBmOuDPP1e5C00HFBEREZGGwq7FKx599FE++eQTzKfX5XTs2JGLL77YsgHw8ePHWb9+Pbt376aoqIg333yTrKws/u///s8u93/qqacsI1Tvv/8+48aNO+81np6eeHp62uX+dYGPZ2OysuBYRjVKrgMMGwYmE2zcCEePQhVG8pr3ac7GqRuVWImIiIhIvWe3xGr16tV8/PHHmEwmLrjgAj7//HMuueQSm23XrFnDgw8+yI4dO/joo4+47bbbymxbUc888wzvvvsuAO+88w6PP/54tfpzVgGeoSQBJzKrOWLVpAlccgmsXm3saTV+fKW7KBmxStiUQFF+Ea4ertWLSURERESkjrLbVMDPPvsMgKioKFavXl1uotS3b1/++OMPy8a+n376abXu/fTTT/P2228D8NZbb/Hkk09Wqz9nFuwdBkBSdjVHrKDa0wFD2obgFexFYW4hidurseZLRERERKSOs1titWrVKkwmE8899xyBgYHnbR8YGMizzz6L2Wxm1apVVb7vU089xTvvvAMYSdXTTz9d5b7qg1AfY41VSo4dEqvhw42PK1ZASkqlLzeZTFpnJSIiIiINgt0Sq+PHjwNw4YUXVviaiy66CIDExKqNZjz11FOlpv819KQKINzPGLFKzztZ/c7atIHOnaGoyJgOWAUliZU2ChYRERGR+sxuiZWXlxcAWVlZFb6mpG1Vikecvabqvffea9DT/87WzM8YscrOq+YaqxK33258/M9/qnS5RqxEREREpCGwW2IVFRUFwIIFCyp8TUnbkrVWFXXkyBHLmioXFxfefPNNy15Zth4lUwUbglYBxohVXuEpioqLqt/hPfeAmxv89Rds317pyyN6RwCQfCCZ7JPZ1Y9HRERERKQOsltidc0112A2m/nwww9ZtmzZedsvX76cDz/8EJPJxDXXXFOpexUXF5d6npiYWO4jMzOz0q/HWUUGNT79rJjknOTqdxgefqaIRRWKjHgFeRHa0di0+Ng6jVqJiIiISP1kt8Tq8ccfJyAggIKCAoYOHcr48ePZvHmzVRK0efNmxo8fz9VXX01+fj4BAQGVLo0eGRlp2XS4Io9JkybZ62XWeU18PMAUDEBStp2mAz74oPFx5kzIyKj05ZoOKCIiIiL1nd0Sq9DQUObOnYu7uzuFhYVMnTqVXr164evrS0REBM2bN8fX15devXoxdepUCgoK8PDw4LvvvqNRo0b2CqPBa+RpAldjhCgx004lzq+4Atq1g8xMmDWr0pdbClisVQELEREREamf7JZYAQwePJi1a9fSs2dPy2hRXl4eCQkJxMfHk5eXZznes2dP1q1bx6BBg+wZQoPXyMuEycVIrI6k22nEymQ6M2o1dSqYzZW63DJite4YxUXF52ktIiIiIuJ83OzdYffu3Vm/fj0bNmxg6dKl7Ny5k+RkY61PSEgInTt3ZtCgQfTq1cvetxbA282Em2tjCoCYNDvsZVVi9Gh4/nnYtg3WrYM+fSp8aeNOjXH3dSc/I5+Tf58krFOY/eISEREREakD7J5YlejVq5eSJwfx9gilIAfiMuyYWIWEwG23wZdfGqNWlUisXFxdiOgVQeyKWI6tPabESkRERETqHbtOBZS6wc/TSFwSMu2YWAE89JDx8dtvIblyFQcj+hhl11XAQkRERETqo0qPWB05cqQm4qBly5Y10m9DFOQdTjyQkGHnYhG9e0P37rB1K8yYAU88UeFLVcBCREREROqzSidWJRsB25PJZKKwsNDu/TZU4X6R7AYSMmLt27HJZIxaPfCAsafV44+DS8UGPZtfbCRWJ3adIC89D88AT/vGJiIiIiLiQJWeCliZ/aMq8xD7iQgwkt9TWbH2f29HjoSAANi/35gSWEF+4X4ERQaBGeI3xts3JhERERERB6v0iNX06dNrIg6xo6igSADyizI5lXOKUJ9Q+3Xu5wdPPw0vvQQTJsCIEeDlVaFLm/dpTmpsKsfWHiNqoP1HPkVEREREHKXSidXo0aNrIg6xoxb+3uASDsXHiUmJsW9iBcbaqqlT4fBh+OgjeOqpCl0W0SeCnXN2qoCFiIiIiNQ7qgpYD0UFmDC5tgIgJjXG/jfw8YHXXjOev/YanDpVocssGwWvPabpnyIiIiJSryixqoei/V0wuUUCcCjlUM3c5O67oWtXSEs7k2SdR3j3cFw9XMlOyiY1JrVm4hIRERERcQAlVvVQCz8TLm7GiNXOpBoYsQJwdYW33zaef/wxHDx43kvcPN1oelFTQPtZiYiIiEj9osSqHnJzMdHYNxKAfadqKLECGDwYhgyBggKjkEUFaKNgEREREamPlFjVUy0Djap7R9JqMLECeOstY3+r776DNWvO27xkPyslViIiIiJSnyixqqfaNzISq5PZRyg2F9fcjbp2hbFjjefjx0N+frnNSwpYHN9ynIKcgpqLS0RERESkFimxqqe6NG4BuFJUnE98Rg1vyPvqqxASAps3w7PPlts0sFUgvk18KS4s5viW4zUbl4iIiIhILVFiVU+1DfIA1xYAxKTU8HTAZs1gxgzj+QcfwM8/l9nUZDKVKrsuIiIiIlIfKLGqp1rX9F5W5xo2DJ580ng+dizExpbZtCSxilsXV/NxiYiIiIjUAiVW9VSkvwum0yXXd5+sob2szvX663DxxZCaCrffXuZ6K41YiYiIiEh9o8SqnvJzN+HvFQnArpray+pc7u4wZw4EBcG6dfD88zabNevZDJOLibQjaWTEZ9RObCIiIiIiNUiJVT3W1D8SgIM1vcbqbJGRZ9ZbvfuukWidw8PPg7AuYQAcW6dRKxERERFxfkqs6rHWwUbJ9fiM2Nq98fDh8M9/Gs/vvBO+/tqqiaYDioiIiEh9osSqHusUGg1AWs4x8ovK31/K7t5+G8aNg+JiuPtu+OKLUqctBSzWqoCFiIiIiDg/JVb1WJfG4WDyBswcSTtSuzd3dYX//AceegjMZrjnHpg61XLaklhtiKO4sAY3MBYRERERqQVKrOqx1oGu4NoSqIW9rGxxcYGPP4bHHzc+f/hheP99ABq1a4RXkBeFOYUk7kis/dhEREREROxIiVU9Fu1/Zi+rfcm1VHL9XCYTvPcePPec8fkTT8C8eZhcTET0jgC0zkpEREREnJ8Sq3oszNuEh3skANtOOGDEqoTJBFOmwGOPGZ/fey8cP05EHyOx0jorEREREXF2SqzqMZPJRGO/SAD2nnJgYmUEA2++Cd26wcmTMG4czS82Equja446NjYRERERkWpSYlXPtQiIBOBwqoMTKwBPT/jmG+Pj4sW02v0LmCB5fzKZiZmOjk5EREREpMqUWNVz7RoZJddPZMY6NpASnTrBW28B4PHSBNq3MyoCHllVy1ULRURERETsSIlVPdctzEiscgqSyMyvI6NC48fD4MGQm8vQ5Fm4UEjsylhHRyUiIiIiUmVKrOq5zqHBYAoCIDY11qGxWLi4wPTpEBJCYNIBrmA5R/7QiJWIiIiIOC8lVvVcdIALJjej5PpBR5Vct6VZM2MDYeBSVtN4+1JyknMcHJSIiIiISNUosarnWvqd2ctqe1IdKGBxthtvhKeeAmA4P3PiPz87Nh4RERERkSpSYlXPubuYCPSOBGDHiTo0YlXijTdIiOyDG0U0nfwQHDzo6IhERERERCpNiVUDEO4fCcDBlDo2YgXg6sqplz4gnqZ45KTBtddCSoqjoxIRERERqRQlVg1AdFAUAHHpsY4NpAwtrurAbO4gjQDYuxduugny8x0dloiIiIhIhSmxagAuaGwkVsnZsZjNZgdHYy2wRSBuUS2ZzUiKvX1h+XJ45BGog7GKiIiIiNiixKoB6NHE2MuqoCiD5JxkB0djW2T/SBIJZ/t1E8Bkgv/+Fz76yNFhiYiIiIhUiBKrBqBDiA+4NAEgJrUOrrMCWl7eEoDN8U3hrbeMg//8Jyxd6sCoREREREQqRolVAxDt74LJNRKA7Sf2OzaYMrS63CgJH7c+joKH/wF33w1FRXDrrbC/bsYsIiIiIlJCiVUD4O9hwse7CwArD290cDS2BUcH49/Mn+KCYo6ti4PPPoM+fYwKgcOHQ1qao0MUERERESmTEqsGollgDwA2xG9wcCS2mUwmWvU3Rq0O/3EYvLzgxx8hIgL27IGRI40RLBERERGROkiJVQPRp/nFABw4tZmi4rqZoJRMBzzyxxHjQNOmMG+ekWT98oux5kqVAkVERESkDlJi1UDc0OYCMPlSUJTF3yf/dnQ4NpUkVkfXHKUo/3Ty16MHzJxpVAr88EN47z0HRigiIiIiYpsSqwZiQDMPTO7dAVgau86xwZQhtGMoPqE+FOYUEr8x/syJm2+Gd94xnj/1FHz7rWMCFBEREREpgxKrBiLEy0RYgLHO6peD6x0cjW0mk8kyahW7Mrb0yX/+E/7xD+P53XfDH3/UbnAiIiIiIuVQYtWA9GrWG4AtCXWzgAVA5BWRAOxfeE6JdZPJmAY4YgTk5xuVAvfsqf0ARURERERsUGLVgFzf1kisTmbsIK8wz8HR2NZhRAcwwdG/jpJ29JwS666u8M030LcvpKbC1VfDsWMOiVNERERE5GxKrBqQm9q0BpcQzBSwLHaro8OxKSAigJaXtgRg9/e7rRt4e8P8+dCuHRw5AlddBUlJtRyliIiIiEhpSqwakBAvFwJ9jXVW3++tmwUsADrd1gmAXd/ust0gNBT+9z9o0QL+/huGDoX09FqMUERERESkNCVWDcwFjXsCsPpY3V1ndcFNF4AJ4tbFkRqbartRy5ZGchUaCps2wfXXQ05OrcYpIiIiIlJCiVUDc1WUsVHw4eSNDo6kbH7hfkT2jwTKmA5Yon17+PVXCAiAlSvh1luhoKB2ghQREREROYsSqwbmrk5GYpWXv5e9KWnnae04F9x6AQC75pYxHbDERRfBggXg5QULF8Itt0BWVi1EKCIiIiJyhhKrBqZtcDge7s0BM1/vrrvTATve2BGTi4n4DfGkxKSU3/jyy+H778HDA+bNg0svVbVAEREREalVSqwaoMgQY53V/2Lq5kbBAH5N/Cx7Wu3+rpzpgCWuvRZWrICwMNi6FXr1gg11N3EUERERkfpFiVUD1K+5sZ/V7hN1d50VQKdbz1Md8Fx9+8K6ddC5Mxw/boxkzZ1bgxGKiIiIiBiUWDVAI9oZiVVG9iaOZhY7OJqydRjRAZOriYTNCSQfSK7YRZGRsHq1MYKVmwu33QZPPgl5dXNDZBERERGpH5RYNUCXtzSmAlJ0hIUxxx0bTDl8G/sSNTAKgF3fVXDUCowqgfPmwRNPGJ+/9x706QN79tRAlCIiIiIiSqwapECvQEJ82wEwb3/dXWcFZ6YD7p5bgXVWZ3N1hXffNRKs0FBj3VWPHvDZZ2A22z9QEREREWnQlFg1UN3DjVGrDfF1u8BDhxEdcHFz4fjW45zce7LyHVx/PWzfDlddZWwg/OCDMGyYcUxERERExE6UWDVQQ6ON/axSMjey5WSRg6Mpm08jH1oPbg3A5v9urlonTZvCkiXGCJa7OyxaBN26wY03GiNZIiIiIiLVpMSqgbq0pVHAwlywmWl78h0cTfl6PmyMrm2ZtoWC7IKqdeLiYqy52rrVKGhhMsFPP8GFF8Lw4bC+bk+JFBEREZG6TYlVA9U9vDvurp5QfJJv9uwiu7Durjtqc3UbgqODyU3JZcfsHdXr7IILYM4c2LkTRo40Eq758+Hii2HAAPjlF63BEhEREZFKU2LVQHm5eTGgVX8AMrL+x4+HCh0cUdlcXF0so1YbPtqA2R6JzwUXwDffwO7dMGaMMUVw5UqjTHuXLvDll1BYd98TEREREalblFg1YEPbXA1Ace7/mL63ilPsasmFYy/EzduN41uPc/Svo/bruH17mD4dYmLg6afB3x927TKSrcsvhwMH7HcvEREREam3lFg1YEPbDgXAnL+aVfEZ7E2tu5sFe4d40+XOLgCs/7AG1kNFRMBbb8HRo/DGG8ZeWGvWQPfu8J//aHqgiIiIiJRLiVUD1r5Re1oFtgLyMeevYkYdH7Xq/YhRcGPPD3vIiM+omZsEBsKzz8KOHcaaq6wsuP9+o2x7YmLN3FNEREREnJ4SqwbMZDIxtI0xalWc+z++3l9IflHdHZkJ7x5Oy0tbUlxYzKbPN9XszVq2hGXLjBLtHh6wcCF07gw//1yz9xURERERp6TEqoG7+vQ6K5f8pZzIMfPLkbq7pxVAr/G9ANj02SaK8ms41pIS7Rs3QteucPIkjBgB48ZBenrN3ltEREREnIoSqwZuYNRA3F3cKSw8hLnwIF/U8emAHUd0xK+pH5nHM9nz457auWmXLsY+V888Y+x/NX26scHwqlW1c38RERERqfOUWDVw/p7+XNryUsCYDvjb0SKOZtbdIhauHq70eKAHYBSxsEvp9Yrw9IQ334QVK6BVK4iNhf794b77YO1aFbcQERERaeCUWIllOmAwSzEDX+6t2/s39bi/B64erhz96ygHltRyOfTLL4ft241y7GYz/Pe/0LcvdOgA//oXHDlSu/GIiIiISJ2gxEosiVV61h+Yzbn89++COl3Ewr+pP73/YVQI/O3J3ygurOURtoAAYzrgihVw113g4wP79sGLLxqjWe3bw913w8cfw4YNkJ9fu/GJiIiISK1TYiV0CetCM/9m5BflEGL6i4RsM98erNujVpe/cDnejbw5ueckm/5TwxUCy9K/P8ycCcePG4nWFVcYx/ftM46PHw+9e0NoqLH5cHy8Y+IUERERkRqnxEowmUxc3doYtWrnvQyAD3YU1N76pSrwCvJiwOQBAKx4eQW5abmOC8bf35ga+PvvRuXAX36BiRNh6FAICYGMDHjnHYiKMtZk7dvnuFhFREREpEYosRIAhrY19rNKTP0fvm6wM7mYpXF1u/R6j/t7ENohlOyT2ayaUkcq9DVqZCRUkyYZCVZSkrEH1qWXGlMC//tfYz3WLbcYZdxFREREpF5w2sQqOzubxYsX89prr3HjjTfSqlUrTCYTJpOJSZMmOTo8pzMoehCuJlf2ndrDjS2NKWsfbK/bpddd3V256p2rAFj3wTpSDqU4OCIbXFzg2muN0ux//gnDhhlFL77/Hnr1gquugqVLVVVQRERExMk5bWK1fv16rrnmGl566SV++uknjqgaW7UEeQXRp3kfAKI8l+FigqVxRew4VbdHrdpe05boq6Ipyi9i6XNLHR1O+fr1g/nzYccOGDUKXF2NpOqqq4wk6/vvoahuv98iIiIiYpvTJlYAwcHBXHnllTz99NPMnj2b8PBwR4fk1Ia2MaYDrj68gBGRbgD83466PWplMpkY/O5gTC4mdn+3myOrnSDB7twZvvoKDh6ERx8Fb2/YtMmYHtixozFdMC/P0VGKiIiISCU4bWJ12WWXkZyczNKlS3nrrbe4/fbb8fT0dHRYTu2WTrcAsOTAEm5sGQvAnIOFxGfV3Q2DAZp0acKF91wIwIL7FpCf5STlzVu1gn//Gw4fhpdeguBg2L/fKHARFQVvvWWcExEREZE6z2kTK1dXV0eHUO+0a9SOa9teixkzKw58RL8mLhQUw9TddXvUCmDgvwbi19SPk3tO8ssjvzg6nMpp3BheecXYXPi99yAiAhIS4NlnITISunc3Eq8NG6C4bie5IiIiIg2V0yZWUjP+2eefAEzfOp172mcB8PnuAjIL6nZxBd/Gvtw0+yZMLia2fbmNrTO2OjqkyvPzg3/+Ew4dgi++gMsuM4pfbNsGr71m7InVvDk88AAsWgQ5OY6OWEREREROU2IlpQyMGkjXJl3JLsjmWNJ0WgeYSM2Hqbvq/qhVZP9IBrwyAIBFDy/ixK4Tjg2oqjw8YOxY+OMPOHHCWI91881G4pWQAJ9/DtddZ2w8fMMNRhKWmOjoqEVEREQatAafWOXl5ZGenl7q0ZCZTCYev/hxAD7e8BHPdTe+RF7fks+xzLo/De2yCZcRfVU0hTmFfH/r986z3qosjRoZFQS/+87YfPjXX+GRR6BFC8jOhnnz4J57oGlTuOQSeP112LVL5dtFREREalmDT6xef/11AgMDLY8WLVo4OiSHu6PLHYT5hnE0/SgeBfO4pIkLWYUwYX3dT1JMLiZu/PpG/Jr6kbQ7icXjFzs6JPvx9ITBg+Gjj4yiFlu2wOTJ0KOHkUitWQPPP29UHWzTxphWuHw5FNT90UYRERERZ9fgE6sJEyaQlpZmeRw9etTRITmcl5sXD/V8CIAP1n7AB/08cTHB3IOFrIwvdHB05+cbdma91dYZW51zvdX5mExGUYuXX4aNG+HoUZg6Fa65xkjADh2CDz6AgQMhLAxuvdX4fO1alXIXERERqQENPrHy9PQkICCg1EPgoZ4P4eHqwbq4dWRnr+e+ju4APP5XPgXFdX+aWb1Zb1VRzZvDgw8aRS1OnoQff4QxY4x1WKmpxlTCf/4T+vaFgADj41NPwcKFkJbm6OhFREREnF6DT6zEtiZ+Tbizy50AfLDuAyb18KCRJ+xOKXaKQhZQD9dbVZSfH4wYAdOnw/Hj8Oef8K9/wbBhRqKVn2+MXL37rnEsJAR69jQSrRUroLDuj0qKiIiI1DVKrKRMj/d5HIAfdv9ARu4RXu1tbMD86qZ8jmfX/UIWVuutHq1H660qytUV+vUz1l7Nn29UGTxwAGbONDYibtvW2Btr0yYj0briCggPh3HjYMECyM119CsQERERcQpKrKRMXZt0ZWDUQIrMRUxeOZkx7dzoEepCegG86ASFLOD0eqtZp9dbTd/K1i+3OjokxzKZoHVruOsuo2z7vn1w7Bh8840xdTAkBE6dMka7rr/emDbYtSuMHGmMes2bZ7QXERERkVKUWEm5/jXwX4CxYfCmhA180M8YtZq5v5CfYpxjyljkgEgGTB4AwC8P/0LS7iSHxlPnREQYidP06cZ+WL//Do8+aqzbKiiAHTtg9mx48UVj36wWLYyRrvvuMxIyJVoiIiIizp1YpaSkcPLkScujuNiYnpadnV3qeGZmpoMjdV59mvdhdLfRADy6+FF6NjbxeBejkMU9K3LZnVzkyPAq7NIJlxJ9VTQF2QXMvXkuOSk5jg6pbnJzM6YD/vvfcOQIxMQYBS7eeMPYT6t7d3BxMaYT/ve/xshXixbG48YbjX20li41CmaIiIiINCAms9l5dxKNjIzk8OHD5203evRoZsyYUaE+09PTCQwMJC0tTRUCT0vISKD9R+3JyM9g+vDp3NV1NNcuzmVFfBFtAkysvsGHIE+To8M8r6wTWXx24WdkxGcQ0TuCUf8bhWeAp6PDcj7p6UZBjBUrjMemTcY6rbOZTHDhhUa594ED4bLLjKIaIiIiIk6kMrmBEqtzKLGy7Z2/3uHp/z1NE98m7B2/l3xzAJf8nM2RTDNDW7jy4xAvXEx1P7k6sfMEMwbMIOdUDi0va8ldS+7C3cfd0WE5t8xM2LwZNmwwHhs3wsGDpdu4uUGnTsb6rujoMx+7dzf22RIRERGpgxpMYlUTlFjZll+UT5epXdh3ah9P9n2Sdwa/w5aTRQyYn0NuEbxwkTsv93CO0Z/4TfF8NfAr8tLziL4qmjvm34Gbl5ujw6pfjh+H5cuN9Vq//25sWFyW6GhjX60+fYxH587g5VV7sYqIiIiUQYlVNSixKtuSA0sY+s1Q3Fzc2PHQDjqEduCb/QWMW5EHwHdXeXF9pHMkKEf/OsrMwTMpyCqg3bB23PrDrbi6uzo6rPrr8GHYudNIsA4eND7u2wd791q3dXWF9u2NaoTduhlTCvv0gcDA2o9bREREGjQlVtWgxKp818++ngX7FjC49WCW3LkEk8nEE3/l8fGuAnzc4H/XedOzsXMkKDHLY5h1zSwKcwvpMKIDN82+CTdP50gM643UVFi/HtasMTYtXr8ekpOt25lM0KWLsSdXv37G88hIoxy8iIiISA1RYlUNSqzKdyD5AJ0+6UR+UT7vDn6XJ/o+QUGxmRuW5LI0rojGXiZWDvemdYBzFJw8sOQAc4bPoSi/iKgro7jtp9vw9HeOKY31ktkM8fGwbRts3258XL++7KmEISEQFWU82reHjh2hQwfj4etbu7GLiIhIvaPEqhqUWJ3fh+s+5B9L/oGLyYXFdy5mcOvBZOSbGbQwh62nimkdYGLl9T409q77xSwADi07xLc3fEt+Zj7NejXjzl/uxCfUx9FhydkSEuCvv2D1amN0a/9+YyPj8kREnHk0a2Z8jI42kq927bSOS0RERM5LiVU1KLE6P7PZzL3z7+WLrV8Q5BXEhvs20CakDcezi7l8Xg6HM830auzCr9d64+vuHMlV3IY4vhn6DTmncgjtEMpdv91FYAut6anTMjIgNtbYa+vgQfj7b9izx/iYdJ5NoF1czoxyBQSAh8eZh5+fMc0wOtp4tGplHBcREZEGR4lVNSixqpi8wjwGfDmAtcfW0jG0I2vvXUuAZwB7U4sZMD+b5Dy4pqUr313lhZuLcyRXJ/8+ycyrZpJ+LJ2AFgHc+sOtRPSKcHRYUhWnThnJVny88YiLg2PHjJGuPXsqt4Gxi8uZEa/mzc987NTJKKzRtGmNvQwRERFxLCVW1aDEquISMhLo+Z+exGfEc3376/nptp9wMbmwJrGIqxcZZdgHN3dlxhVeNPJyjuQq7UgaMwfP5NTeU2CC3uN7M/BfA7Xuqj4xmyEx0UiwDhyAnBzIzz/zSEkxRsEOHTIeOTnl9xceDhddZJSJDww01naVPMLCjFGxiAijAIeIiIg4FSVW1aDEqnLWx63n8umXk1eUxzOXPMMbg97AZDKx8HAhdy3LJacIWvmZmDPIi4ucpFpg9qlsfn38V7Z/vR0A/wh/rvnoGjrc0MHBkUmtM5uNPbmOHj0z6hUXZ5SP377dmHZYXHz+fnx9jXVd7dsbo12NG0NoqPGxSRO44AJjCqKIiIjUKUqsqkGJVeV9ufVLxswbA8BjFz/Ge0Pew8XkwvZTRdy2NJdD6WY8XOCDfp6Ma++GyUn+cn/wfwdZ9OAiUg6lANDhhg4MeX8IQZFBjg1M6o6sLCPB2rLF2JMrM9M4VvIxPt6YklhUVH4/JhO0bWtMLbzwQiPRCg83RryaNFGhDREREQdRYlUNSqyq5qP1H/Ho4kcBGNN9DP8Z9h/cXNxIzTNz78pcFhw2frEc3c6ND/p54uPmHMlVQXYBK19dyZp31lBcWIyblxuXPH0Jlz53Ke4+7o4OT5xBfr4xpXDvXmNT5OPH4eRJo8DGyZPGKFhCQvl9BARAy5bQujW0aWN8jI42ph76+BgPX98zn4uIiIhdKLGqBiVWVffVtq8YN28cReYiRnQYweybZuPp5kmx2cx72wp4aWM+xWa4INiFWVd60THYOfa6Ajix8wSL/7GY2OWxAAS0COCqt6+i062dnGYETuqwEyeMUa+Sx8GDxjqwEyeMxKwyIiKMKYft2xvTD1u0gOBgY8+vko9+flrzJSIiUgFKrKpBiVX1/Pz3z9z2/W3kF+UzKHoQP932E34extqRFfGFjP49j+M5Znzc4P/6eXJ3O+cZ9TGbzez5cQ+/PfkbaYfTAGjetzkDJg8gelC0EiyxP7MZ0tKMUa7Dh41iGwcPGh9jY40ph9nZxiMrq2LrvcAY1WrWzHg0bWpMOfTwAHf3Mw9/f2M9WEklxKZNwc2tRl+uiIhIXaPEqhqUWFXfskPLGD5nOFkFWXQP786COxbQPKA5AInZxYxdkceyOGNq4F1t3fi/fp74Ocl+VwAFOQX89fZf/PnGnxTmFALQ8tKW9J/Un6iBUUqwxDHMZqOi4b59xrTDksfx48bxlBRITq78CFgJk8kY7WrUyCi8UfKxadMzSVqzZsYxb29jXVjJR31PiIiIk1JiVQ1KrOxjfdx6hs0exomsEzT1a8q82+fRK6IXAMVmM29tLWDyJmNqYKS/iTcv9mR4pKtTJSUZCRn8+cafbPpsE0V5RqLY6vJWDJg8gMgBkQ6NTcQms9kY3Tp+/MweXwkJxnqvgoLSj5SUM5UQ4+OhsLDq9w0JMYpx2Ho0bXrmeUiIsW+YiIhIHaHEqhqUWNnP4dTDXDf7Onae2ImXmxdf3fAVt3S6xXJ+VUIRY5bncizL+BLs39SVd/p60LWRc5RlL5Eel86fb/zJ5s83U5RvJFiRAyIZMHkArS5v5djgROyhuNhY75WUZGy+XPJISjISs5IELT7eGBXLyTl/JURb3NyMKoglCZevr5FomUzGRxcXY51YWJhRqr6kXH2rVsY1SspERMTOlFhVgxIr+8rIy+COH+5g0f5FAEweMJkXL38RF5PxC1BmgZm3t+bz/o4C8orAxQTj2rsxqacnjb2dZ/QKIP1YOqteX8WW/26xJFhRA6PoP7E/LS9r6VSjcSLVVlBgJFjZ2UYSdvy47UdCgvHx1Knq3c/DwyjU0arVmb3Czk7APDyMdiaT8XB1NaotBgZCUJDx0d151nyKiEjtUGJVDUqs7K+ouIin//c07699H4B+Lfox7fpptA9tb2kTm1HM8+vy+SHGmG4U6AHPX+jBw53c8XB1roQk7Wgaq6asYsu0LRQXGMUEQjuG0n1sd7qN6oZfuDaCFbGSn2+Mip2dcOXkGNMXi4uNj4WFxohYUtKZEbSEBGO6YkULd5TH37/0erGSNWPBwWcqKgYFWRf6cHe3PubqXCPvIiJimxKralBiVXOmb5nOY0seIyM/A09XTyYPmMyTlzyJm8uZSmOrEop4ck0e204ZvyS1DTTxVh9PhrZwrvVXAKmHU1k1ZRXbZ263FLkwuZpoO7QtPR7oQdtr2zrdaxKpkwoLjfVgsbFG9cSSdWMlyVdSktHm7P/uCgogPd2oupiZaf+YfH2NaYolj7Awo8y9t3fp4h7lPUr2KGvUSBUZRUQcRIlVNSixqllH0o5w/4L7+fXgrwD0aNqDL4Z/QdcmXS1tiorNfLmvkIkb8zmRY3x5DopwZcKFHvQLd3G6ZCQ3LZddc3exdfpWjq05Zjke1iWMy56/jAtuuQAXV60NEXGYwsL/b+/Ow6SoDvXxv1XV+zI7zLAMMwMMOyi43F9wD64Rn3AVFZXEqI8hPmrUKPneqI/gTa5x9+ZeNUZMco2JIUhCYiTeRK9IFE1ARUBWWYd1Zpi1p/euOr8/qqu6e7p7tp6hZ+D98NRT1XXqVFefmmH67VN1Wg9Yx48n7hUzpqam1FEV29r03rVIJHWwj4GkKHrvWWWl/kXRI0fqvWsejx7gPB49qFksXU92e+LSSAY1IqIeYbDKAYPVwBNC4NVNr+K+v96H1lArFEnBPf9yD5ZeuBReu9fcri0i8OONETz/RRTxK+pw5jAZ90634l9rLLDIQytgAcDxncex8ecb8clLnyDi04e9Lqktwbn/di6m3zQdFjvf7BANOULog3UYISsS0YNYfX1iamzUv2ssGARCIX2ePHVeFwgklvv7z7Qk6b1gxkiMxmWMxhzQw6aq6nNN04Ob252Yior0+9mqq4GaGv27zoZiWNuwAfh//w/48kv9dRqXnWpaapvYbF1PydsoSs8mWe6fbY2BXYwpebCXbMv9sV1P92Hc10g0RDFY5YDB6sQ54juCu/5yF1btWAUAGOkdiWcufQbXT70+pVdqd5uGZzdH8JsvYwjFBxob45Fwx1QrvjXBihLH0PsPO9gSxPrn1+Of//lPBJuDAABHkQOTr5mM6TdNR9X5VezFIiI93NTXAwcPAnV1+vzoUf3yRb8/MQ+FEkEo2xQK6QGvP+5H60xR9PvRvF59KijQ53Z7evDoHFg8Hr0XrawsMfd49LpG/f5+Y97WBjz8MPDCC/0fXCmz/g5xmaauyrorH2z7PZleSy51r7xS/2AnjxiscsBgdeK9/eXbuPvtu7GnZQ8AYE7NHDx5yZOYNWJWynaNQYGfbYvipW1RNIb0H1uHAlw/zoJFU6w4Y9jQu1k80hHBJy99gn/+5J9oP9RurveO9GLq9VMx+ZrJqPxKJaQh2DtHRIOQquqXN9bXJ748OrmnLRLR38wkX0IoSYleNL9fn5qa9HvajPva+vrF0z1lhCyHI3XeeV1ZmT4qZGWlPh81Sh/x0bhk0ukEVq4E7r1XD6gAsHAhcNddeoBLfoMXi6Ve9mksd7UuEtHbONdJ03q3rdHL1nm5q7KeLGcqIzqRjh7Ve9fziMEqBwxW+RGKhfDkuifx4w9/jFAsBAC4eOzF+P7s7+PisRen9GAFYwK/3R3DS9ui5iAXgH6Z4C0TrbhmrAXF9qEVRDRVQ90Hddjy+hZse2MbQq0hs8xd7sbEr0/E5H+djJqv1kCxDb0ASUQnMU3T3/wcPw74fImpvT01gCQHkeRlny8xyEhjo76fUKj7581VbS3w058Cc+YM/HOdTJJH6uxLMMs12KmqPs82Gdv1tiyXutzvwO33T3/SL1nOIwarHDBY5dfelr14ZM0jWP7FcqhCv+5vZsVMfP+c7+PaKddCkROhQgiBfzZo+Nm2KFbujSESz1g2GbhijIIbx1txxRgF9iE2XHssHMPu/92NbW9sw663diHcFjbL7AV21F5Zi0n/Ogm1V9TC5rHl8UiJiAaIpumhKxQCwmF9yrZsPA6F9J64Q4f0SyYPHdIHIPH59F42g80GPPigfm9Vni8xIqLBj8EqBwxWg8P+1v147uPn8MrGVxCIBgAAE0sn4uHzH8aCaQtShmgH9MsEX/syit9+GcPm5kQvVpENuHqsBTeNt2J2hQx5iN1Aq0ZU7H9/P7av2o6df9yJjmOJYaEVu4Jxl4zDpH+dhAlXTYB7mDuPR0pENIhpmn45o9+vD2Hv4fcJElHPMFjlgMFqcGkKNOGFDS/gJ//8CZqDzQCA2pJaPHTeQ7hpxk1pAQsAvmhW8fqXMSzfE8Nhf+LHu8ojYcF4C64da8G0kqE3bLvQBA798xB2rNqBHat2oHl3s1kmyRLGnDcGk+ZNwqR5k1BUXZS/AyUiIiI6STBY5YDBanDyhX14fv3zeObjZ9AUbAIAVBZU4raZt+HWmbeisrAyrY6qCXxwTA9Zf9gXgy/pq2ZGuiRcPFrBJaMVzBllQekQG1lQCIHGrY3Yvmo7dqzagWMbj6WUu8vdqDi9AhUzK/T5aRUoHlcMxcr7s4iIiIh6isEqBwxWg1tHpAMvbngRT3/0NBoDjQAAWZJxxfgrcPus23HlhCsz9mIFYwKrD8Tw+u4Y/u+wag7bDgASgBmlMmaXKzinQsZXyhWM9gytoc5b97dix5/0nqy6D+ogtPRfa9kqo7S2FMOmDEPZ5DKMOXcMqi+s5mAYRERERFkwWOWAwWpoCMVC+P2232PZZ8uw9sBac/0w1zAsmLYAN02/CWePOjvj5X6hmMCHx1S8c0iftrakf6dLlUfC7AoFs8sVzK6QMaV46NyfFQ1EUb+lHsc2HsOxz4/h2MZjaNjagKg/mratvcCO8VeMx6R5kzD+ivFwFPJGbiIiIiIDg1UOGKyGnl1Nu/DKZ6/g1U2vosHfYK4fXzIeN067EfMmzcPpFadnvafqaEDDR8c0rDum4qN6FZuaNHTu8CmyAf9fuYJzKhR8pVzBmcNkOC1DI2gB+v1ZbQfbcHz7cTRua0TDlgbs/t/dKYNhSIqE0gmlGD51OMqmlGHYlGEYNnkYiscVw+bm6INERER06mGwygGD1dAVVaN4d++7+M2W32DVjlXmaIIAMNI7ElfWXom5E+ZiTs0cuG3ZR9DzRQT+2aDi43oV645p+GeDikAsdRurDJxRJuu9WvGerSF3n5YmcHjDYez44w7s/ONOHN9xPOu2ngoPiscVo2RcCcpPK0fV+VWoOL0CsmVoXTJJRERE1BsMVjlgsDo5dEQ68Kcdf8Ib297Au3vfhT+a+A4Tu2LHV2u+iitrr8SVE65EdVF1l/uKagKbmzR8VK/io2MqPjqm4Vgw/ddmcpGM2RUyZpUpmFEqY1qJDNcQ6tVqO9iGxq2NaNwWn7Y24vjO4wi1ZP6iTpvXhjHnjEHVBVUYMWsEhk8fDk+FZ8iNtkhERESUDYNVDhisTj6hWAhr96/F6i9X48+7/oz9rftTyqcNn4Y5NXMwu3I2ZlfOxuiC0V3uTwiBvT4RD1kqPjymYldbhsEiJGB8gYQZpQpOK5UxvUTGaaUyRrikIRU+gi1BtOxpQfOeZjTvbsbhfxzGgQ8OpHxxscFZ6sTwacMxfNpwlNSWoLS2FCW1JSiqLuKIhERERDTkMFjlgMHq5CaEwPbj2/HWrrew+svVWFe3DqpQU7YZUzgG51Seg6smXIW5E+bCa/d2u9/GoMBH9Sr+Eb9Ha0uzhoYMvVoAUOYAppfoYWtGqR62JhbJsMpDJ2xpqoaGLQ3Yv3Y/Dq47iPrN9Wj+sjnjaISAfv9WcU0xSmpLUDK+xJw7i52wOC2wOq2wOCywF9o5gAYRERENGgxWOWCwOrU0B5vxzp538GHdh/jo0Ef4/Njn0ERilEC7Ysfl4y/H/CnzMXfCXBQ5inq872MBTQ9ZTRo2N2vY1KT3bGXKHjYZmFwsmz1bM0plTC8ZWvdtRYNRHN9+HPVb6tG4rREtu1vQ9GUTmnc3IxaMdb+DuLLJZai+qBo1X61B9QXVcJW5BvCoiYiIiLJjsMoBg9WprSPSgfWH1+Pdve9i5baV+LL5y5TyscVjMaN8Bk4rPw0zymdgZsVMVBdV9/jSvmBMYFuLhs1N8dDVrGJzk4b29JHQAQDFdmCsV8bYAhljCySMK0gsj3BJQ2IIeKEJ+I740Ly7WQ9aXzbr055mRHwRxEIxRINRxEIxqGE1rX5JbQmKa4pRWFWIwqpCFFUXoaiqCIVVhfCO9EJWOIAGERERDQwGqxwwWJFBCIEtDVuwcttKrNy2EtuPb8+4XamzFGeNOgtnjTwLZ448E1OGTUF1UXXGLyrO9jz7fQKbm/XerU1NKjY3a9jv6/pX06EANV49ZI0tkFHjleKhS0a1V4JdGfyhq7NgcxD71+7Hvvf2Yf+a/Wjc2tjl9rJFRkFlAYqqilBUXZQIX/HHBaML+AXIRERE1GcMVjlgsKJsjgeOY0v9Fmyu34xN9ZuwqX4TttRvQVRL726yylaMKxmHiaUTMalsEk4rPw0zR8xEbUktFLlnb/QDMYF97Rp2twvsbdewt13DnvhyXYeA2sVvrgRgtFtCTYGEsV4ZVV590IwRbgkjXRJGumWU2jHoB9HwN/jRsLUBbQfa0Lq/VZ8faEXr/la0H2yHFkv/cucUEuAd6U3p5TICmPHY6rSemBdDREREQw6DVQ4YrKg3wrEwNtVvwobDG7DhyAZ8dvQzfNn8JUKxzEOUu6wunFZ+GqYPn44pw6Zg8rDJmDJsCkZ5R/Uq5EQ1gQO+eODy6QFsb7uGffF1/h7c0uRQgEqPhDEeGVUeCZUeGWM8EsZ49fkotzSoB9TQVA0dRzvQur8VrQda08JX24E2xELdN4Sj2AHvCC88IzzmPHnZmNu99hPwqoiIiGgwYbDKAYMV5UoTGg62HcSupl3Y1bQLXzR8gc/rP8emY5sQjAUz1vHavJg8bDIml+mTEbpqimp63MNlEEKgMSSwt11gn0/D3naBgx0ajgQEjvoFjgb08u7IEuK9W4lerlHGY7eEES4Zo9wSPNbBGb6EEPA3+FN6udoOtJkBrPVAKyK+SI/3Z3VbE2FrpDctfLnL3bB77bC6rbC5bbA4LYO+R5CIiIi6xmCVAwYrGiiqpmJX0y5sPLYRWxu2Yvvx7djWuA27m3enDflusCt2TCybaIat6qJqFDuKUewsRrGjGCXOEpR7yiFLvRvAIaIKHPIL1HXolxXW+fTwdaBDX3ewQyDSzVV2hgIr4mErEbxGuCSUO2WUOSUMc0gY7pRQbMegGmxDCIFQawgdRzvgO+oz574j+nLy+khHzwOYSQJcpS4Ujy1GUU0RimqKUFxTDHe5G44ihzk5i52weW0MYURERIMQg1UOGKzoRIuoEexu3o1tjduwvXE7th3X5zubdma9pDBZgb0AMytmYtaIWZg1YpY5UqHb5u7zMWlCoD4ocKhD4Ihf4HBAwxG/sSxwxK/3gHVkGc0wE0UChjkkDHNKKIuHrXKnhHKXEcTic5eMkkEWwiIdkZTwlTw3lv0NfkQ6Ir0aWt5gcVrgHemFd4QX3pFe2IvsEKqA0IQ5dxQ7UFBZgMIxhfpUWQhXmQsWR88GSSEiIqLeY7DKAYMVDRaqpmJ/636zZ2v78e043H4YLaEWtARb0BJqQWuoNeV7t5KVOEswpnAMxhSOQWVBZdryCO+IHo9cmE17ROCwX+CoEbwCicfHgwINIYHGoEBrLzt8rDL00OXUg1ix3ZiAIlvyYwnFNqDYIaHYJsFhyX8Y01QN0UAUkY4I/PV+tOxrQcveFrTua0XrvlYEmgIItYb0qSUENZK5t7KnLA4LnCVOOIodcJY49anYCUeJ3htmrEsu95R7YPPY+ukVExERnbwYrHLAYEVDSUyLYXvjdnx29DN8dvQzfHr0U2xp2IL2cHu3dRVJwUjvSD1sFVZitHc0CuwFcFld5lTkKEJNcQ3GFY/LqQcsogocD+n3djUE9bDVENR7xeoDAkfj82MBDU3hPj8NHApQYpdQFA9cRXYp8TgezIrtEopsyev1dfkaqCPij6DjWLzn64gPvqM+hNvCkBQJsiJDUiRIsoRgUxBtdW1oq2tD+8F2tB/qwaiIXbB5bYnBOio8cBQ5YC+0w1Goz50lTriHu/VpmBuuMhdkC78zjIiITi0MVjlgsKKTQVuoDQfbD6KurQ51bXU42HYQde3xeVsdDrUfyjhMfFfK3eUYVzIOlQWVKHeXY7h7OMo98bm73Fx2WV05HXtEjQeuoD7QxvGgQEtEoDUs0BIWaAkDLWGB1ohAc1hf3xoBtBz/J/NYgWKblBTG9MdGb5i+HmZIM8JZoQ1Q8hDKhBCI+CIINgf1qUWfh1pCqY+bQyllgaYAov7enXuDMTCHzWPLuGx1W+EocqQN7OEocsDqssLitPALnYmIaEhhsMoBgxWdCjShob6jPhG82g/icPthdEQ6EIgFEIjqU6O/EXta9qA11NrjfXtsHjNsdQ5dnQNZob2w16MeZn49Ar4o0BzSA1dKAAvrwcwIYcZ6I5y19WFcis4KbfolioU2CQU2wGuVUGCT4LUCBTYJBVYJXlunZasEr01CgVXvMXOewMsYw75wymAd/no/Qm0hhNvC5jzYFIS/0Q9/gx+B4wGgn/5SWBwWWF3WxOROLNvcNj2AuSwpj5O3Mwb8cBQn5vwuMiIiGigMVjlgsCJK1xJswZ6WPdjTvAdHfEfQ4G9Avb8e9f56fblDX46ovU8pXpsXBfYCFDoKUewoRmVhJcYUjEFVURWqCqswzD0MVtkKRVZgkS2wyBZ4bB4U2gvhsrpyHk1P1fQeL7MXzAxnQGs4KZAlBTbjcW8G7+iOXdHDmdFTltwzVmQHCm1SPLDpwS152QhxNmVgwpmmagg2BxHxRRDpiCDijyDqj6Yu+/WyYHOwf0ZV7AWLw5IStMx5SeJxSs9aUlAzetqMZWkQf3cbERGdeAxWOWCwIuobIQTaw+1m6DICV8rjpPVt4bacn9MiW1BoL0SRowiFjvjcXohCRyHKnGUYU5gIaGMKx6DIUdSvw5pH1NQQ1h4V8EWA9qhAe0TvRWuPJNa3RQR8UYH2COJzgfZo7pcxGuyK3hPmMXvKALdVgssCuC0SnBb9sdsCOC363GVJemzVt3PFtzPCW673nwlNIBqMIhqIT/6k5YAeypIfdy43Hkf8EYRaQ+ZljaHWEER/NV6czWuDvcAOe4F+v5nVZYViV2BxWMyp82OrywpHYWIIfXuhXV+Or+PIjUREQxeDVQ4YrIhOjHAsjLZwG9rD7WgL6fOmYBPq2uqwv3U/DrQdwIHWA2gJtUDVVMS0GGJaDFEtio5IR9bRELsiQYLT6oTL6oLTos+LncUoc5Wh1FmKUmepvuxKXTZ6x1xWFxwWR7+GM+MyxtZw4jLGtjDMHjK9dwzwxUNZcnDriOrLgd6P8N4ryYHNCFueePByWwBX5/AWD2mueEjrHN6Mxw4FObWl0ATCvrB+X1nyPWYtwbR1Rq+aEdSSl6OBfux6zECxKxmDl80T7yGT9HaQZAmKTUm7/DFTL5vNY4PNG597bLx3jYhogDBY5YDBimjwE0LAH/WjLdSG1lAr2sLxeajNXG7wN+BA2wHUtdXhQOsBNAYa++W5jXBW7ChGqasUJc4SlDpLUewoht1ih02xmVOBvQAjvSNTJrfV3e9fBhzT9HCmBy+9F6w9oi/7Y4A/poevQEzAH9Xn5uMYEIiHM39MIBifd0SBUG4jwXdLAszeMaeSoXctHsQSvWuJsOa2SnApeqhzKIBD0es4FAl2RQ9tToteZle6/l40oQnEQjGEfWGE25OmtjCiwSjUsIpYKKZP4Zi5bKyP+qMItYXMYfTDbWF9uS3Ub/emdUexK7DYk3rUerCs2BVYndbUe95cVshWGZKcGJVSVmS9d85pgdVpzTpX7MqQ/qLrWCiW+H66+g6oYRVqVIUW1aDFNGiqBkmWUiahCWhRLWW7lHAc7/E0xX8ehBCpy4h/yCAhsX8p9bmylaWs76qsh/vr7XMZHwx0JoSAFtOgRlSoYRWaquk/U7JkjnZq/pwZ64bwzw+dvBiscsBgRXRyCkQDaA+3IxANIBgNIhgLIhANoDnYjKZAE44HjqMpmJgnr2sPt/fp/rFMFElJGdLebXMnlq1uc53b6obH5oHb6obbllj22Dwpj5OX++Oes2RRTe8h80UFOqKJSxs7jBAXTQ1sycEsYAQ2FfBHU4NceIADWyY2GWbwMsKWEbyMMNabcociwRHvdTPWOS2JUOdQJDhkASkYQSQpaCWHr0hHBELoXwANoQc8NaKalz3GArHUSyWNSyI79PvZwr4whDq4/oRLsgTZKkOxKpCtMhyFjpTvUbMX2mGxW6DYFHOyuq3m968Z2yo2Je1NvRHuLA49yCXfD2cElZ7eIxdqDaHuwzrsf38/Dqw9gObdzQi1dv+F7JRFUq+rcQ7UqNq3DxaSg5qUCJxA5uXutu11eX/uK4/PdTIcNyTgsmcvg6PQgXxisMoBgxURZRLTYghG9TDmj/rREmwxA1hTsAmtoVZE1Ig5GZc6HvEdMSdfxDegxyhBMgcCKbAXmPebFdpTH3de9tq8sCk2WBUrLLIFVtkKp9UJj80Dp8XZ758iq1qih8wIXIFYegALxAQCUSCgpva0pQS3mN6zFlIFwioQjAmEVCCo9t+9a7myyek9aN31sHVVnlgnYItpsIQisIQjsKoaLNEYlJgGJRqDEotBi2hmT5saVs0eN3M5GDPvf4sFYoj4I9Cimt4To8bnsfg+4tt2nucr3Bk9RsmsLivcw91wDXPp81KX2XNiTG0H2nDs82MZ789T7Ir+VQEVHlicFj0gWmSzF88IwEb7yIpslhvbqhE10aZBvb0TBx2fZXij2jlkC02Y64wpW1nK+q7KutnfiephJeqp+4/dD0+5J6/H0JtswDtqiYh6wCJb4LV74bV79RXFvd9HR6QDvrAP/qjfHNLeH/GbYc1Y1xHpgD/ihz/q15eNefK6SKIsEA0AAAQE2sJt/TIwiEGCZPaKGZPRc9Z5yrTebXPDKlshSRJkSYYECYqsmOFuhLOo3+9bM8Q0vQfNCF4hFQjFg5exLhgDwmpiXTCmBzRje72+sS4R3MIZy/X9dQ51EU2f2qPJ71r78x2sBMCescQIdQ6LBIcdsDkBe1KvnC0e0uyyvl5fB9hlvUfOWG+Lb2+XJXiNZUWCTQZsQoU1osISi8EmNCiagFVVoagq0BGB2haE1hZCuDWIcFtYvzQsqpqXiEX90cT3scW/g02LailBQ4tpiIVj0KKJeyszBaNoIIrW/a1o3d/abauV1Jag+sJqVF9YjfLTyuEdqX/n2ql8OZoRrnoa6LKVQUDvkbTrvZIWuwWSIiW2UxPhtPPjzpdLmp//C6RfQjkQ5SfyuU6y8oF4LpvHhqGEwYqI6AQxwkZ/04SGQDQAX9inDwYSbjMHBMm4HGk370drD7fDF/YhqkURVaPmPKyGAehhrSPSgY5IR78ft8Gm2OCyxnsWhAZVqNCEBofFYY70aIz8aAwg4rQ4zbnTmnnZYXHAaXWmLBdZnHA4HObllwP1JjqmpQYvI4x1F/RCSdunBr2eB8HkDqSBD3XJ5PgEAMZ3i7lhfAohOwG7OxHK7Ioe/IzgZpP1yWoENlkPfon1gE0I2NUYbNEYrJqAzSLBIgM2qwSrLMESCENuCUBqCUC0BoDWIBRFgtUqw2JTYLVKcBY5MWJ2JYoqC+L7lqDIQBRALApIktCvQkp0KpmPU+Yp606OMGZergUJyP0rBtP3r8T3y6+eo5MULwXshJcCEhElwprRM5ZpMnrPuir3hX2IaTEIxD/NhoCqqWbQ68vojv1FkRTz0skiRxE8Ng/sih0OiwN2S3yuJOZp6yz27Nt3UyZLAzeKnxHqOvewBeP3t4U1PYxF4uvDWnx9PJxlWh9REX+cCHqR+LKxXq+X2H9oEF2O2VNCaIDWCKEeBkQAEEFABCFEGEC489Zpj414pQcvEQ8pxrp4ublOmAFNXyeS6iIRcABAMpbMNWnr0rfNXF9/mPIo/nyJdZLU6bkgp6xL1E9skbwutb7U6fXE752L/zPW6/XNtfHtMj2nnPJ8aeVSd/WzlSO1XEqdp9aXzPrG3mRJSmyb1s5J6yVA7lze6Ziz1Yeklxv1BTQIoUIIFYAKITT96gD9GtP4/zNSfJ1strMcb2tZls3XYzyXnHIeE+s6H595nju/5pR9mKco6TUn/04kXRIbX5d4Ln3dXTNK4bUNQMrvBV4KSEREOZEl2exhK0f5gDyHEHpvWGuoFYFoALIkm5MkSQjFQuZoj8boj8bAI6FYKHU507pOy8Z2xkAkqlDREmpBS6hlQF5fVyyyBTbFBkVSoMiK+bodFgc8Ng+8Nv2yU4/NA1mSzd48AQHz8kyrfn6M7TpPsiRD1fTeP6OuXbGbPXdOpzOtZ8+m2Pq19yUWD1nJgStshDINCMWAiCb0njUViGrxx2q8t03Vy6Lx8uRtI5pAVE30yoXV5P0kb6fvJ6ql7jOiAcHQJmiB30JEt0KoBwH1ENIDFBHly1VVRzBt2Ih8H0aPMVgREVFeSJKUet/aCaJqKoKxoHk5pDHviHQgHAsjrIYRjoURioUQVuPzpMfhWBghNcO6Ttt3riuSejiM72UbbIx74ICkeyAAczATYyRKh8WRCMHQPxm3KlazV87sqVMcGXvtOq+zW+xwKnYUWeyw2+xmj1+muXHPnkETWnzQmKi5TVdagi14fcvr+PnGn2Nj48a0clmSUe6ugNdeAKfFCbvFAbvFAZtiT+mhSXzGrp9Zo6zzstGuycvJZUjepySldYTpPb1I+fkxzo2xTjMeJ50zo6zztonH3W/Tdf2k/WStnzhqo8ca8XlyL7a+vciw78zPCZH87En77uoYBDKWJx1hN22RWJ/++rrYp0h/PejRc2d/fmMfkqRAlhRIkiU+l+NFmrkPc1mIeA+Xcebj9zFC63Q8ScsZ1p9odsvQusyWwYqIiE4piqyYvTqjMOqEPKcQAjEtlha8jN4kTWhQNRWhWAi+iA++sM+8pFITmtmLJ0GCJrRuL8PsiHRAQKT0AgL6F3MHY8GUHrxgNJjyxi9T4Bvo++x6y67ol1NG1AhUkTp+v1W26oHd5oXb5o6HmsSb4X2t+xCK6UOr2xQb5k2ah6+N/xqqi6pRVVSFUd5RsCq8CYgom/QAmV6Wsi6H7azy0PpdZLAiIiIaYJIkwapYYVWsAzKASS6EEIioETNodb7vTRMagtGgOQKlP+JHMBZMuTxR1VTEtBhCsVBKz11yj13aejWMYFS/NNPo9cs27xyejMFVMolqUTQHm9EcbM66zfTh03HbzNuwcMZClLpKc2tAolNMpnvsEoUn+GAGGQYrIiKiU5gkSfqldhY7ClGY78PJSNXUtLClCQ12ix02xaZ/D5tsRVgNwxf2pfT6ATB7+yRJQpmrDFOHTT1pRvIjosGDwYqIiIgGNUVW4JL1IfK74rQ6UeQoOjEHRUTUycCN90pERERERHSKYLAiIiIiIiLKEYMVERERERFRjhisiIiIiIiIcsRgRURERERElCMGKyIiIiIiohwxWBEREREREeWIwYqIiIiIiChHDFZEREREREQ5YrAiIiIiIiLKEYMVERERERFRjhisiIiIiIiIcsRgRURERERElCMGKyIiIiIiohxZ8n0Ag40QAgDQ3t6e5yMhIiIiIqJ8MjKBkRG6wmDVic/nAwBUVlbm+UiIiIiIiGgw8Pl8KCws7HIbSfQkfp1CNE3DkSNH4PV6IUlSvg8H7e3tqKysxMGDB1FQUJDvwzklsM3zg+2eH2z3/GC75wfbPT/Y7vnBdu8fQgj4fD6MHDkSstz1XVTssepElmWMHj0634eRpqCggL8UJxjbPD/Y7vnBds8Ptnt+sN3zg+2eH2z33HXXU2Xg4BVEREREREQ5YrAiIiIiIiLKEYPVIGe327FkyRLY7fZ8H8opg22eH2z3/GC75wfbPT/Y7vnBds8PtvuJx8EriIiIiIiIcsQeKyIiIiIiohwxWBEREREREeWIwYqIiIiIiChHDFZEREREREQ5YrAahHw+H5YuXYrp06fD4/GgsLAQZ511Fp555hlEIpF8H96Q09TUhF/+8pdYuHAhpkyZArfbDbvdjtGjR2PevHlYtWpVt/vgOek/jz/+OCRJMqeusN1z097ejieeeAKzZ8/GsGHDzJ/7iy66CEuXLkVra2vGemz3vnvnnXdw3XXXoaqqCg6HA06nE2PHjsVNN92EtWvXdlmX7Z4uEAjg7bffxo9+9CNcffXVqKqqMv/vWLp0aY/2UV9fj/vvvx8TJ06E0+lESUkJzjvvPLzyyivoyfhde/bswaJFi1BTUwOHw4Fhw4bhsssuw+9///scX93glUu7Hz58GC+++CKuvfZajB8/Hk6nE06nEzU1Nbjhhhvw3nvv9egYcj1vQ1F//Lx39p3vfMfcR3V1dbfbn4rt3q8EDSr79+8X1dXVAoAAIFwul7Db7ebjmTNniubm5nwf5pBisVjM9gMgHA6HcLvdKeuuuOIK4ff7M9bnOek/O3bsEA6HI6Xts2G75+a9994T5eXlZnvZbDZRVFSU0vYbN25Mq8d27xtN08SiRYtS2tfpdAqn05my7r777stYn+2e2Zo1a1LaL3lasmRJt/U/+eQTUVpaatbxeDwpfxMuu+wyEQ6Hs9ZfvXq1cLlc5vYFBQVClmXz8S233CI0TevHVzw49LXd6+rqhCRJKdu7XK6034Nbb71VxGKxrPvJ9bwNVbn+vHf23nvvpZyPqqqqLrc/Vdu9PzFYDSLRaFRMnz5dABAjRowQ77zzjhBCCFVVxfLly4XX6xUAxNe+9rU8H+nQAkCcffbZ4sUXXxR79uwx1+/bt0/cdttt5n8YCxcuTKvLc9J/VFUVs2fPFgDEV77ylS6DFds9Nx9++KH5Rubqq68WGzZsMN/8+f1+sX79evHQQw+JvXv3ptRju/fdL37xC/Nnev78+WLXrl1m2Y4dO8TXv/51s/wPf/hDSl22e3Zr1qwRxcXFYs6cOWLx4sXit7/9raioqOjRG83W1lZz20mTJokNGzYIIYQIh8Pi+eefF1arVQAQd9xxR8b6e/fuNT+EO+ecc8TOnTuFEEL4fD7xyCOPmOfziSee6NfXPBj0td337dsnAIg5c+aIV199VRw+fFgIof8sb926NeX34OGHH864j1zP21CWy897Z36/X4wbN05YrVZx5plndhusTuV2708MVoPIK6+8Yv6H89FHH6WVv/7662b5u+++m4cjHJree++9LsuTP2Wuq6tLKeM56T//+Z//KQCIm266SSxZsqTLYMV27zu/3y/Gjh0rAIi77767V3XZ7n134YUXCgBi/PjxIhqNppVHIhHzvCxYsCCljO2eXaZejaqqqh690Xz44YfNnsPOHyIIIcRjjz0mAAhFUczQlGzhwoUCgKioqBAtLS1p5d/+9rfNXqyTrTexr+3e2toqPv3006zlmqaJyy+/3OwNCQaDadvket6Gslx+3ju79957BQDx0EMPiZtvvrnbYHUqt3t/YrAaRM477zwBQFx00UUZyzVNEzU1NQKA+OY3v3mCj+7ktX79+qyfJPOc9A/jk9/S0lLR0NDQbbBiu/fdSy+9ZL4ZzPSmpSts976bOHGiACCuueaarNtcffXVAoCYO3duynq2e+/09I3mmDFjzMv1MvH5fMLj8QgA4pFHHkkp6+joMHt9H3300Yz1jd4ZAOIXv/hFn17LUNLXN/idrVixwmy3zz77LK08l/N2MupLu3/88cdClmUxYcIEEQwGexSs2O79g4NXDBKBQADr1q0DAFxxxRUZt5EkCZdffjkA4G9/+9sJO7aTncPhMJdVVTWXeU76z+233w6/349nn30Ww4YN63JbtntufvWrXwEArr322pSf7e6w3XMzduxYAMCmTZsQi8XSyqPRKD7//HMAwJlnnmmuZ7sPjJ07d6Kurg5A9nb1eDw477zzAKS364cffohgMNhl/erqakyePDljfcou299cIPfzRkA4HMatt94KIQRefvnlHv0dYLv3HwarQWL79u3QNA0AMG3atKzbGWXHjh1Dc3PzCTm2k937779vLk+fPt1c5jnpH8uWLcP//d//4eKLL8Y3v/nNbrdnu/ddOBzGJ598AgA444wzUFdXh29/+9uorKyEzWZDeXk5rrrqKqxevTqtLts9N3fccQcAYPfu3bjhhhuwe/dus2znzp247rrrsHfvXowbNw733XefWcZ2HxhffPGFudyTdt22bVtO9bdu3dqn4zwVGX9zbTYbJkyYkFKW63kj4N///d+xfft23Hbbbbjgggt6VIft3n8YrAaJI0eOmMujRo3Kul1yWXId6pvW1lb8+Mc/BgCcd955mDhxolnGc5K7w4cPY/HixXA6nfjZz37Wozps977bv3+/OSz33r17MW3aNCxbtgwNDQ1wu91oaGjAW2+9hblz5+L2229PGTqX7Z6bq666Cs899xxsNhtWrlyJ2tpauFwuuFwuTJo0Ce+//z7uuOMOrF+/HgUFBWY9tvvA6G27tre3o6OjI61+cXExnE5nt/V5Tnpm3759eOmllwAA119/fcrvApD7eTvVbdy4EU8++STKy8vx1FNP9bge273/MFgNEj6fz1x2uVxZt0suS65DvadpGr7xjW/g6NGjcDgceP7551PKeU5yt2jRIrS1tWHp0qXmpVLdYbv3XUtLi7n8ox/9CFarFW+88QY6OjrQ0tKCAwcO4NprrwUAvPLKK3juuefM7dnuubv33nvxhz/8AcOHDwcABINB83KySCSCjo4OtLW1pdRhuw+MXNvVWO6qbnI5z0n3gsEgrr32WgQCAZSVleHxxx9P24a/D30Xi8Vw6623IhaL4b/+679QVFTU47ps9/7DYEWnrHvuuQdvvfUWAOCFF17AjBkz8nxEJ5df//rXWL16NU4//XR873vfy/fhnBKMS8qM5Z///OeYP38+rFYrAGDMmDFYvnw5TjvtNADAY489lvF+IOq9QCCA66+/HnPnzsWYMWPwt7/9DY2NjWhsbMTf/vY3TJkyBa+99hrOPvtsbN68Od+HS3RCxWIx3Hjjjfj0009htVrxm9/8BiNHjsz3YZ1UHn/8cXz++eeYO3currvuunwfzimLwWqQ8Hq95nIgEMi6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GKyIiIiIiIhyxGBFRERERESUIwYrIiIiIiKiHDFYERERERER5YjBioiIiIiIKEcMVkRERHl24YUXQpIkXHjhhfk+FCIi6iMGKyIiIiIiohwxWBEREREREeWIwYqIiIiIiChHDFZEREREREQ5YrAiIiIiIiLKEYMVERENCmvWrMHNN9+MsWPHwuVyoaCgANOnT8fixYtx5MiRjHWWLl0KSZIgSRIAoLW1FUuWLMHUqVPh8XhQUlKCiy66CL/97W97dAz79+/Hfffdh6lTp8Lr9cLlcqG2thaLFi3Cli1berQPn8+HZ555Bl/96ldRUVEBm82GgoICzJw5E3fffTfWrVvX7T4OHz6M733vexg/fjycTidKS0tx2WWX4e233+7RMRARUR4IIiKiPAoGg2LBggUCQNbJ7XaLN998M63ukiVLzG327t0rxo0bl3Uf1113nYhGo1mP49VXXxV2uz1rfUVRxGOPPdbla3nnnXdEWVlZl68l05/eCy64QAAQF1xwgfjwww+73MdTTz3V+0YmIqIBxx4rIiLKGyEE5s+fj+XLlwMArrrqKrz22mtYt24dPv74Y/zkJz/BmDFj4Pf7MX/+fHzyySdZ93X99ddj3759+M53voN3330XGzZswM9//nNMmDABALBixQosXrw4Y93Vq1fjW9/6FsLhMDweD5YsWYIPPvgAH3/8MZ555hmUlZVBVVU8+OCD+OlPf5pxH2vWrMEVV1yB48ePQ1EUfOtb38KqVavw6aefYt26dVi2bBmuvvpqWK3WrK/h6NGjmDdvHmRZxuOPP44PP/wQ69evx7PPPouioiIAwA9+8ANs3bq1J81LREQnUr6THRERnbpefvllAUBYrVbx9ttvZ9ymublZTJ06VQAQ55xzTkpZco8VAPH666+n1W9vbxennXaaACBkWRZbtmxJKY9EImLkyJECgPB4PGLjxo1p+9i/f78YMWKEACBcLpdobGxMKQ8Gg+Y+XC6XWLNmTdbXXFdXl7bO6LECIKqqqsShQ4fStvnggw+EJEkCgPjud7+bdf9ERJQf7LEiIqK8EELgiSeeAAB897vfxeWXX55xu+LiYjz11FMAgHXr1uHLL7/MuN3cuXNxww03pK33er14+eWXAQCapuGll15KKV+1apV5D9fDDz+M008/PW0fVVVV5jEEAgH88pe/TCn/1a9+Ze7jsccew4UXXpjxGAGgsrIyaxkA/Pd//zdGjRqVtv7cc8/Fv/zLvwAAPvjggy73QUREJx6DFRER5cW2bduwZ88eAMD8+fO73Pb88883lz/++OOM29xyyy1Z65999tmYOnUqAODdd99NKTMeS5KEW2+9Nes+rr32WhQWFmbcx1tvvQUAcLvduP3227PuoztFRUW48sors5afccYZAIC9e/f2+TmIiGhgMFgREVFeJN8v9ZWvfMUc3S/T5PF4zG2PHTuWcX9nnXVWl8939tlnAwB27dqFSCRirv/iiy8AADU1NRg2bFjW+jabDTNnzkypY9i4cSMAPfi4XK4uj6MrtbW1kOXsf5pLSkoA6CMPEhHR4MJgRUREedHQ0NCneoFAIOP64cOHd1mvvLwcgH4JYktLi7m+ubm5R/UBoKKiIqWO4fjx4wCAESNGdLuPrnQXyozQpWlaTs9DRET9z5LvAyAiolOTqqrm8p///GdUV1f3qF62AGR8l1Vf5VqfiIhObQxWRESUF6WlpeZyUVERpk2bltP+6uvruxwYor6+HoAeoIqLi831xuV1RnlXjMsQjTqGsrIyHDp0CEePHu31cRMR0cmBlwISEVFeGPcrAfpof7nasGFDj8pra2ths9nM9Uag27dvHxobG7PWj0aj5r1UnUPgrFmzAOj3jWW7VJGIiE5uDFZERJQXs2bNwujRowEAL7/8MkKhUE77e/XVV7OWbdiwwRxw4uKLL04pMx4LIdKGUU+2cuVKtLW1ZdzHVVddBUC//8sY2p2IiE4tDFZERJQXsizjwQcfBKAPH/7Nb34T4XA46/bt7e14/vnns5a/+eabWLFiRdr6jo4OLFq0yHxOY9kwb948jBw5EgDwH//xH9iyZUvaPg4ePIgHHngAgD7AROeh3RcuXGh+99RDDz2EtWvXZj3OQ4cOZS0jIqKhi/dYERFR3nznO9/BO++8g1WrVuGNN97AZ599hkWLFuHss89GYWEh2tvbsWPHDrz//vt488034XA4cNddd2Xc15lnnokbb7wRa9euxfz581FQUIDNmzfjiSeewM6dOwEAd955J2bMmJFSz2az4eWXX8ZVV12F9vZ2nHPOOVi8eDHmzJkDRVHw0Ucf4fHHHzdHMXz66adRVlaWsg+Hw4HXXnsNl156KQKBAC6++GJ84xvfwLx58zB69GiEw2Hs2LEDf/nLX/Dmm292GSCJiGhokoQQIt8HQUREp65oNIp77rkHL730Err7k1RTU5Py5bhLly7Fo48+CkDv9ZozZw727duXse4111yD5cuXw2LJ/Jniq6++ikWLFmUNPYqi4Ic//CF+8IMfZD2+v/71r7jhhhtShnPPpPPrvPDCC7F27VpccMEFeP/997PWS369/PNNRDS48FJAIiLKK6vVihdffBGbNm3C3XffjenTp6OwsBCKoqCwsBCnn346brvtNqxcuRLbt2/Pup+amhp8+umnePDBBzF58mS4XC4UFhbi/PPPx69//WusXLkya6gCgJtvvhk7duzAPffcg8mTJ8PtdsPpdGLcuHG4/fbbsXHjxi5DFQBcdtll2Lt3Lx577DHMnj0bpaWlUBQFBQUFmDVrFu69916sX7++z21FRESDF3usiIhoyGIPDhERDRbssSIiIiIiIsoRgxUREREREVGOGKyIiIiIiIhyxGBFRERERESUIwYrIiIiIiKiHHFUQCIiIiIiohyxx4qIiIiIiChHDFZEREREREQ5YrAiIiIiIiLKEYMVERERERFRjhisiIiIiIiIcsRgRURERERElCMGKyIiIiIiohwxWBEREREREeXo/wfg2dFKHzLSegAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 1000x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA24AAAH3CAYAAADDpwzFAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjMsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvZiW1igAAAAlwSFlzAAAPYQAAD2EBqD+naQAA5uRJREFUeJzs3Xd4VFX6wPHvnZn0DiFAQkeQ3kRQQQFBBcUCqKAiiA17L+u6K9hd20/dRd21UOwCYlcUBEFEFKSDIiUQUgkhPVPv+f1xM5OEmYQkM8kk8H6e5z4zc++55547SWDeOee8R1NKKYQQQgghhBBCNFmmYDdACCGEEEIIIUTNJHATQgghhBBCiCZOAjchhBBCCCGEaOIkcBNCCCGEEEKIJk4CNyGEEEIIIYRo4iRwE0IIIYQQQogmTgI3IYQQQgghhGjiJHATQgghhBBCiCZOAjchhBBCCCGEaOIkcBNCCCGECBBN07y2efPmBa09r732WpW2hIeHk5GR4VVu5MiRXu2+5pprGr/BolqLFy+u8vOxWCxs2bIl2M0SjcgS7AYI0ZR16tSJ/fv3B6y+6dOnB/U/8Ops2rSJTz/91Gv/7NmzG/S6TqeT9u3bk5WV5fP4t99+y3nnndegbRBCGFJTU+ncuXO9z587d6580G9iDh8+zD/+8Y8q+2bMmEFycnKQWhQcv//+Ox9++CHLly/n4MGDHDlyhISEBFJSUhg9ejRTpkzhlFNOCfh1HQ4H27ZtY/369Z5t69atOByOKuU6duxIamrqMeubOHEiPXv2ZOfOnQC4XC5uu+02Vq1aFfC2i6ZJAjchBJs2beLRRx/12t/Qgdu3335bbdAGMG/ePAnchBCinp588kny8vI8ry0WCw888EAQW9S4CgsLufXWW3nvvfdQSlU5lpOTQ05ODhs3buSFF17gqquuYs6cOcTGxgbs+mPHjuWHH34IWH2apvHQQw8xbdo0z77Vq1fz2WefcfHFFwfsOqLpkqGSQoigOVbv46effkpBQUHjNEYIIY4j6enpvPrqq1X2XXbZZX71qjYneXl5jB49mnfffdcraDuaUop3332X0aNHVwl0/eVyuQJWl9sVV1xB+/btq+z75z//ecx7FMcH6XETogb9+vUjMTHR57GMjAwyMzO99nfv3p2YmBif55wo/2HWRl5eHl988UWNZaxWKx9++CEzZ85spFYJIY7WsmVLOnXqdMxy1f1bKYLj5ZdfxmazVdlXuafmeHfjjTeyfv16r/0xMTF07NiRAwcOUFhYWOXY+vXrmTlzJgsXLmywdoWFhXn9XOrCYrFwxRVX8Oyzz3r2bd26lW+//ZZx48YFoomiCZPATYgafP7559Uemz17ts/hhf/9738ZOXJkA7bq+PD+++9jt9uPWW7evHkSuAkRROPHj2+Sc3NF9axWK2+88UaVfUlJSYwZMyZILWpc33zzDYsXL/baf9111/HKK68QGRlJWVkZd9xxB2+++WaVMosWLeKbb74JSBDUpk0bLrjgAgYPHszgwYM59dRTee2113x+dqiLK6+8skrgBvDKK69I4HYCkKGSQgTBkSNHePnll5kwYQKdO3cmNjaWsLAwkpOTGTlyJI899pjPrF++/PXXXzzyyCOMHDmSlJQUoqKiCAkJoXXr1vTq1YtRo0Zx2223MW/ePPbs2VPlXHdmqhkzZvis21d2tEDNe5s/f77XvjPOOMNr3y+//MKuXbvqVHdmZibPPfccF198MV26dCE+Pp7Q0FBSUlIYNGgQU6dO5c033yQ3N7dB6klNTfX53q1cudLndWqbzW3evHk+6wVjSM5bb73FmDFjaNu2LRaLxXMMjEQwa9euZc6cOVx33XWcccYZnHzyySQlJREaGkpUVBTJycmceeaZ3H333fzyyy91es/z8/OZM2cOl19+Od26daNFixaEhobSpk0b+vfvz6WXXsorr7zCwYMHPef07dvX616eeOKJGq9z0003eZ1z/vnn16mtbjW9nwALFy5k/PjxpKSkeP4+J02axNKlS2t9jdLSUt58802mTJlCt27dSEhIIDQ0lNatW3Paaafx0EMP8ddffx2znpoyFf76669cd911dO3alcjIyKBnMazsmmuu8Wq3+4utsrIy/u///o8zzjiDxMREwsPD6dq1KzfddJMn+UJtpKam8uijjzJmzBjat29PZGQkERERpKSkMGLECP7xj3/w559/1qndgfo35GgHDhzggQceoFevXkRHRxMbG8vAgQN57LHHKCoqqlNdNfn000/Jz8+vsu+yyy7DYvH/+/qVK1f6/H10J9dYtGgRF110Ee3atSM0NLTKscbyn//8x2tfx44defXVV4mMjAQgIiKCOXPm0KFDB6+yc+bMCUg7PvzwQ7788ktmz57N+PHjad26dUDq7d+/P7169aqy77vvviM9PT0g9YsmTAkh6mXWrFkK8NpWrFhR7Tkul0s99dRTKioqyue5lbewsDA1a9Ys5XK5qq3vkUceUWaz+Zh1Vd4qq8t57m3WrFl+v3fbtm3zWfdPP/2kunbt6rX/oYceqlW9JSUl6tZbb1UhISF+3Yu/9ezbt69OvxsjRozwKjt9+nSvcnPnzvVZb05OjhoyZEiNP++tW7fW+Wc9duxYlZmZWeN77nA41KxZs1RkZGSt6qx8X2+++abX8Q4dOlT7O2+321XLli29zlm8eHGNbaxOde9nfn6+Ouecc2q8j2nTpimHw1Fj/W+++abP9h69mc1mdfPNNyur1VptXb7Omzt3rpo1a5YymUw+j9VVdb+3vn4Xa2v69Ole9Y0YMUJt2bLF59+6ewsNDVX//ve/a6y7uLhY3XDDDbX6N1DTNHXllVeq/Pz8GusMxL8h1f2s5s6dq6Kjo6utq1u3biotLa3e73VlEyZM8Kp/yZIlNZ5T23+HVqxY4bP9O3bsUBdccIHPY/v27QvIfdVGXl6ez7+Je++912f5e+65x+ffZF5eXoO0z9dnh44dO9a5njvuuMOrnmP9zYjmT4ZKCtFIXC4XkyZN4rPPPqtVeZvNxqOPPsq2bdv4+OOPMZmqdpDPnz+fxx57rCGa2uB89QZ06NCBM844g8mTJ/PUU09VOfbOO+/wxBNPeL0HleXm5jJixAh27NjhV9sCVU9jOv/8833O5fDXt99+y9ixY/n5558931JXVlZWxrhx4/jxxx/rVf9VV13FQw89xKFDhzz7Dhw4wNdff8348eO9yn///fccPny4yr6kpCQuvPDCel2/OmPHjj1mj+OCBQvQdZ133nnH5/Hbb7/d57f+vrhcLl577TU2b97MsmXLiIiIqNV5c+bMaZCfe0NLS0tj9OjRVX7uR7Pb7dx+++1ERERw3XXXeR3Pz8/nrLPOYuvWrbW6plKK999/n19//ZWffvrJZ89HQ/7tv/3226xevbrGMn/99RfTp09n+fLlfl3L6XSybNkyr/1Dhw71q95jmTZtWq1+H//3v//xv//9LyDXvPDCC5k1a1aVfb/99hu6rnuVrS7d/+DBg732uVwu1q9fzznnnBOQdjYEXz/Pr7/+mttuuy0IrRGNRQI3IRrJ/fff7zNoM5vNtGvXjoiICFJTU7FarVWOL168mEcffdRrTHx1Hwrbtm1Lq1atsNls5OTkcOTIkWrb5P6P7PDhwz6Hsvj6j87f9X9cLhfvvvuu1/7JkyejaRpTpkzxCtwOHjzIsmXLOPfcc33Wqes6F154YbUfuMLDw+ncuTOappGWllbtkKRA1dPYKn9Y6tSpE5GRkcdsX2xsLG3atCEyMhKXy0V2djY5OTle5TZv3sycOXO4//77vY5dc8011QZtFouFrl27EhoaSnp6us9MbeHh4dx8881eX0C89tprPgO3Dz74wGvftGnTCAkJqfY+68MdtMXHx9O+fXvPuk9He/fdd7nkkkuYNGlSlf2vvPKKz79PTdNISUkhNjaW/fv3U1JSUuX4zz//zE033eRzGLEvlX/uCQkJtGvXjtzcXJ9Jk/wxf/78Y7ZpxIgR1Q4FPtrevXs9z5OTk2nRogW7d+/2+rcP4M4772TMmDF07Nixyv7Jkyf7DNo0TeOkk07CbDaza9curw/wu3fvZsKECaxZs6bKsNiG/tt3B20mk4nu3btTVFTkc1jbDz/8wG+//capp55ap/or27p1q1f72rdvT9u2betdZ21U/n1MSUkhISGB9PR0r7+djIwMNmzYEJBr9unTx2vf5s2bfZb1NSQSoF27dj73b968udkFbr/88gtKqSq/2+I4E+wuPyGaq7oMlfzzzz+VxWLxKnvttddWGYpWWFio7rrrLq9y4eHhKj09vUqdRw9Ni46OVr/88ovXtTMzM9XixYvVzTffrJKSknzeS3VDxhrCl19+6fNaGzZs8JTp1auX1/Errrii2jqra39cXJx6++23qwxBc7lcau3aterqq69Wjz32WIPU09hDJQE1cuRItWvXrirt++677zyv//rrLzV9+nS1ZMkSlZ2d7bMde/fuVWeffbZX3T169PAqW91wqbCwMPX888+roqKiKuU3b96sbrvtNnXjjTdW2Z+VlaXCwsKq1GEymVRqamqVcmVlZSomJsbrejt37vR5L7VR0/v57LPPeoZCOp1O9dJLLylN07zKDRw4sEqdhw8fVnFxcV7lxo8fr/bs2eMpZ7Va1TPPPHPMvwW36tqZkJCgFi9eXGV46e7du6v8LtRWdb+3tdlGjBjhs05fQyUBFRsbq7755htPuYKCAjV16lSfZe+6664qdX799dc+y51yyinqr7/+8pQ7cOCAGj58uM+yH3zwQZU6A/W3r1T1P6v+/ftXad9TTz3ls5yvOuvC172MHTv2mOf5O1QSUP369fP6/V2zZo0qLCz0vK7u/876bL7a98ADD/gsu2PHDp/3vX37dp/lH3zwwWO+Z/URqKGSSikVHh7uVVdjDksVjU8CNyHqqS6B24MPPuhVbtiwYdXWPWjQIK/yTz/9dJUyRwduPXr0ULqu19hmp9Ppc39jBm6XXXaZ13W6d+9epcxjjz3mVSYiIqLa+SmnnXaaV3mLxaLWrVtXY1uOnlMUqHoaO3A7+eSTVVlZWY1trK3ff//d5zVyc3OrlJsyZYrPcseab+ZrHpevD/d///vfq5RZuHBhnf6GaqO693PatGk+y1977bU+y1cOHl977TWv4506dVJ2u91nnRMnTvQqP3PmTK9y1X1wXb58uV/vQWWNGbi9/fbbXmUdDofq3r27V9nWrVtXKTdp0iSvMuHh4T7nhx06dMhnID1mzJgq5QL1t6+U75+VyWTyGUz7ut/JkyfXeM1j+ec//+lV51VXXXXM8/wN3BITE1VOTs4xr9PQgdvMmTN9lq38xUllu3fv9lne199hIAQycEtOTvaq64cffghsg0WTIlklhWgEvuYb7N2715Mi+OjN17DFo+c9DBgwoMrrP/74gxEjRvCvf/2LTz/9lJ07d3ql2zebzX7fiz+OHDnic4mFKVOm1PgajPlUH3/8sdf+goICfv31V6/9kyZNYsiQITW2JywsLOD1BMN9991HeHh4rcpu2rSJf/zjH4wZM4ZOnToRGxuL2Wz2ZIYbNGiQz/OOznL6/fffe5UZOnQoEydOrPH6vt6ru+++22vfW2+9hcPh8Lz2NUzS19ynQKiuXl+ZPgHWrl3ree7rb72wsJDTTz/d59/6zz//7FW+tnOchg0bxtlnn12rsv5o2bIlp5xySo3bySefXOv6IiIiuPLKK732WywWpk6d6rU/Ozubffv2eV7/8MMPXmXGjh3rc8hbYmIil1xyidf+n376yfP71Rh/++effz7dunXz2t+jRw+vfTUNb68NX5kuW7Zs6VedtTFz5kxatWp1zHKzZ89GGR0Hfm91yZ6qqlmgurr9zYGvn+vR84DF8UXmuAnRCPbv3++1LzMzs05zUY6u45577vH60Ld69eoqE+DNZjM9e/bkrLPOYsqUKZx55pl1bHlgffDBBz4XHr3iiiuqvO7WrRuDBg3i999/r7J/3rx53HDDDVX2HTx40OdE9Lp+oA1UPcEwatSoY5YpKiri2muvZdGiRfW6RuXU4iUlJT4/HNT3verfvz+jRo1ixYoVnn3Z2dksWbKEyy+/nMLCQr7++usq58TExHD55ZfX63rH0q9fP5/7+/bt63N/Wlqa57mvv/W8vDyfc/yqc+DAgVqVq83PPRACvY5b9+7dqw14anqPO3fuTHFxsc/Apn///tVez9cxq9XKoUOHSE5ObpS//YEDB/rcHx0d7bXPn8WZqzs/JibGrzpro7F+H48lLi7O5/7q1g2t7v2Oj48PVJMaTGxsrNe+srKyILRENBbpcROiERy9nk59HP1BedKkSbz++us1/ofscrnYtm0br776KmeddRbjx4+ntLTU77bUl68Pf/379/f5rfPRwRwYyRuOXvOquve2RYsWdWpboOqpj9osRF6T6ibXVzZp0qR6B21g/C65NcR75avX7fXXXweMNamOTlwxZcoUoqKi6n29mlT3N1Xd/sqJIALxt26322uV/KI2P/emqKZ/s471HhcUFASsTvfPqjH+9lNSUnzuD8S6akfzFRQXFhYG/DpHayq/j4mJiT73V9cTVd3+6uppSnz9PdQ2K61onqTHTYhGEB8fX+eFWo9W+YOz28yZM7niiiv45JNP+OGHH9i0aRO7d++u9hu3r776igcffJB///vffrWlPnbs2MFvv/3mtX/z5s11yoA1b948nnzySc/r6r4VrUsPRyDrqUnloX+VVe6xqY9jDddauXKlz6GNl1xyCQ899BAnn3yy51vqvXv30rVr1xrra4j3avz48XTr1q1KYL5ixQr+/PPPRh0mCVBcXOzzW/vqgqnKgUGgvqX39fd+tGAP0a2v4uLiao8d6z2urjelpkC3umPun1Vj/O1X97NqiOx/vobPBfJeqlPb38eGXg7g6GkEbtX1ZFf372919TQlvoLOxviyUQSP9LgJ0QiOTmUNcNttt9VpLH913wrHxsZyzTXXsGDBArZs2UJpaSnZ2dn88MMPXmnKwUhh7mtYUEML1FCrd955p0r727dv73N9N1/zYGoSqHoAQkNDfe739YG1IdK3H83XvKvk5GQWLVrEkCFDqnwYrs0wvaioKJ/fRtfnvXLTNI077rjDa/8TTzzh1f4+ffo06JpUW7Zs8bm/ujXD2rdv73nu6299/PjxdZ670xyGadXXn3/+We3wtGO9x9HR0SQkJHgdry4FfHXHwsPDPfOxAvm33xR07tzZa19TmvfkXg4gEFvluY9ugwcP9jmfu7olCHztN5vN1a771pT4Csh9/fzF8UMCNyEawejRo732LVq0qMYFaCv74YcfvIZEHL0GVGVJSUmMGjWKN9980+tYfn6+V+9fdd+UBmpYZXVrt9VHWlpalQ9UsbGxPj/EL168+JiLwVYefheoeqD6b/C3bdvmtW/OnDm16l3xh6/12Vq0aOHzw82rr75aqzp9rW+0bt26Yy4w72utLrcZM2Z4vXfvvvsuTqezyr6G7G0DY7FkX6r78uGMM87wPPf1t75s2TJ27dpVq2v/9ttvfvfANnVlZWV8+OGHXvudTqfPfyfatGlT5cOor7ln3377LQcPHvTaf/jwYT799FOv/cOHD/es/xfIv/2mwNccze3btwehJcGRkJDA2LFjvfYvXrzYa9SD3W5n8eLFXmXHjRvn8wuCkSNHehI5ubfqkhY1tN27d3t9ARIfH0+nTp2C0h7ROCRwE6IRzJgxw+tDclZWFmPGjGHp0qVeWa1KSkr46aefePjhhzn55JMZPXq014T8iy++mHHjxvH666/z559/en34t9ls1S7SfXSPkK//oAC++OKLWt3fsXz33Xc+e5V69+59zGx1kZGRXucd/QF65syZXmWcTifnnnsuCxYsqDKHTCnF+vXrufbaa3nuuecapJ7IyEif/3m+/PLLbNy40fN64cKFPP30017lAs3X8LLt27dXWVS5pKSEu+++m4ULF9aqTl/vFRhzz1566SWvLxZ27tzJPffcw5133lltnVFRUV7JZ44WGhrK1VdfXas21tf8+fN58cUXPQGjy+Xi5ZdfZu7cuV5lBw4cWCWj4uWXX+6VMMBqtXLuueeycOFCryDUarXy22+/8cQTTzBo0CCGDBnCnj17GuCumpY777yzyvDdwsJCrr32Wp8B7tHzXa+99lqvMlarlUsuuaTKe5eWlsaECRN8zgM6uo5A/e03Bf369fP6dzMtLY2srKwgtajx3XrrrV779u/fz8033+yZSlBWVsYtt9zic5SBr/ObmnXr1nntO+2002Tx7eNdAywxIMQJoS7ruCml1J133lntWjSRkZGqW7duqk+fPiolJcXnQr9HL6p59Jo7oaGhqnPnzqp///6qR48eKioqyue1unbt6tW2gwcPVtu2Tp06qVNOOcWz2Wy2Or9Xl19+uVe98fHxtarrxhtv9Pl+FRQUeMq4XC51+umnV3sPERERqlevXqp3795V1nSaNWtWlWsFqh6llLrlllt81mE2m1Xv3r1V27Zt67w+UX3X2/viiy+qvU7r1q1V3759VURERI3t8fV77evn6t5CQkJUjx49VN++fVXLli1rvK/KDhw44HOxevd2+eWXH/N+a6umBbjBWNy6X79+qkWLFtWWWbRokVe9//d//1dt+bCwMNWlSxfVr18/1aFDB2U2m2v1Xvuqa+7cuQF7L5Sqfh23li1bVvk3oLrt3nvv9aqzunXc3FtKSorq06ePz4WEARUVFeW1GLtSSo0ZM8ZneU3TVPfu3VWPHj2UyWTyWWbo0KFVFixXKrB/+3X5Wfl6f6pbE68uLrzwQq96P/vssxrP8Xcdt6a28LOv9f4AFRMTo/r06aNiYmJ8Hr/00kurrbO275Hb7Nmzvf5OfP3bHxoa6lXuwgsvrPH+br/9dq96Xn755fq+XaKZkMBNiHqqa+DmcDjURRddVOOHmJq2YwVutd18LXyrlFJnnHFGrc6v60LPR44cUWFhYXX6z66y77//3mc73njjjSrlDh06pHr16lWn98LXh65A1fPnn39W+2G08hYbG6tSUlJq9f7UN3BzuVw+F3X3tVX3BYOv3+vS0tI6/x7W5uc+efLkas//7rvvjnl+bVX3fo4fP75W9zJ16tRq664ucK/N1tQCt9puF198sVedvgKTXr16qc6dO9eqzjfffNNnWw8fPlznv1NAdenSRWVmZvqsM1B/+3X5WTVU4LZgwQKveu+4444azzneArfDhw+rU045pU4/z1NOOUUdPny42jrrGrgd64uLmrZjLcrds2fPKuVNJpPPRejF8UWGSgrRSCwWC0uWLOFf//pXndbUCQsLY+LEiV7DGatLgFGd8PBwXnjhBWbMmOHz+Jw5c6rN2OaP6tZumzx5cq3OHzlypM9EGEcPl0xMTOS3337jlltu8cxdqY9A1dO9e3fefPPNGtN9d+3alZUrV3LSSSfV+zq1YTKZWLJkSY2LJJtMJh599FHuuuuuWtcbERHBsmXLmDVrls8hrfVVXRs6duzocw5ZoC1cuJDLLrusxjLTpk3zOXTSbc6cOcydO7dOKcXNZjPnnXfecZ9coFWrVixbtqza9fIAQkJC+Pe//13tfMYWLVqwbt06ZsyY4TOxyNE0TePyyy9n/fr1tGnTxmeZQP3tNwWTJk3yGrL70UcfNfh82qakRYsWLF++nKuuuuqYwwc1TeOqq67ihx9+aBZZGTdt2sTOnTur7DvnnHOazJIMogEFO3IUormqa49bZYWFher1119XkydPVt26dVPx8fHKbDarqKgo1b59ezVq1Ch15513qiVLlqj8/HyfdTidTrV27Vr1/PPPqyuvvFINHjxYJSUlqbCwMGUymVR0dLTq0qWLGjdunHruuedURkbGMduVmpqq7rrrLtW3b18VHR3tc8hmXXvchg4d6lVHixYtlN1ur3UdN9xwg8/3+q+//vJZPiMjQz377LPqwgsvVJ06dVKxsbEqJCREtW3bVg0cOFDNmDFDvf/++zV+sxqoerZs2aKuvvpq1b59exUaGqpatGihhg0bpl5++WXPe1nbb3Hr2+PmVlxcrJ599ll16qmnqujoaBUeHq46d+6spk2bptauXauUqr7X5Vi/10eOHFH//ve/1aWXXqpOOukkFR8frywWi0pKSlJ9+/ZVU6ZMUW+99ZZKT0+vVVuHDBni1YbZs2fX+l5r41jv52effaYuuugilZycrEJDQ1Xbtm3VhAkT1Lffflvra1itVvXOO++oadOmqZ49e6oWLVooi8WiIiMjVXJysho+fLi66aab1Pvvv69ycnKqrcdXO5trj5u7R8lms6n//Oc/avjw4SoxMVGFhYWpzp07qxtvvFHt2LGj1u3es2ePmjVrlho1apRKSUlR4eHhKiwsTLVp00adeeaZ6qGHHqpTfUr597dfl59VQ/W4KaXUPffc41X30qVLqy1/vPW4VbZhwwZ17733qgEDBqhWrVqpkJAQlZiYqAYMGKDuvfdetX79+lrV01R63O6//36v8l999VUd3xXRHGlKHZUVQQghhAgiXdfp3r17lUQTJpOJffv20aFDh4BdZ968eT57oOW/xcC55pprqiTBARgxYgQrV64MToNOIAcPHuSkk06qMuLhqquuCliGXxEcTqeTzp07V8mi2qdPH7Zs2SKJSU4AMlRSCCFEk+F0Onn88ce9MitecMEFAQ3ahDjetWvXjptvvrnKvo8++oj9+/cHqUUiEN5//32vpS+eeOIJCdpOEBK4CSGECKov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13A3i/+aKul1MdNw0cFpkpdT/lrfxo1JiIiIyFlycnIwffp0tGzZEt7e3ggLC0N8fDzWrVtntUxcXBwkScKYMWPka9HR0fJuipIkyTuHl5eVlYU333wTXbp0QVhYGJRKJYKCgtCpUydMmzYNaWlpZmXKysrw3XffYdKkSejQoQOCgoKgVCpRr149dOrUCYmJibhx44ZT+sLop59+wtNPP43w8HB4eXmhadOmePHFF/HHH3+YPP+4uDizstxVsnaolVMlVSoVunTpgn379mHr1q2YOnWqWR4hBLZt2wYANk9rLE+n02H48OEmI21Dhw51uO01VXaJIXBTKnzgdqHciJsDjDtKcpokEREROcvJkycRHx9vsst4SUkJdu7ciZ07d2LMmDHo1q2bU+61atUqjB8/HkVFRSbXc3NzcfDgQRw8eBDJyclmRw688MILWLFihVl92dnZcrlPPvkEGzZsQJcuXRxu5/z58zFjxgyTdWoZGRn49NNPsXr1aqxfv97he5Dr1crADQASEhKwb98+7N69G7/++is6depkkr5u3TqcO3cOADBq1Kgq1W0caUtOToa7u/tdPdJmlHtrjZuHu2+1HAVARERE5Kj8/Hz07t1bDtqGDBmChIQEhIWF4ffff8f777+PpKQkizOykpKSUFRUhA0bNuD1118HAGzbts1kOU10dLT8eOXKlfJ7SC8vL4wbNw59+vRBeHg4CgsLkZaWho0bN+LMmTNm99JqtWjatCmefPJJdOzYEY0bN4a7uzvOnz+PHTt2YNmyZbh58yaefPJJHDt2DGFhYXb3SXJyMqZPnw4ACA4OxmuvvYauXbsCAPbt24d33nkHQ4cORWhoqN33oBpC1FIajUbExsYKAKJhw4Zix44dQgghdDqdSE5OFv7+/gKA6NOnj1nZ2bNnCwACgMjIyDBJ02q1YujQoQKAcHd3F8nJyU5td15engAg8vLynFqvowav/z+BRIiQj18VomtXIQAh1qyxu74ydZmYo5gjEpEo8v6sWc+ViIjIGYqLi8WJEydEcXGxq5tSZ0yZMkV+Dzdv3jyz9LKyMtGrVy85j6X3eklJSVbTjC5fvixUKpUAIMLCwkR6errVNl24cMHs2h9//CH0er3VMmlpacLX11cAEK+//rrVfJUpKSkR9evXFwBESEiIOHPmjFme06dPi+DgYPk5d+/e3SxP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gK1bt1rMI4TAtm3bAAC9evWyue4WLVqgcePGFdZdVFSEffv2VbluIiIiIiIie9TKwA0AEhISAAC7d+/Gr7/+apa+bt06nDt3DgAwatQom+uVJEnOv3btWmRmZprl+e9//4vCwkIoFAqMGDHCjtYTERERERHZrlYHbrGxsRBC4Omnn8bOnTsBAHq9HuvWrcO4ceMAAH369EHPnj1NyiYmJkKSJEiSZDEwmzJlCsLDw6FWq9GvXz+kpqYCAMrKyrBo0SL885//BAC88MILaNGiRTU+SyIiIiIiolq6qyQAuLu7Y+PGjejRowcyMzMRHx8PlUoFvV6PkpISAECbNm2watWqKtcdEBCATZs2oXfv3jhx4gTat28PPz8/lJSUQKPRADBMkfzggw+qXLcQAgAP4iYiIiIiquuMMYExRqhIrQ3cAKBJkyZIS0vDggUL8PXXXyMjIwNKpRIxMTEYNmwYJk+eDA8PD7vqbteuHY4fP4758+dj06ZN+PPPP+Hj44PWrVsjISEBY8eOlTdIqQrjYd08iJuIiIiIiABDjBAQEFBhHknYEt6R0+j1ely+fBl+fn6QJMmlbcnPz0ejRo3w559/Wj2vjpyP/e4a7HfXYL+7BvvdNdjvrsF+dw32u3MIIVBQUICIiIhKB4Vq9YhbbeTm5obIyEhXN8OEv78//8O5APvdNdjvrsF+dw32u2uw312D/e4a7HfHVTbSZlRrNychIiIiIiKqKxi4ERERERER1XAM3OowT09PzJ49G56enq5uSp3CfncN9rtrsN9dg/3uGux312C/uwb7/c7j5iREREREREQ1HEfciIiIiIiIajgGbkRERERERDUcAzciIiIiIqIajoEbERERERFRDcfArQ4qKChAYmIiYmNj4evri4CAAHTo0AHvvfceysrKXN28WufmzZtISkrCyJEjcd9998HHxweenp6IjIzEwIED8c0331RaB18T53nnnXcgSZL8VRH2u2Py8/Mxf/58dO7cGaGhofLPfY8ePZCYmIjc3FyL5djv9vvhhx/wzDPPICoqCl5eXvD29kbTpk0xYsQI7N27t8Ky7HdzarUaW7ZswVtvvYWnnnoKUVFR8u+OxMREm+q4du0aXn31Vdx7773w9vZGcHAwunbtis8//xy27P929uxZjB8/HtHR0fDy8kJoaCh69+6Nr776ysFnV3M50u+X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",
      "text/plain": [
       "<Figure size 1000x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA24AAAJyCAYAAAC8MpMzAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjMsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvZiW1igAAAAlwSFlzAAAPYQAAD2EBqD+naQAAqatJREFUeJzs3Xlc1NX+x/HXd4ZNEBAzE0HENU0td1MjMU2t7Fpmamba5m2xru238lZ269dqN6tbVveWZZupWbmi6dVCs8XSXEtTEEXQ3BgW2Wa+vz+ISQIUmBlmBt7P++Bxh5nz/ZwPiDYfzvl+jmGapomIiIiIiIj4LIu3ExAREREREZFTU+EmIiIiIiLi41S4iYiIiIiI+DgVbiIiIiIiIj5OhZuIiIiIiIiPU+EmIiIiIiLi41S4iYiIiIiI+DgVbiIiIiIiIj4uwNsJ1DcOh4MDBw4QHh6OYRjeTkdERERERLzENE2ys7Np3rw5Fsup19RUuNWyAwcO0KJFC2+nISIiIiIiPmLfvn3ExsaecowKt1oWHh4OlPzhREREeDkbERERERHxFpvNRosWLZw1wqmocKtlpdsjIyIiVLiJiIiIiEiVbqFScxIREREREREfp8JNRERERETEx6lwExERERER8XEq3ERERERERHycCjcREREREREfp8JNRERERETEx6lwExERERER8XEq3ERERERERHycCjcREREREREfp8JNRERERETEx6lwExERERER8XEq3ERERERERHycCjcREREREREfp8JNRERERETEx6lwExERERER8XEq3ERERERERHycCjcREREREREfp8JNRERERETEx6lwExERERER8XEq3ERERERERHycCjcREREREREfp8JNRERERETEx6lwExERERER8XEq3ERERERERHycCjcREREREREfp8JNRERERETEx6lwExERERER8XEq3ERERERERHycCjcREREREREfp8JNRERERETEx6lwExERERER8XEq3ERERERERHycCjcREREREREfp8JNRERERETEx6lwExERERER8XEq3ERERERERHycCjcREREREREf57eFW15eHsuWLePJJ59k5MiRtGzZEsMwMAyDadOmuWWOgwcPcu+993L22WfToEEDGjduTEJCAv/9738xTdMtc4iIiIiIiJxOgLcTqKnvvvuOSy+9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r3bsp556ylm03X777ezfv5/s7GxOnDjBhg0buOCCC3A4HNx777388MMP7v7SfE7pNslW4YZbjwL4aOtHfLX3KxoENODFoS+6La6Iv1px7wqK8oqIuyCOc8ef6+10RERExIf4beH27rvvsmXLFgA++eQTBg8eDJSshI0ZM4Y33ngDgKVLl7Jq1apqxZ49ezYAAwYM4NVXXyUmJsYZu0ePHixevJiGDRtimibz589315fks5wdJd3YmMRWYOO+FWpIIlJqz8o9bJ9X0pDk0lcvxfDQeYkiIiLin/y6cAMYOHAgffv2Lff62LFjadWqFfBHIVZVGRkZAPTs2bPC1yMjI2nfvj0AOTk51Yrtj/5oTOK+H5fH1zxORk4GbRu35b5+97ktrog/shfaWXrHUgB6Te7FWeee5eWMRERExNf4ZeGWl5fHunXrALjkkksqHGMYBsOGDQNgxYoV1YrfunVrgEq3QWZlZbFz506g8uKuLnEWbm5qTLLt0DZe+vYlQA1JRAC+mfENR34paUgy8PGB3k5HREREfJBfFm47duzA4SgpJjp37lzpuNLXMjMzOXr0aJXj33bbbQCsWbOGyZMnk56eDpQ00/jxxx8ZPnw4OTk59O3bt0b30Pmb3VmlWyVd37plmiZ3LLsDu2nnig5XMKztMJdjivgz234bX/7zSwAufu5iQhqFeDkjERER8UV+WbgdOHDA+bj0/rOKnPzaydeczuTJk3nggQewWCy89tprxMbGEh4eTkhICD169ODXX3/lwQcfZNWqVVit1lPGKigowGazlfnwJw7TZE+2+7ZKztk6hzWpa9SQROR3K+5dQVFuES36t+Dc69SQRERERCrml4Vbdna283FoaGil405+7eRrTsdisfD000/z9ttv07BhQ6DkXrbSowDy8/PJysoiNzf3tLGefvppIiMjnR8tWrSoch6+ID3XpMAOAQbENXRtxS27IJv7vii5n+3hhIeJbxTvhgxF/NeelXvYNncbhkUNSUREROTU/LJw87TDhw8zaNAgrr/+evr27cvatWs5fvw4GRkZLFiwgDPPPJOZM2fSp08f5zbKyjz00ENkZWU5P/bt21dLX4V7OI8CiDAIsLj2pvKfX/6TA9kH1JBEhJKGJMvuXAaUNCRpdl4zL2ckIiIivizA2wnURHh4uPNxXl5epeNOfu3ka05n4sSJrFmz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iWKO7T5GZIvIWspKREREREROx22FW6lzzjmHc845x91hxQ2yM7LdOk5ERERERGqHS4Xb7NmzAbjiiiuqfL9WTk4OCxYsAGDChAmuTC/VVNU2/t5q9y8iIiIiIhVzqTmJxWLBMAy2bNlS5VW23bt3065dOywWC8XFxTWd2m95szmJw+7gpfiXsKXbKr7PzSjpLjklZYrubxMRERER8bBabU5SUy42s5QasFgtDHtpWMknf77d8PfPh80YpqJNRERERMTH1Po7dLvdDkBAgNtvr5Mq6DiyI6PnjyYipmxFHxEbwej5o+k4sqOXMhMRERERkcrUevX0yy+/ANC4cePanlp+13FkR84ecTZpyWlkZ2QTHh1OXEKcVtpERERERHxUtQq3r776qsLnv//+ew4fPnzKawsKCti9ezfTp0/HMAy6du1ananFzSxWC/GJ8d5OQ0REREREqqBahVtiYmK5s9hM0+TGG2+scgzTNDEMg1tuuaU6U4uIiIiIiNRb1d4bZ5qm86Oi5073ERsby6uvvsoVV1zhzq9DRERERESkzqrWitvq1audj03T5KKLLsIwDN566y1atWpV6XWGYRASEkJ0dDQtWrSoebYiIiIiIiL1ULUKtwEDBlT4fO/evat8jpv4CLsdkpMhIwOioyEhAaxW/4iv3L0TX7l7J75y90585e6d+MrdO/GVu3fi+2tsT8f359w9zXRBamqqmZqaahYVFbkSpl7JysoyATMrK8t7SXzyiWnGxpom/PERG1vyvK/HV+7eia/cvRNfuXsnvnL3Tnzl7p34yt078f01tqfj+3PuNVSd2sClwk2qz+uF2yefmKZhlP2BhZLnDMP1H1xPxlfuyt2XYit35e5r8ZW7cvel2Mq97sVW7h5RndrAME3T9OSK3qJFi5g7dy6HDx+mVatW3HzzzXTv3t2TU/o0m81GZGQkWVlZREREnP4Cd7LbIT4e9u+v+HXDgJgY2LatZkvGdjuccw6kp7s/vidjezq+cvdOfOXunfjK3Tvxlbt34it378RX7rUf29PxfSH32FhISan1bZPVqQ1cKtxWr17NmDFjCAkJYfPmzTRq1KjM64888ghPPfVUmeesVitvvfUW1113XU2n9WteLdzWrIGBA2t3ThERERERf7B6NSQm1uqU1akNqn0cwMmWLl3K4cOH6dWrV7mibfPmzTz11FOYJdsxadSoEaZpUlxczC233EJqaqorU0tNZGR4OwMREREREd/k4++Vq9VV8s/Wrl2LYRgMHjy43GszZ87ENE2ioqJYuXIl3bp1Y8OGDQwbNoxjx47x+uuv88wzz7gyvVRXdHTVxi1dChdeWP34X30Fl17qmfiejO3p+MrdO/GVu3fiK3fvxFfu3omv3L0TX7nXfmxPx/eV3Kv6XtlbXLmZrmXLlqbFYjG//PLLcq/FxsaaFovFfPTRR8s8/9hjj5mGYZg9evRwZWq/5dXmJMXFJZ1zKroxs/TmzBYtSsb5Wnzlrtx9KbZyV+7KXbkrd+Xua7nr++K9+C6ota6SoaGhpsViMX/66acyz//666+mYRimxWIxN27cWOa1lStXmoZhmI0aNXJlar/lM10l//yD6+6OPZ6Ir9yVuy/FVu7K3dfiK3fl7kuxlXvdi63cPaLWCrcGDRqYFovF/Oqrr8o8P2vWLNMwDDMqKqrcNRs3bjQNwzCDgoJcmdpveb1wM82Kz7Bo0cKzZ2S4K75y90585e6d+MrdO/GVu3fiK3fvxFfu3onvr7E9Hd+fc6+hWjsOoHXr1uzdu5eZM2fy17/+1fn8Nddcw8cff8xll13GokWLylyzbt06EhISaNq0KZmZmTWd2m95tavkyfz5VHrl7p34yt078ZW7d+Ird+/EV+7eia/cvRPfX2N7Or4/514DtXYcwLhx45gzZw7nnXce69atIzQ0lD179tC5c2cKCgp48cUX+dvf/lbmmlmzZnHTTTdx7rnnsmnTpppO7bd8pnATERERERGvqrXjAG6++WagpPV/586dGTVqFOeffz75+fk0aNCAcePGlbvmq6++AqB9+/auTC0iIiIiIlJvuFS4XXTRRUyZMgXTNElNTeXTTz/l8OHDADz//PM0adKkzPj8/Hw+//xzDMPgwpq08hQREREREamHXDrHDeDFF19k0KBBzJs3j8zMTKKjo5kwYQIXXXRRubELFy4kIiKCyMhILr/8clenFhERERERqRdcusdNqk/3uImIiIiICNTiPW4iIiIiIiLieSrcREREREREfJxL97ilpaW5NHlcXJxL14uIiIiIiNQHLhVurVq1qvG1hmFQXFzsyvQiIiIiIiL1gkuFm/qaiIiIiIiIeJ5LhdusWbNOOyY3N5edO3fyySefkJ6eTv/+/Z0Hd4uIiIiIiMjp1dpxAEVFRdx9993MnDmT+++/n2eeeaY2pvU5Og5ARERERETAR48DCAwM5N///jeJiYk8//zzLF++vLamFhERERER8Wu1fhzALbfcgmmavPLKK7U9tYiIiIiIiF+q9cKtXbt2AGzYsKG2pxYREREREfFLtV64ZWVllfl/ERERERERObVaL9zeffddAKKjo2t7ahEREREREb9Ua4Xbrl27uPXWW3n33XcxDINLL720tqYWERERERHxay6d49a6devTjnE4HBw/fpzs7Gznc02bNmXq1KmuTC0iIiIiIlJvuFS4paamVvuavn378vbbb2urpIiIiIiISBW5VLhNnDjxtGMsFgvh4eG0atWKAQMG0LVrV1emFBERERERqXdcKtxmzZrlrjxERERERESkErXeVVJERERERESqR4WbiIiIiIiIj1PhJiIiIiIi4uOqdI/b7NmzPTL5hAkTPBJXRERERESkLjFM0zRPN8hisWAYhnsnNgyKi4vdGtMf2Gw2IiMjycrKIiIiwtvpiIiIiIiIl1SnNqhyV8kq1HciIiIiIiLiAVUq3FJSUjydh4iIiIiIiFSiSoVby5YtPZ2HiIiIiIiIVEJdJUVERERERHycCjcREREREREfV+XmJBXJysripZdeAmDSpElER0efcnxGRgb/+c9/ALj33nsJCwtzZXoREREREZF6waXC7YMPPmDatGm0a9eORx999LTjmzVrxgcffMCvv/5KTEwMN910kyvTi4iIiIiI1AsubZVctmwZhmEwevToKo03DIOxY8dimiaLFi1yZWoREREREZF6w6XCbdOmTQD069evytf07du3zLWuys7OZtq0aXTp0oWGDRsSGRlJr169eOGFFygsLHTLHKVuvfVWDMPAMAzi4+PdGltERERERKQyLm2VPHToEMBp7207WbNmzQA4ePCgK1MDsHfvXhITE0lNTQUgNDSUgoICNmzYwIYNG/jggw9YtWoVUVFRLs+1evVq3nzzTZfjiIiIiIiIVJdLK24hISEA5OXlVfma0rFWq9WVqSkuLubyyy8nNTWV6OhovvjiC3Jzc8nLy2POnDmEh4ezceNGxo8f79I8pTlPmjSJgIAAevbs6XI8ERERERGR6nCpcCtdaduwYUOVrykdW7ryVlPvvvsuW7ZsAeCTTz5h8ODBAFgsFsaMGcMbb7wBwNKlS1m1apVLc02dOpXdu3fzwAMP0KlTJ5diiYiIiIiIVJdLhVtCQgKmafLaa69RVFR02vFFRUW89tprGIbBBRdc4MrUvPvuuwAMHDjQed/cycaOHUurVq0AmD17do3n+eabb3j55Zdp3749//jHP2ocR0REREREpKZcKtxuuOEGAHbt2sW4ceNOuWUyLy+Pa665hp07d5a5tiby8vJYt24dAJdcckmFYwzDYNiwYQCsWLGiRvMUFBRw4403Ypomb775pnNrqIiIiIiISG1yqTlJv379GDt2LHPmzGHBggV89913TJo0iYSEBOc2yoyMDL766iv++9//sn//fgzDYNSoUQwYMKDG8+7YsQOHwwFA586dKx1X+lpmZiZHjx6lcePG1Zrnn//8Jzt27ODmm292KV8RERERERFXuFS4Abz99tscPnyYlStXsn//fh577LEKx5mmCcDFF1/s3OZYUwcOHHA+jomJqXTcya8dOHCgWoXbxo0bee655zjrrLN4/vnna5YoJat2BQUFzs9tNluNY4mIiIiISP3k0lZJKOksuXz5cmbMmEFMTAymaVb40aJFC15++WWSkpJc3nKYnZ3tfBwaGlrpuJNfO/ma0ykuLubGG2+kuLiYl19+mUaNGtUoT4Cnn36ayMhI50eLFi1qHEtEREREROonl1fcoOR+sr/97W/ceeedbNq0iY0bN3L48GEAmjRpQvfu3TnvvPMwDMMd03ncM888w6ZNmxg+fDijR492KdZDDz3EPffc4/zcZrOpeBMRERERkWpxS+FWyjAMunXrRrdu3dwZtpzw8HDn49M1RKnomlPZvn07TzzxBA0bNuS1116reZK/Cw4OJjg42OU4IiIiIiJSf7m8VdIbmjdv7nycnp5e6biTXzv5mlOZPHkyhYWFTJ06laioKHJycsp8FBcXAyX37JU+V5WjEERERERERGrKLwu3jh07YrGUpL5169ZKx5W+1qxZsyo3JklJSQFKtjiGh4eX+/jggw8ASEtLcz736quvuvLliIiIiIiInJJbt0rWltDQUPr3709ycjJJSUncf//95caYpsny5csBGDJkSG2nWCtM06SoqMh5NIKI1F1Wq5WAgAC/uVdYRERE3MsvCzeAiRMnkpyczOrVq/n222/p06dPmdfnzZvHnj17AJgwYUKV46ampp7y9euvv553332Xli1bnnasp+Tl5ZGVlUV2djZ2u90rOYhI7QsODqZRo0ZERUWpgBMREaln/Lpwe+mll9iyZQtXXXUV7777LoMGDcLhcPDJJ58wadIkAC655BIGDRpU5tpp06bx+OOPAyVbI+Pj42s7/RrLzs5m//79BAYG0qhRI8LCwrBYLHoTJ1KHmaZJcXExWVlZHDx4kMLCQpo1a+bttERERKQW+W3hFhAQwMKFCxk4cCCpqakMHjyY0NBQHA4H+fn5AHTr1s15T1pdkJeXx/79+4mIiKB58+Yq1kTqmfDwcI4dO0ZmZiYNGjQgMjLS2ymJiIhILfHL5iSl4uPj2bx5M48++iidO3fGMAwCAwPp0aMH06dP55tvviEqKsrbabpNVlYWgYGBKtpE6rGoqChCQ0Ox2WzeTkVERERqkWGapuntJOoTm81GZGQkWVlZREREVPk60zTZtWsXjRo1omnTph7MUER83ZEjRzh8+DDt2rVzdtgVERER/1Od2kD/xfcTRUVF2O12wsLCvJ2KiHhZSEgIDofDea6kiIiI1H0q3PxEact//XZdREr/HdBRICIiIvWHqgA/o3vbRET/DoiIiNQ/KtxERERERER8nAo3ERERERERH6fCTURERERExMepcBOpxDvvvINhGBiGQWpqaoVj1q1bx5VXXkmzZs0ICAhwjj9+/Hit5ioiIiIidVuAtxMQ8VeLFi3iyiuvxG63ezsVEREREanjVLiJ1NC9996L3W6nefPmPPPMM3Tq1ImgoCCAah2uLiIiIiJyOircRCpx/fXXc/3111f4WlpaGrt27QLg4Ycf5rrrrqvFzERERESkvtE9biI1kJ6e7nzcvn17L2YiIiIiIvWBCjeRGigoKHA+DgwM9GImIiIiIlIfqHATqURFXSWvv/56DMNg4MCBznEDBw50jjMMg3feeadcrOzsbF544QUuuugimjVrRlBQEBEREXTr1o0777yTdevWlbvG4XDwv//9j/vuu4/+/fvTpEkTAgMDadSoEV27duW+++4jLS3NU1++iIiIiPgQ3eMmLrE7TNZm2snMM2kWanBBMytWi+HttHzKypUrueaaazh8+HCZ54uKiti0aRObNm3i3//+N6Zplnn9n//8J48//ni5eFlZWfz000/89NNPzJw5k/fff58rr7zSo1+DiIiIiHiXCjepsc9SirlnfQHpuX8UHDFhBv/qG8wVrermj9b//d//cd999/H9999z4403AvD222/Tq1cv55jY2Fjn49WrV3PJJZdQXFyM1WrluuuuY8SIEcTFxZGfn8/27dtZtmwZixYtKjdXcXEx0dHRXHnllfTt25fWrVsTEhLCvn37+Prrr3nttdfIyclh3Lhx/Pjjj3Ts2NHz3wARERER8Yq6+e5aPO6zlGLGrszH/NPzB3JNxq7MZ87gkDpZvMXExBATE1Nm9axVq1Z07ty53Nj8/HzGjx9PcXExoaGhLFmyhMTExDJj+vXrx80338y+ffvKXX/zzTfz2GOPlbuHrnv37owYMYI777yT888/n/T0dJ566inee+8993yRIiIiIuJz6t4763rONE3yij07h91hcvfXBeWKNgATMIB7vi7gouYWj26bDA0Aw/DdbZmzZ8/mwIEDADz11FPliraTtWjRotxz8fHxp4wfGxvL/fffz1133cXChQsxTdOnvx8iIiIiUnMq3OqYvGJo/E6uV3MwgfQ8kzNn53l0nqPXhxHmww0dFy9eDEBYWBiTJk1yOZ7NZuPIkSPk5eU574cLDQ11vpaSkkLr1q1dnkdEREREfI8KNxEP2bhxIwA9evRwFljVtXfvXqZPn86iRYvYu3fvKccePnxYhZuIiIhIHaXCrY4JDShZifKktRl2/rI8/7TjFg4N4YJoq8fyCPXxn97S++Cio6NrdP2yZcsYNWoUeXlVW7k8ceJEjeYREREREd/n4299pboMw/D49sHBsVZiwgwO5JoV3udmUNJdcnCsjgaoqcOHDzNu3Djy8vJo2LAh9913H0OHDqVNmzZERkYSFBQEwP/+9z8GDRoEUO44ARERERGpO1S4SbVZLSUt/8euzMeAMsVbaZn2Qt/gel+0NWnShP3795ORkVHta+fPn8/x48cB+PTTTxk8eHCF444ePepKiiIiIiLiJyzeTkD80xWtApgzOITmYWWLs5gwo84eBVBd3bt3B2DDhg1V3u5Yatu2bQA0bty40qKtNLaIiIiI1H0q3KTGrmgVwK6xoay4LITZA4NZcVkIO8eGqmj73eWXXw5AXl4eb775ZrWuLS4uOdMhPz8fh8NR4Zi8vDyd3SYiIiJST6hwE5dYLQYDmgcwpm0gA5oH1PvtkScbP348MTExAEydOpUvv/yy0rH79+8v83m7du2AkuJs7ty55cbb7XZuvvlm5zlxIiIiIlK3qXAT8ZCQkBDee+89AgICyMvLY/Dgwdx4440sXLiQH3/8kfXr1zNr1iyuvvpq2rRpU+ba0aNHExwcDMANN9zAgw8+yKpVq9iwYQPvvvsuffr04aOPPqJ///7e+NJEREREpJZpT5uIBw0cOJDFixdzzTXXcOzYMWbNmsWsWbNOe11sbCwzZ87k5ptvJj8/n2effZZnn322zJgxY8YwadKkU94DJyIiIiJ1g1bcRDxs6NCh7Nmzh6eeeop+/fpxxhlnYLVaiYiIoHv37tx1111899135a674YYbSE5O5oorruDMM88kMDCQ6Ohohg0bxscff8ycOXOwWj13Tp6IiIiI+A7D1OFPtcpmsxEZGUlWVhYRERFVvi4/P5+UlBRatWpFSEiIBzMUEV+nfw9ERETqhurUBlpxExERERER8XEq3ERERERERHycCjcREREREREfp8JNRERERETEx6lwExERERER8XEq3ERERERERHycCjcREREREREfp8JNRERERETEx6lwExERERER8XEq3ERERERERHycCjcREREREREfp8JNRERERETEx6lwExERERER8XEq3ERERERERHycCjcREREREREfp8JNRERERETEx6lwExERERER8XEq3ERERERERHycCjcREREREREfp8JNxAXvvPMOhmFgGAapqakVjlmyZAlDhw6lSZMmWK1WDMOgUaNGtZqnOyQmJmIYBomJiRW+Xvp9mDZtWq3mJSIiIlIfBHg7AZG67LXXXmPy5MneTkNERERE/JwKNxEPycvL4+GHHwagQ4cOPPnkk7Rp04aAgACsVquXsxMRERERf6LCTcRDNmzYQFZWFgDTp0/nsssu83JGnmWaprdTEBEREamzdI+biIekp6c7H7dv396LmYiIiIiIv1PhJuIhBQUFzseBgYFezERERERE/J0KN5FTOHbsGA8++CAdOnSgQYMGNG3alMGDBzNv3rxKryntvnjDDTc4n2vVqpWz66JhGKxZs6bcdb/99hv//Oc/6d+/P02bNiUwMJCoqCj69OnDAw88wObNm8tdU1hYyKJFi7jjjjvo1asXUVFRBAYGcsYZZ9CnTx+mTZvG4cOH3fK9OB11lRQRERHxHN3jJi5x2B2kJaeRnZFNeHQ4cQlxWKx14/cBO3bsYPDgwRw4cMD5XH5+PqtWrWLVqlXccMMNXHjhhW6Z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+8ItOzubadOm0aVLFxo2bEhkZCS9evXihRdeoLCwsEYx09PTee2117j66qtp27YtDRo0oEGDBrRq1YprrrmG//3vf27+KkRERERERCpnmKZpejuJmtq7dy+JiYmkpqYCEBoait1up6CgAIBu3bqxatUqoqKiqhxz3759tGzZkpO/LaGhoZimyYkTJ5zP3Xjjjbz55ptYrdZq5Vyd09FPlp+fT0pKCq1atSIkJKRac4pI3aJ/D0REROqG6tQGfrviVlxczOWXX05qairR0dF88cUX5ObmkpeXx5w5cwgPD2fjxo2MHz++WnHtdjumaTJo0CDeffdd0tPTyc3NJScnh23btjFixAgA3n77baZNm+aBr0xERERERKQsvy3c3n33XbZs2QLAJ598wuDBgwGwWCyMGTOGN954A4ClS5eyatWqKseNiorihx9+YOXKlUyYMIHmzZs7455zzjl8+umnDBs2DIAZM2aQn5/vzi9LRERERESkHL8u3AAGDhxI3759y70+duxYWrVqBcDs2bOrHDcyMpLu3btX+rphGNx4440A5OTksGPHjuqkLSIiIiIiUm1+Wbjl5eWxbt06AC655JIKxxiG4VwZW7FihVvnP/meErvd7tbYIiIiIiIif+aXhduOHTtwOBwAdO7cudJxpa9lZmZy9OhRt82/Zs0aAIKCgmjfvr3b4oqIiIiIiFQkwNsJ1MSBAwecj2NiYiodd/JrBw4coHHjxi7PnZKSwuuvvw7AmDFjTtv9paCgwNnlEko6x4iIiIiIiFSHX664ZWdnOx+HhoZWOu7k106+pqZOnDjB1VdfTV5eHk2aNOGZZ5457TVPP/00kZGRzo8WLVq4nIeIiIiIiNQvflm4eUNxcTHjxo3jhx9+IDAwkA8++MDZcfJUHnroIbKyspwf+/btq4VsRURERESkLvHLrZLh4eHOx3l5eZWOO/m1k6+pLrvdzrXXXstnn31GQEAAH374IUOGDKnStcHBwQQHB9d4bhEREREREb9ccTt5pSs9Pb3ScSe/VpXVsYrY7XbGjx/P3LlzsVqtvP/++4waNapGsaTueeeddzAMA8MwSE1NrXDMkiVLGDp0KE2aNMFqtWIYBo0aNarVPH1Famqq8/v1zjvveDsdEREREb/hl4Vbx44dsVhKUt+6dWul40pfa9asWY0ak5SutM2ZM8dZtI0ZM6Zm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",
      "text/plain": [
       "<Figure size 1000x700 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "r_ifca = {}\n",
    "r_dfca_gi = {}\n",
    "r_dfca_li = {}\n",
    "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",
    "os.makedirs('graphs', exist_ok=True)\n",
    "\n",
    "for l in range(len(learning_rates)):\n",
    "\n",
    "    plt.figure(figsize=(10,5))\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,5))\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,5))\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,7))\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": {
     "144195a9bc4947e5a03f895783f9a670": {
      "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_28dbf1539e2b4d819c6f6344545509fa",
       "placeholder": "​",
       "style": "IPY_MODEL_c848db877e1845ffa3e0e94186432e31",
       "tabbable": null,
       "tooltip": null,
       "value": " 4/4 [00:05&lt;00:00,  5.44s/engine]"
      }
     },
     "273082d462db4822834d079685314544": {
      "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_460c9ec716e848b5aff502414f194bf4",
       "placeholder": "​",
       "style": "IPY_MODEL_310fc725f1fb45e8bf8b60b7b4c6ba7d",
       "tabbable": null,
       "tooltip": null,
       "value": "100%"
      }
     },
     "28dbf1539e2b4d819c6f6344545509fa": {
      "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
      }
     },
     "310fc725f1fb45e8bf8b60b7b4c6ba7d": {
      "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
      }
     },
     "460c9ec716e848b5aff502414f194bf4": {
      "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
      }
     },
     "49dba1fc0b394811907289a5a5065fe1": {
      "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": ""
      }
     },
     "4ca9b84c6b8749c4b71d3c614fc3bf4f": {
      "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_8606070fdac845a59df3fc8c70effcff",
        "IPY_MODEL_9bcad4764bf144d4a79a95d7b9ffbb4e",
        "IPY_MODEL_aa1f5192b68148e2aa6fc6b71f7d7c8e"
       ],
       "layout": "IPY_MODEL_adfcbbc252b045bebe7c37b9f06ff680",
       "tabbable": null,
       "tooltip": null
      }
     },
     "69cfffb31d0b47cbbe29aba58cb52620": {
      "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
      }
     },
     "7ca84cd38878426bb0216de87eab68a8": {
      "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
      }
     },
     "7e9c50e16ac54e1e9dd6bf823879c784": {
      "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
      }
     },
     "8606070fdac845a59df3fc8c70effcff": {
      "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_bc99f67f1d0d446a909cfbaf1259068c",
       "placeholder": "​",
       "style": "IPY_MODEL_69cfffb31d0b47cbbe29aba58cb52620",
       "tabbable": null,
       "tooltip": null,
       "value": "unknown: 100%"
      }
     },
     "9bcad4764bf144d4a79a95d7b9ffbb4e": {
      "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_b5eda79c46234c6ea7de7165bff5c3a5",
       "max": 4,
       "min": 0,
       "orientation": "horizontal",
       "style": "IPY_MODEL_49dba1fc0b394811907289a5a5065fe1",
       "tabbable": null,
       "tooltip": null,
       "value": 4
      }
     },
     "aa1f5192b68148e2aa6fc6b71f7d7c8e": {
      "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_cebd8f776ba94f80b98be49fe883c405",
       "placeholder": "​",
       "style": "IPY_MODEL_7ca84cd38878426bb0216de87eab68a8",
       "tabbable": null,
       "tooltip": null,
       "value": " 4/4 [4:43:52&lt;00:00, 847.23s/tasks]"
      }
     },
     "adfcbbc252b045bebe7c37b9f06ff680": {
      "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
      }
     },
     "aff1dbd08eb14d4d99922b2b97f5659c": {
      "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
      }
     },
     "b5eda79c46234c6ea7de7165bff5c3a5": {
      "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
      }
     },
     "bc99f67f1d0d446a909cfbaf1259068c": {
      "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
      }
     },
     "bd02010de0c247c5a8907fdc055a1629": {
      "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": ""
      }
     },
     "c848db877e1845ffa3e0e94186432e31": {
      "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
      }
     },
     "c9d08d8972d944f5bf145660a4be587e": {
      "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_273082d462db4822834d079685314544",
        "IPY_MODEL_eeb90be7d2ef4ab0b8d78e675bcb81bf",
        "IPY_MODEL_144195a9bc4947e5a03f895783f9a670"
       ],
       "layout": "IPY_MODEL_aff1dbd08eb14d4d99922b2b97f5659c",
       "tabbable": null,
       "tooltip": null
      }
     },
     "cebd8f776ba94f80b98be49fe883c405": {
      "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
      }
     },
     "eeb90be7d2ef4ab0b8d78e675bcb81bf": {
      "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_7e9c50e16ac54e1e9dd6bf823879c784",
       "max": 4,
       "min": 0,
       "orientation": "horizontal",
       "style": "IPY_MODEL_bd02010de0c247c5a8907fdc055a1629",
       "tabbable": null,
       "tooltip": null,
       "value": 4
      }
     }
    },
    "version_major": 2,
    "version_minor": 0
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
