{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-08-08T08:03:10.032091Z",
     "iopub.status.busy": "2025-08-08T08:03:10.031843Z",
     "iopub.status.idle": "2025-08-08T08:03:15.541626Z",
     "shell.execute_reply": "2025-08-08T08:03:15.540537Z"
    },
    "id": "OHJWesKs-tqd"
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-08-08 10:03:13.205695: E external/local_xla/xla/stream_executor/cuda/cuda_fft.cc:467] Unable to register cuFFT factory: Attempting to register factory for plugin cuFFT when one has already been registered\n",
      "WARNING: All log messages before absl::InitializeLog() is called are written to STDERR\n",
      "E0000 00:00:1754640193.226342 1085291 cuda_dnn.cc:8579] Unable to register cuDNN factory: Attempting to register factory for plugin cuDNN when one has already been registered\n",
      "E0000 00:00:1754640193.232331 1085291 cuda_blas.cc:1407] Unable to register cuBLAS factory: Attempting to register factory for plugin cuBLAS when one has already been registered\n",
      "W0000 00:00:1754640193.248150 1085291 computation_placer.cc:177] computation placer already registered. Please check linkage and avoid linking the same target more than once.\n",
      "W0000 00:00:1754640193.248165 1085291 computation_placer.cc:177] computation placer already registered. Please check linkage and avoid linking the same target more than once.\n",
      "W0000 00:00:1754640193.248167 1085291 computation_placer.cc:177] computation placer already registered. Please check linkage and avoid linking the same target more than once.\n",
      "W0000 00:00:1754640193.248169 1085291 computation_placer.cc:177] computation placer already registered. Please check linkage and avoid linking the same target more than once.\n",
      "2025-08-08 10:03:13.253266: I tensorflow/core/platform/cpu_feature_guard.cc:210] This TensorFlow binary is optimized to use available CPU instructions in performance-critical operations.\n",
      "To enable the following instructions: AVX2 FMA, in other operations, rebuild TensorFlow with the appropriate compiler flags.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "WARNING:tensorflow:From /home/kirch/local/python-3.11/lib/python3.11/site-packages/tensorflow/python/compat/v2_compat.py:98: disable_resource_variables (from tensorflow.python.ops.resource_variables_toggle) is deprecated and will be removed in a future version.\n",
      "Instructions for updating:\n",
      "non-resource variables are not supported in the long term\n"
     ]
    }
   ],
   "source": [
    "import json\n",
    "import os\n",
    "import time\n",
    "import ipyparallel as ipp\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "import torch\n",
    "import ifca as IFCA\n",
    "\n",
    "import numpy as np\n",
    "\n",
    "from util import *"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-08-08T08:03:15.552429Z",
     "iopub.status.busy": "2025-08-08T08:03:15.552252Z",
     "iopub.status.idle": "2025-08-08T08:03:15.557099Z",
     "shell.execute_reply": "2025-08-08T08:03:15.556194Z"
    }
   },
   "outputs": [],
   "source": [
    "import sys\n",
    "import os\n",
    "import random\n",
    "sys.path.append(os.getcwd())\n",
    "\n",
    "random.seed(42)\n",
    "seeds = random.sample(range(10000), 5)\n",
    "learning_rates = [0.25]\n",
    "\n",
    "ifca = []"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "7ADsUSUi-tqf"
   },
   "source": [
    "Running the ifca experiment"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 1000
    },
    "execution": {
     "iopub.execute_input": "2025-08-08T08:03:15.560264Z",
     "iopub.status.busy": "2025-08-08T08:03:15.560093Z",
     "iopub.status.idle": "2025-08-10T00:19:13.147524Z",
     "shell.execute_reply": "2025-08-10T00:19:13.145939Z"
    },
    "id": "T_XDv25r-tqf",
    "outputId": "9c8f4300-c792-4e49-be40-c694fa066e6f"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "---------------------------------IFCA, lr: 0.25, seed: 1824---------------------------------\n",
      "config: {'m': 100, 'm_test': 20, 'p': 2, 'n': 1000, 'participation_rate': 1, 'num_epochs': 150, 'batch_size': 50, 'tau': 10, 'lr': 0.25, 'data_seed': 1824, 'train_seed': 1824, 'project_dir': 'output'}\n",
      "Using device: cuda:2\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "WARNING:tensorflow:From /home/kirch/repos/dfca_paper/cifar/cifar10.py:143: calling TruncatedNormal.__init__ (from tensorflow.python.ops.init_ops) with dtype is deprecated and will be removed in a future version.\n",
      "Instructions for updating:\n",
      "Call initializer instance with the dtype argument instead of passing it to the constructor\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "I0000 00:00:1754640258.553563 1085291 gpu_device.cc:2019] Created device /job:localhost/replica:0/task:0/device:GPU:0 with 38484 MB memory:  -> device: 2, name: NVIDIA A100-SXM4-40GB, pci bus id: 0000:81:00.0, compute capability: 8.0\n",
      "WARNING: All log messages before absl::InitializeLog() is called are written to STDERR\n",
      "I0000 00:00:1754640258.595906 1085291 mlir_graph_optimization_pass.cc:425] MLIR V1 optimization pass is not enabled\n",
      "2025-08-08 10:04:18.668227: W tensorflow/c/c_api.cc:305] Operation '{name:'softmax_linear/biases/Assign' id:221 op device:{requested: '/device:CPU:0', assigned: ''} def:{{{node softmax_linear/biases/Assign}} = Assign[T=DT_FLOAT, _class=[\"loc:@softmax_linear/biases\"], _has_manual_control_dependencies=true, use_locking=true, validate_shape=true, _device=\"/device:CPU:0\"](softmax_linear/biases, softmax_linear/biases/Initializer/Const)}}' was changed by setting attribute after it was run by a session. This mutation will have no effect, and will trigger an error in the future. Either don't modify nodes after running them or create a new session.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "finding good initializer from train data\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "I0000 00:00:1754640259.673424 1086153 cuda_dnn.cc:529] Loaded cuDNN version 90501\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-08-08 10:04:25.813202: W tensorflow/c/c_api.cc:305] Operation '{name:'softmax_linear/biases/Assign' id:221 op device:{requested: '/device:CPU:0', assigned: ''} def:{{{node softmax_linear/biases/Assign}} = Assign[T=DT_FLOAT, _class=[\"loc:@softmax_linear/biases\"], _has_manual_control_dependencies=true, use_locking=true, validate_shape=true, _device=\"/device:CPU:0\"](softmax_linear/biases, softmax_linear/biases/Initializer/Const)}}' was changed by setting attribute after it was run by a session. This mutation will have no effect, and will trigger an error in the future. Either don't modify nodes after running them or create a new session.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-08-08 10:04:32.454012: W tensorflow/c/c_api.cc:305] Operation '{name:'softmax_linear/biases/Assign' id:221 op device:{requested: '/device:CPU:0', assigned: ''} def:{{{node softmax_linear/biases/Assign}} = Assign[T=DT_FLOAT, _class=[\"loc:@softmax_linear/biases\"], _has_manual_control_dependencies=true, use_locking=true, validate_shape=true, _device=\"/device:CPU:0\"](softmax_linear/biases, softmax_linear/biases/Initializer/Const)}}' was changed by setting attribute after it was run by a session. This mutation will have no effect, and will trigger an error in the future. Either don't modify nodes after running them or create a new session.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-08-08 10:04:39.731058: W tensorflow/c/c_api.cc:305] Operation '{name:'softmax_linear/biases/Assign' id:221 op device:{requested: '/device:CPU:0', assigned: ''} def:{{{node softmax_linear/biases/Assign}} = Assign[T=DT_FLOAT, _class=[\"loc:@softmax_linear/biases\"], _has_manual_control_dependencies=true, use_locking=true, validate_shape=true, _device=\"/device:CPU:0\"](softmax_linear/biases, softmax_linear/biases/Initializer/Const)}}' was changed by setting attribute after it was run by a session. This mutation will have no effect, and will trigger an error in the future. Either don't modify nodes after running them or create a new session.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-08-08 10:04:45.026232: W tensorflow/c/c_api.cc:305] Operation '{name:'softmax_linear/biases/Assign' id:221 op device:{requested: '/device:CPU:0', assigned: ''} def:{{{node softmax_linear/biases/Assign}} = Assign[T=DT_FLOAT, _class=[\"loc:@softmax_linear/biases\"], _has_manual_control_dependencies=true, use_locking=true, validate_shape=true, _device=\"/device:CPU:0\"](softmax_linear/biases, softmax_linear/biases/Initializer/Const)}}' was changed by setting attribute after it was run by a session. This mutation will have no effect, and will trigger an error in the future. Either don't modify nodes after running them or create a new session.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "found good initializer\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0 tr: l 3.853 a 0.191  clct[np.int64(49), np.int64(51)] ans[np.int64(50), np.int64(50)] lr 0.250000 cl_acc 0.670000 134.880sec(train) 7.215sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0 tst: l 3.853 a 0.203  clct[np.int64(9), np.int64(11)] ans[np.int64(10), np.int64(10)] cl_acc 0.950000 1.516sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10 tr: l 1.204 a 0.646  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.226096 cl_acc 1.000000 431.069sec(train) 9.997sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10 tst: l 1.105 a 0.686  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000000 2.038sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20 tr: l 1.004 a 0.713  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.204477 cl_acc 1.000000 402.520sec(train) 10.015sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20 tst: l 0.939 a 0.738  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000000 1.774sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 30 tr: l 0.920 a 0.745  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.184925 cl_acc 1.000000 139.685sec(train) 5.172sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 30 tst: l 0.879 a 0.762  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000000 0.968sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 40 tr: l 0.843 a 0.770  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.167243 cl_acc 1.000000 139.934sec(train) 5.853sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 40 tst: l 0.841 a 0.777  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000000 1.217sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 50 tr: l 0.802 a 0.786  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.151252 cl_acc 1.000000 137.864sec(train) 5.027sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 50 tst: l 0.807 a 0.788  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000000 1.072sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 60 tr: l 0.751 a 0.801  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.136789 cl_acc 1.000000 134.628sec(train) 5.653sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 60 tst: l 0.784 a 0.795  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000000 1.090sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 70 tr: l 0.727 a 0.806  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.123710 cl_acc 1.000000 139.541sec(train) 5.437sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 70 tst: l 0.761 a 0.801  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000000 1.151sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 80 tr: l 0.693 a 0.818  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.111881 cl_acc 1.000000 152.627sec(train) 5.363sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 80 tst: l 0.744 a 0.805  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000000 1.402sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 90 tr: l 0.677 a 0.821  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.101183 cl_acc 1.000000 152.510sec(train) 9.165sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 90 tst: l 0.726 a 0.811  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000000 2.135sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 100 tr: l 0.643 a 0.830  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.091508 cl_acc 1.000000 134.724sec(train) 5.769sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 100 tst: l 0.714 a 0.814  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000000 1.133sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 110 tr: l 0.621 a 0.837  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.082758 cl_acc 1.000000 138.699sec(train) 5.758sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 110 tst: l 0.701 a 0.815  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000000 1.074sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 120 tr: l 0.606 a 0.841  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.074845 cl_acc 1.000000 148.002sec(train) 5.790sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 120 tst: l 0.692 a 0.818  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000000 1.198sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 130 tr: l 0.576 a 0.850  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.067689 cl_acc 1.000000 147.428sec(train) 5.185sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 130 tst: l 0.682 a 0.822  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000000 1.415sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 140 tr: l 0.562 a 0.853  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.061216 cl_acc 1.000000 146.359sec(train) 5.257sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 140 tst: l 0.674 a 0.823  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000000 1.018sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "result written at output/results.pickle\n",
      "---train cluster Ended in 7.49 hour (26948.402 sec) \n",
      "---------------------------------IFCA, lr: 0.25, seed: 409---------------------------------\n",
      "config: {'m': 100, 'm_test': 20, 'p': 2, 'n': 1000, 'participation_rate': 1, 'num_epochs': 150, 'batch_size': 50, 'tau': 10, 'lr': 0.25, 'data_seed': 409, 'train_seed': 409, 'project_dir': 'output'}\n",
      "Using device: cuda:2\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "I0000 00:00:1754667148.166844 1085291 gpu_device.cc:2019] Created device /job:localhost/replica:0/task:0/device:GPU:0 with 38484 MB memory:  -> device: 2, name: NVIDIA A100-SXM4-40GB, pci bus id: 0000:81:00.0, compute capability: 8.0\n",
      "2025-08-08 17:32:28.216291: W tensorflow/c/c_api.cc:305] Operation '{name:'softmax_linear/biases/Assign' id:221 op device:{requested: '/device:CPU:0', assigned: ''} def:{{{node softmax_linear/biases/Assign}} = Assign[T=DT_FLOAT, _class=[\"loc:@softmax_linear/biases\"], _has_manual_control_dependencies=true, use_locking=true, validate_shape=true, _device=\"/device:CPU:0\"](softmax_linear/biases, softmax_linear/biases/Initializer/Const)}}' was changed by setting attribute after it was run by a session. This mutation will have no effect, and will trigger an error in the future. Either don't modify nodes after running them or create a new session.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "finding good initializer from train data\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-08-08 17:32:36.705680: W tensorflow/c/c_api.cc:305] Operation '{name:'softmax_linear/biases/Assign' id:221 op device:{requested: '/device:CPU:0', assigned: ''} def:{{{node softmax_linear/biases/Assign}} = Assign[T=DT_FLOAT, _class=[\"loc:@softmax_linear/biases\"], _has_manual_control_dependencies=true, use_locking=true, validate_shape=true, _device=\"/device:CPU:0\"](softmax_linear/biases, softmax_linear/biases/Initializer/Const)}}' was changed by setting attribute after it was run by a session. This mutation will have no effect, and will trigger an error in the future. Either don't modify nodes after running them or create a new session.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-08-08 17:32:43.960279: W tensorflow/c/c_api.cc:305] Operation '{name:'softmax_linear/biases/Assign' id:221 op device:{requested: '/device:CPU:0', assigned: ''} def:{{{node softmax_linear/biases/Assign}} = Assign[T=DT_FLOAT, _class=[\"loc:@softmax_linear/biases\"], _has_manual_control_dependencies=true, use_locking=true, validate_shape=true, _device=\"/device:CPU:0\"](softmax_linear/biases, softmax_linear/biases/Initializer/Const)}}' was changed by setting attribute after it was run by a session. This mutation will have no effect, and will trigger an error in the future. Either don't modify nodes after running them or create a new session.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-08-08 17:32:49.168834: W tensorflow/c/c_api.cc:305] Operation '{name:'softmax_linear/biases/Assign' id:221 op device:{requested: '/device:CPU:0', assigned: ''} def:{{{node softmax_linear/biases/Assign}} = Assign[T=DT_FLOAT, _class=[\"loc:@softmax_linear/biases\"], _has_manual_control_dependencies=true, use_locking=true, validate_shape=true, _device=\"/device:CPU:0\"](softmax_linear/biases, softmax_linear/biases/Initializer/Const)}}' was changed by setting attribute after it was run by a session. This mutation will have no effect, and will trigger an error in the future. Either don't modify nodes after running them or create a new session.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-08-08 17:32:54.436582: W tensorflow/c/c_api.cc:305] Operation '{name:'softmax_linear/biases/Assign' id:221 op device:{requested: '/device:CPU:0', assigned: ''} def:{{{node softmax_linear/biases/Assign}} = Assign[T=DT_FLOAT, _class=[\"loc:@softmax_linear/biases\"], _has_manual_control_dependencies=true, use_locking=true, validate_shape=true, _device=\"/device:CPU:0\"](softmax_linear/biases, softmax_linear/biases/Initializer/Const)}}' was changed by setting attribute after it was run by a session. This mutation will have no effect, and will trigger an error in the future. Either don't modify nodes after running them or create a new session.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-08-08 17:32:59.718841: W tensorflow/c/c_api.cc:305] Operation '{name:'softmax_linear/biases/Assign' id:221 op device:{requested: '/device:CPU:0', assigned: ''} def:{{{node softmax_linear/biases/Assign}} = Assign[T=DT_FLOAT, _class=[\"loc:@softmax_linear/biases\"], _has_manual_control_dependencies=true, use_locking=true, validate_shape=true, _device=\"/device:CPU:0\"](softmax_linear/biases, softmax_linear/biases/Initializer/Const)}}' was changed by setting attribute after it was run by a session. This mutation will have no effect, and will trigger an error in the future. Either don't modify nodes after running them or create a new session.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-08-08 17:33:04.960191: W tensorflow/c/c_api.cc:305] Operation '{name:'softmax_linear/biases/Assign' id:221 op device:{requested: '/device:CPU:0', assigned: ''} def:{{{node softmax_linear/biases/Assign}} = Assign[T=DT_FLOAT, _class=[\"loc:@softmax_linear/biases\"], _has_manual_control_dependencies=true, use_locking=true, validate_shape=true, _device=\"/device:CPU:0\"](softmax_linear/biases, softmax_linear/biases/Initializer/Const)}}' was changed by setting attribute after it was run by a session. This mutation will have no effect, and will trigger an error in the future. Either don't modify nodes after running them or create a new session.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "found good initializer\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0 tr: l 3.838 a 0.220  clct[np.int64(25), np.int64(75)] ans[np.int64(50), np.int64(50)] lr 0.250000 cl_acc 0.750000 143.895sec(train) 7.101sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0 tst: l 3.836 a 0.236  clct[np.int64(5), np.int64(15)] ans[np.int64(10), np.int64(10)] cl_acc 0.750000 1.577sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10 tr: l 1.210 a 0.644  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.226096 cl_acc 1.000000 146.047sec(train) 5.456sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10 tst: l 1.110 a 0.682  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000000 1.020sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20 tr: l 1.009 a 0.714  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.204477 cl_acc 1.000000 1127.234sec(train) 18.704sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20 tst: l 0.945 a 0.736  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000000 3.400sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 30 tr: l 0.909 a 0.749  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.184925 cl_acc 1.000000 151.645sec(train) 5.438sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 30 tst: l 0.884 a 0.764  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000000 1.057sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 40 tr: l 0.840 a 0.774  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.167243 cl_acc 1.000000 148.864sec(train) 5.547sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 40 tst: l 0.847 a 0.775  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000000 1.324sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 50 tr: l 0.799 a 0.784  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.151252 cl_acc 1.000000 144.866sec(train) 5.240sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 50 tst: l 0.813 a 0.787  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000000 1.312sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 60 tr: l 0.760 a 0.798  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.136789 cl_acc 1.000000 144.829sec(train) 5.240sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 60 tst: l 0.792 a 0.793  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000000 1.216sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 70 tr: l 0.719 a 0.809  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.123710 cl_acc 1.000000 144.519sec(train) 7.698sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 70 tst: l 0.769 a 0.800  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000000 1.484sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 80 tr: l 0.709 a 0.813  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.111881 cl_acc 1.000000 146.135sec(train) 7.538sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 80 tst: l 0.753 a 0.804  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000000 1.682sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 90 tr: l 0.657 a 0.828  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.101183 cl_acc 1.000000 142.097sec(train) 6.058sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 90 tst: l 0.735 a 0.808  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000000 1.331sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 100 tr: l 0.645 a 0.831  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.091508 cl_acc 1.000000 145.549sec(train) 7.629sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 100 tst: l 0.721 a 0.811  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000000 1.704sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 110 tr: l 0.614 a 0.839  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.082758 cl_acc 1.000000 146.138sec(train) 5.229sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 110 tst: l 0.708 a 0.814  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000000 1.225sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 120 tr: l 0.604 a 0.841  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.074845 cl_acc 1.000000 146.882sec(train) 6.041sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 120 tst: l 0.701 a 0.816  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000000 1.014sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 130 tr: l 0.579 a 0.849  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.067689 cl_acc 1.000000 143.034sec(train) 5.292sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 130 tst: l 0.688 a 0.819  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000000 1.032sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 140 tr: l 0.562 a 0.853  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.061216 cl_acc 1.000000 143.803sec(train) 5.174sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 140 tst: l 0.684 a 0.822  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000000 1.276sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "result written at output/results.pickle\n",
      "---train cluster Ended in 10.14 hour (36512.821 sec) \n",
      "---------------------------------IFCA, lr: 0.25, seed: 4506---------------------------------\n",
      "config: {'m': 100, 'm_test': 20, 'p': 2, 'n': 1000, 'participation_rate': 1, 'num_epochs': 150, 'batch_size': 50, 'tau': 10, 'lr': 0.25, 'data_seed': 4506, 'train_seed': 4506, 'project_dir': 'output'}\n",
      "Using device: cuda:2\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "I0000 00:00:1754703660.910463 1085291 gpu_device.cc:2019] Created device /job:localhost/replica:0/task:0/device:GPU:0 with 38484 MB memory:  -> device: 2, name: NVIDIA A100-SXM4-40GB, pci bus id: 0000:81:00.0, compute capability: 8.0\n",
      "2025-08-09 03:41:00.966796: W tensorflow/c/c_api.cc:305] Operation '{name:'softmax_linear/biases/Assign' id:221 op device:{requested: '/device:CPU:0', assigned: ''} def:{{{node softmax_linear/biases/Assign}} = Assign[T=DT_FLOAT, _class=[\"loc:@softmax_linear/biases\"], _has_manual_control_dependencies=true, use_locking=true, validate_shape=true, _device=\"/device:CPU:0\"](softmax_linear/biases, softmax_linear/biases/Initializer/Const)}}' was changed by setting attribute after it was run by a session. This mutation will have no effect, and will trigger an error in the future. Either don't modify nodes after running them or create a new session.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "finding good initializer from train data\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-08-09 03:41:09.166913: W tensorflow/c/c_api.cc:305] Operation '{name:'softmax_linear/biases/Assign' id:221 op device:{requested: '/device:CPU:0', assigned: ''} def:{{{node softmax_linear/biases/Assign}} = Assign[T=DT_FLOAT, _class=[\"loc:@softmax_linear/biases\"], _has_manual_control_dependencies=true, use_locking=true, validate_shape=true, _device=\"/device:CPU:0\"](softmax_linear/biases, softmax_linear/biases/Initializer/Const)}}' was changed by setting attribute after it was run by a session. This mutation will have no effect, and will trigger an error in the future. Either don't modify nodes after running them or create a new session.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-08-09 03:41:16.525335: W tensorflow/c/c_api.cc:305] Operation '{name:'softmax_linear/biases/Assign' id:221 op device:{requested: '/device:CPU:0', assigned: ''} def:{{{node softmax_linear/biases/Assign}} = Assign[T=DT_FLOAT, _class=[\"loc:@softmax_linear/biases\"], _has_manual_control_dependencies=true, use_locking=true, validate_shape=true, _device=\"/device:CPU:0\"](softmax_linear/biases, softmax_linear/biases/Initializer/Const)}}' was changed by setting attribute after it was run by a session. This mutation will have no effect, and will trigger an error in the future. Either don't modify nodes after running them or create a new session.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-08-09 03:41:24.381557: W tensorflow/c/c_api.cc:305] Operation '{name:'softmax_linear/biases/Assign' id:221 op device:{requested: '/device:CPU:0', assigned: ''} def:{{{node softmax_linear/biases/Assign}} = Assign[T=DT_FLOAT, _class=[\"loc:@softmax_linear/biases\"], _has_manual_control_dependencies=true, use_locking=true, validate_shape=true, _device=\"/device:CPU:0\"](softmax_linear/biases, softmax_linear/biases/Initializer/Const)}}' was changed by setting attribute after it was run by a session. This mutation will have no effect, and will trigger an error in the future. Either don't modify nodes after running them or create a new session.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-08-09 03:41:32.678525: W tensorflow/c/c_api.cc:305] Operation '{name:'softmax_linear/biases/Assign' id:221 op device:{requested: '/device:CPU:0', assigned: ''} def:{{{node softmax_linear/biases/Assign}} = Assign[T=DT_FLOAT, _class=[\"loc:@softmax_linear/biases\"], _has_manual_control_dependencies=true, use_locking=true, validate_shape=true, _device=\"/device:CPU:0\"](softmax_linear/biases, softmax_linear/biases/Initializer/Const)}}' was changed by setting attribute after it was run by a session. This mutation will have no effect, and will trigger an error in the future. Either don't modify nodes after running them or create a new session.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-08-09 03:41:40.906642: W tensorflow/c/c_api.cc:305] Operation '{name:'softmax_linear/biases/Assign' id:221 op device:{requested: '/device:CPU:0', assigned: ''} def:{{{node softmax_linear/biases/Assign}} = Assign[T=DT_FLOAT, _class=[\"loc:@softmax_linear/biases\"], _has_manual_control_dependencies=true, use_locking=true, validate_shape=true, _device=\"/device:CPU:0\"](softmax_linear/biases, softmax_linear/biases/Initializer/Const)}}' was changed by setting attribute after it was run by a session. This mutation will have no effect, and will trigger an error in the future. Either don't modify nodes after running them or create a new session.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "found good initializer\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0 tr: l 3.852 a 0.190  clct[np.int64(13), np.int64(87)] ans[np.int64(50), np.int64(50)] lr 0.250000 cl_acc 0.630000 149.263sec(train) 6.243sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0 tst: l 3.851 a 0.188  clct[np.int64(0), np.int64(20)] ans[np.int64(10), np.int64(10)] cl_acc 0.500000 1.025sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10 tr: l 1.193 a 0.652  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.226096 cl_acc 1.000000 149.427sec(train) 5.409sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10 tst: l 1.109 a 0.684  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000000 1.042sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20 tr: l 0.972 a 0.728  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.204477 cl_acc 1.000000 149.386sec(train) 5.254sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20 tst: l 0.939 a 0.741  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000000 1.282sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 30 tr: l 0.907 a 0.750  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.184925 cl_acc 1.000000 147.727sec(train) 5.358sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 30 tst: l 0.880 a 0.763  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000000 1.052sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 40 tr: l 0.856 a 0.768  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.167243 cl_acc 1.000000 150.949sec(train) 7.581sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 40 tst: l 0.838 a 0.779  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000000 1.502sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 50 tr: l 0.808 a 0.784  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.151252 cl_acc 1.000000 150.473sec(train) 5.488sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 50 tst: l 0.808 a 0.786  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000000 1.531sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 60 tr: l 0.772 a 0.793  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.136789 cl_acc 1.000000 148.038sec(train) 7.440sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 60 tst: l 0.778 a 0.797  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000000 1.503sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 70 tr: l 0.724 a 0.807  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.123710 cl_acc 1.000000 146.682sec(train) 7.557sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 70 tst: l 0.759 a 0.802  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000000 1.484sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 80 tr: l 0.702 a 0.815  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.111881 cl_acc 1.000000 147.361sec(train) 5.199sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 80 tst: l 0.740 a 0.805  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000000 1.359sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 90 tr: l 0.672 a 0.823  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.101183 cl_acc 1.000000 148.382sec(train) 5.275sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 90 tst: l 0.726 a 0.810  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000000 1.050sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 100 tr: l 0.651 a 0.831  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.091508 cl_acc 1.000000 145.279sec(train) 5.173sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 100 tst: l 0.713 a 0.813  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000000 1.240sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 110 tr: l 0.615 a 0.839  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.082758 cl_acc 1.000000 147.988sec(train) 5.159sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 110 tst: l 0.699 a 0.817  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000000 1.099sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 120 tr: l 0.592 a 0.846  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.074845 cl_acc 1.000000 150.040sec(train) 5.292sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 120 tst: l 0.688 a 0.819  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000000 1.254sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 130 tr: l 0.573 a 0.850  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.067689 cl_acc 1.000000 149.536sec(train) 5.719sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 130 tst: l 0.677 a 0.822  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000000 1.098sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 140 tr: l 0.561 a 0.853  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.061216 cl_acc 1.000000 147.092sec(train) 5.151sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 140 tst: l 0.670 a 0.823  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000000 1.214sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "result written at output/results.pickle\n",
      "---train cluster Ended in 6.49 hour (23355.259 sec) \n",
      "---------------------------------IFCA, lr: 0.25, seed: 4012---------------------------------\n",
      "config: {'m': 100, 'm_test': 20, 'p': 2, 'n': 1000, 'participation_rate': 1, 'num_epochs': 150, 'batch_size': 50, 'tau': 10, 'lr': 0.25, 'data_seed': 4012, 'train_seed': 4012, 'project_dir': 'output'}\n",
      "Using device: cuda:2\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "I0000 00:00:1754727016.147674 1085291 gpu_device.cc:2019] Created device /job:localhost/replica:0/task:0/device:GPU:0 with 38484 MB memory:  -> device: 2, name: NVIDIA A100-SXM4-40GB, pci bus id: 0000:81:00.0, compute capability: 8.0\n",
      "2025-08-09 10:10:16.195484: W tensorflow/c/c_api.cc:305] Operation '{name:'softmax_linear/biases/Assign' id:221 op device:{requested: '/device:CPU:0', assigned: ''} def:{{{node softmax_linear/biases/Assign}} = Assign[T=DT_FLOAT, _class=[\"loc:@softmax_linear/biases\"], _has_manual_control_dependencies=true, use_locking=true, validate_shape=true, _device=\"/device:CPU:0\"](softmax_linear/biases, softmax_linear/biases/Initializer/Const)}}' was changed by setting attribute after it was run by a session. This mutation will have no effect, and will trigger an error in the future. Either don't modify nodes after running them or create a new session.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "finding good initializer from train data\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-08-09 10:10:25.787292: W tensorflow/c/c_api.cc:305] Operation '{name:'softmax_linear/biases/Assign' id:221 op device:{requested: '/device:CPU:0', assigned: ''} def:{{{node softmax_linear/biases/Assign}} = Assign[T=DT_FLOAT, _class=[\"loc:@softmax_linear/biases\"], _has_manual_control_dependencies=true, use_locking=true, validate_shape=true, _device=\"/device:CPU:0\"](softmax_linear/biases, softmax_linear/biases/Initializer/Const)}}' was changed by setting attribute after it was run by a session. This mutation will have no effect, and will trigger an error in the future. Either don't modify nodes after running them or create a new session.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-08-09 10:10:31.051818: W tensorflow/c/c_api.cc:305] Operation '{name:'softmax_linear/biases/Assign' id:221 op device:{requested: '/device:CPU:0', assigned: ''} def:{{{node softmax_linear/biases/Assign}} = Assign[T=DT_FLOAT, _class=[\"loc:@softmax_linear/biases\"], _has_manual_control_dependencies=true, use_locking=true, validate_shape=true, _device=\"/device:CPU:0\"](softmax_linear/biases, softmax_linear/biases/Initializer/Const)}}' was changed by setting attribute after it was run by a session. This mutation will have no effect, and will trigger an error in the future. Either don't modify nodes after running them or create a new session.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-08-09 10:10:36.348695: W tensorflow/c/c_api.cc:305] Operation '{name:'softmax_linear/biases/Assign' id:221 op device:{requested: '/device:CPU:0', assigned: ''} def:{{{node softmax_linear/biases/Assign}} = Assign[T=DT_FLOAT, _class=[\"loc:@softmax_linear/biases\"], _has_manual_control_dependencies=true, use_locking=true, validate_shape=true, _device=\"/device:CPU:0\"](softmax_linear/biases, softmax_linear/biases/Initializer/Const)}}' was changed by setting attribute after it was run by a session. This mutation will have no effect, and will trigger an error in the future. Either don't modify nodes after running them or create a new session.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "found good initializer\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0 tr: l 3.800 a 0.225  clct[np.int64(47), np.int64(53)] ans[np.int64(50), np.int64(50)] lr 0.250000 cl_acc 0.970000 146.034sec(train) 5.350sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0 tst: l 3.794 a 0.238  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000000 1.483sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10 tr: l 1.190 a 0.654  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.226096 cl_acc 1.000000 152.180sec(train) 5.196sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10 tst: l 1.099 a 0.689  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000000 1.325sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20 tr: l 0.977 a 0.725  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.204477 cl_acc 1.000000 147.627sec(train) 5.624sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20 tst: l 0.937 a 0.741  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000000 1.184sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 30 tr: l 0.897 a 0.754  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.184925 cl_acc 1.000000 1137.178sec(train) 22.860sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 30 tst: l 0.879 a 0.764  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000000 3.383sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 40 tr: l 0.863 a 0.765  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.167243 cl_acc 1.000000 146.922sec(train) 5.413sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 40 tst: l 0.842 a 0.776  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000000 1.155sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 50 tr: l 0.795 a 0.787  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.151252 cl_acc 1.000000 144.086sec(train) 7.925sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 50 tst: l 0.809 a 0.787  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000000 1.569sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 60 tr: l 0.755 a 0.798  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.136789 cl_acc 1.000000 139.981sec(train) 5.241sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 60 tst: l 0.784 a 0.795  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000000 1.539sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 70 tr: l 0.719 a 0.809  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.123710 cl_acc 1.000000 136.222sec(train) 5.553sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 70 tst: l 0.763 a 0.800  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000000 1.223sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 80 tr: l 0.693 a 0.818  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.111881 cl_acc 1.000000 133.419sec(train) 5.075sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 80 tst: l 0.745 a 0.806  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000000 1.026sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 90 tr: l 0.664 a 0.825  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.101183 cl_acc 1.000000 142.043sec(train) 5.283sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 90 tst: l 0.730 a 0.810  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000000 0.995sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 100 tr: l 0.655 a 0.826  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.091508 cl_acc 1.000000 145.319sec(train) 5.026sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 100 tst: l 0.713 a 0.816  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000000 1.020sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 110 tr: l 0.618 a 0.838  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.082758 cl_acc 1.000000 146.204sec(train) 5.382sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 110 tst: l 0.703 a 0.817  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000000 1.037sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 120 tr: l 0.588 a 0.846  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.074845 cl_acc 1.000000 137.311sec(train) 5.043sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 120 tst: l 0.692 a 0.822  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000000 1.386sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 130 tr: l 0.586 a 0.845  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.067689 cl_acc 1.000000 133.032sec(train) 4.944sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 130 tst: l 0.680 a 0.824  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000000 1.284sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 140 tr: l 0.550 a 0.856  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.061216 cl_acc 1.000000 134.442sec(train) 5.375sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 140 tst: l 0.671 a 0.825  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000000 1.054sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "result written at output/results.pickle\n",
      "---train cluster Ended in 10.06 hour (36200.369 sec) \n",
      "---------------------------------IFCA, lr: 0.25, seed: 3657---------------------------------\n",
      "config: {'m': 100, 'm_test': 20, 'p': 2, 'n': 1000, 'participation_rate': 1, 'num_epochs': 150, 'batch_size': 50, 'tau': 10, 'lr': 0.25, 'data_seed': 3657, 'train_seed': 3657, 'project_dir': 'output'}\n",
      "Using device: cuda:2\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "I0000 00:00:1754763216.578162 1085291 gpu_device.cc:2019] Created device /job:localhost/replica:0/task:0/device:GPU:0 with 38484 MB memory:  -> device: 2, name: NVIDIA A100-SXM4-40GB, pci bus id: 0000:81:00.0, compute capability: 8.0\n",
      "2025-08-09 20:13:36.629142: W tensorflow/c/c_api.cc:305] Operation '{name:'softmax_linear/biases/Assign' id:221 op device:{requested: '/device:CPU:0', assigned: ''} def:{{{node softmax_linear/biases/Assign}} = Assign[T=DT_FLOAT, _class=[\"loc:@softmax_linear/biases\"], _has_manual_control_dependencies=true, use_locking=true, validate_shape=true, _device=\"/device:CPU:0\"](softmax_linear/biases, softmax_linear/biases/Initializer/Const)}}' was changed by setting attribute after it was run by a session. This mutation will have no effect, and will trigger an error in the future. Either don't modify nodes after running them or create a new session.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "finding good initializer from train data\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-08-09 20:13:43.098951: W tensorflow/c/c_api.cc:305] Operation '{name:'softmax_linear/biases/Assign' id:221 op device:{requested: '/device:CPU:0', assigned: ''} def:{{{node softmax_linear/biases/Assign}} = Assign[T=DT_FLOAT, _class=[\"loc:@softmax_linear/biases\"], _has_manual_control_dependencies=true, use_locking=true, validate_shape=true, _device=\"/device:CPU:0\"](softmax_linear/biases, softmax_linear/biases/Initializer/Const)}}' was changed by setting attribute after it was run by a session. This mutation will have no effect, and will trigger an error in the future. Either don't modify nodes after running them or create a new session.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-08-09 20:13:48.466726: W tensorflow/c/c_api.cc:305] Operation '{name:'softmax_linear/biases/Assign' id:221 op device:{requested: '/device:CPU:0', assigned: ''} def:{{{node softmax_linear/biases/Assign}} = Assign[T=DT_FLOAT, _class=[\"loc:@softmax_linear/biases\"], _has_manual_control_dependencies=true, use_locking=true, validate_shape=true, _device=\"/device:CPU:0\"](softmax_linear/biases, softmax_linear/biases/Initializer/Const)}}' was changed by setting attribute after it was run by a session. This mutation will have no effect, and will trigger an error in the future. Either don't modify nodes after running them or create a new session.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-08-09 20:13:53.903497: W tensorflow/c/c_api.cc:305] Operation '{name:'softmax_linear/biases/Assign' id:221 op device:{requested: '/device:CPU:0', assigned: ''} def:{{{node softmax_linear/biases/Assign}} = Assign[T=DT_FLOAT, _class=[\"loc:@softmax_linear/biases\"], _has_manual_control_dependencies=true, use_locking=true, validate_shape=true, _device=\"/device:CPU:0\"](softmax_linear/biases, softmax_linear/biases/Initializer/Const)}}' was changed by setting attribute after it was run by a session. This mutation will have no effect, and will trigger an error in the future. Either don't modify nodes after running them or create a new session.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-08-09 20:13:59.427012: W tensorflow/c/c_api.cc:305] Operation '{name:'softmax_linear/biases/Assign' id:221 op device:{requested: '/device:CPU:0', assigned: ''} def:{{{node softmax_linear/biases/Assign}} = Assign[T=DT_FLOAT, _class=[\"loc:@softmax_linear/biases\"], _has_manual_control_dependencies=true, use_locking=true, validate_shape=true, _device=\"/device:CPU:0\"](softmax_linear/biases, softmax_linear/biases/Initializer/Const)}}' was changed by setting attribute after it was run by a session. This mutation will have no effect, and will trigger an error in the future. Either don't modify nodes after running them or create a new session.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-08-09 20:14:04.909743: W tensorflow/c/c_api.cc:305] Operation '{name:'softmax_linear/biases/Assign' id:221 op device:{requested: '/device:CPU:0', assigned: ''} def:{{{node softmax_linear/biases/Assign}} = Assign[T=DT_FLOAT, _class=[\"loc:@softmax_linear/biases\"], _has_manual_control_dependencies=true, use_locking=true, validate_shape=true, _device=\"/device:CPU:0\"](softmax_linear/biases, softmax_linear/biases/Initializer/Const)}}' was changed by setting attribute after it was run by a session. This mutation will have no effect, and will trigger an error in the future. Either don't modify nodes after running them or create a new session.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "found good initializer\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0 tr: l 3.834 a 0.237  clct[np.int64(52), np.int64(48)] ans[np.int64(50), np.int64(50)] lr 0.250000 cl_acc 0.980000 145.135sec(train) 5.317sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0 tst: l 3.830 a 0.250  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000000 1.616sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10 tr: l 1.182 a 0.654  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.226096 cl_acc 1.000000 144.625sec(train) 5.098sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10 tst: l 1.097 a 0.688  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000000 1.482sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20 tr: l 0.988 a 0.720  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.204477 cl_acc 1.000000 142.592sec(train) 7.363sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20 tst: l 0.932 a 0.744  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000000 1.378sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 30 tr: l 0.916 a 0.747  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.184925 cl_acc 1.000000 144.732sec(train) 5.021sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 30 tst: l 0.875 a 0.763  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000000 1.326sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 40 tr: l 0.866 a 0.763  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.167243 cl_acc 1.000000 143.312sec(train) 5.236sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 40 tst: l 0.835 a 0.778  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000000 1.340sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 50 tr: l 0.810 a 0.781  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.151252 cl_acc 1.000000 141.167sec(train) 5.207sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 50 tst: l 0.807 a 0.786  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000000 1.333sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 60 tr: l 0.756 a 0.798  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.136789 cl_acc 1.000000 142.875sec(train) 5.087sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 60 tst: l 0.779 a 0.797  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000000 1.336sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 70 tr: l 0.723 a 0.809  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.123710 cl_acc 1.000000 137.538sec(train) 5.050sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 70 tst: l 0.761 a 0.801  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000000 1.204sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 80 tr: l 0.681 a 0.821  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.111881 cl_acc 1.000000 136.166sec(train) 5.030sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 80 tst: l 0.741 a 0.808  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000000 1.343sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 90 tr: l 0.658 a 0.827  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.101183 cl_acc 1.000000 144.805sec(train) 5.166sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 90 tst: l 0.727 a 0.810  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000000 1.444sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 100 tr: l 0.645 a 0.830  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.091508 cl_acc 1.000000 134.539sec(train) 6.954sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 100 tst: l 0.714 a 0.814  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000000 1.578sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 110 tr: l 0.609 a 0.840  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.082758 cl_acc 1.000000 139.047sec(train) 8.154sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 110 tst: l 0.704 a 0.816  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000000 1.676sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 120 tr: l 0.606 a 0.840  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.074845 cl_acc 1.000000 139.428sec(train) 7.282sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 120 tst: l 0.695 a 0.819  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000000 1.509sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 130 tr: l 0.570 a 0.851  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.067689 cl_acc 1.000000 137.134sec(train) 5.045sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 130 tst: l 0.683 a 0.823  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000000 1.316sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 140 tr: l 0.551 a 0.857  clct[np.int64(50), np.int64(50)] ans[np.int64(50), np.int64(50)] lr 0.061216 cl_acc 1.000000 132.748sec(train) 5.076sec(infer)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 140 tst: l 0.676 a 0.824  clct[np.int64(10), np.int64(10)] ans[np.int64(10), np.int64(10)] cl_acc 1.000000 1.496sec\n",
      "result written at output/results.pickle\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "result written at output/results.pickle\n",
      "---train cluster Ended in 6.09 hour (21940.725 sec) \n"
     ]
    }
   ],
   "source": [
    "import json\n",
    "import time\n",
    "import torch\n",
    "import numpy as np\n",
    "\n",
    "\n",
    "with open(\"config.json\", \"r\") as read_file:\n",
    "    config = json.load(read_file)\n",
    "\n",
    "for lr in learning_rates:\n",
    "    config['lr'] = lr\n",
    "    res_final = []\n",
    "\n",
    "    for seed in seeds:\n",
    "        print(f\"---------------------------------IFCA, lr: {lr}, seed: {seed}---------------------------------\")\n",
    "        start_time = time.time()\n",
    "        config['data_seed'] = seed\n",
    "        config['train_seed'] = config['data_seed']\n",
    "\n",
    "        print(\"config:\",config)\n",
    "        device = torch.device(\"cuda:2\" if torch.cuda.is_available() else \"cpu\")\n",
    "        print(f\"Using device: {device}\")\n",
    "\n",
    "        exp = IFCA.TrainCIFARCluster(config)\n",
    "        exp.setup()\n",
    "        res = exp.run()\n",
    "        res_final.append([[r['test']['loss'] for r in res], [r['test']['acc'] for r in res], [r['test']['cl_acc'] for r in res]])\n",
    "        del exp\n",
    "        duration = (time.time() - start_time)\n",
    "        print(\"---train cluster Ended in %0.2f hour (%.3f sec) \" % (duration/float(3600), duration))\n",
    "\n",
    "    res_mean = np.mean(res_final, axis=0).tolist()\n",
    "    ifca.append(res_mean)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-08-10T00:19:13.153709Z",
     "iopub.status.busy": "2025-08-10T00:19:13.153480Z",
     "iopub.status.idle": "2025-08-10T00:19:13.699046Z",
     "shell.execute_reply": "2025-08-10T00:19:13.698001Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Average Test Loss (Last Epoch): 0.6678\n",
      "Average Test Accuracy (Last Epoch): 0.8253\n",
      "Average Cluster Accuracy (Last Epoch): 1.0000\n"
     ]
    },
    {
     "data": {
      "image/png": "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5+e7Pd8zzzxjBAYGlniuwkthZTnOtkyYMKFc7TVnzhyX55szZ065zmcYhrF582bj/PPPL1XdNWrUMGbPnu32XKmpqca//vWvMrVF9+7dXZ7L0/elrFauXOnynDt37jRuv/32Yp/36quvNlJTU4s9/6JFi4xGjRqV6nUMGDDASEpKcnuupk2buvyZmjlzphEaGuq1n7eyvF+l4er3vWnTpsaBAweMTp06uW0Pi8VijB8/vthz5+bmGuPHj3f5+l0t11xzjXHo0KESzzlhwgQjIiKiVOccOnSo0zncvVfffPONUadOHbfnqlu3rrFt27Zyt3VhDz30kNP5X3311WKPGTp0aKne+8TERJf1//DDD8Y999zjcltx/757W0FBgVGzZk2nGm6++WaX+7/xxhsua966dWul1Dty5EiXz//LL7+43L979+5Ov0/e8sUXX5S63YDyYiggYKL8/HzdfPPN+vrrr0u1f3Z2tiZNmqTt27dr/vz5TkMp3n//ff3nP/+piFL9wjfffKObbrqp1BdHnzlzRiNGjNC2bdv0xhtvOG0fM2ZMsUM/S8uX3pehQ4dq3bp1xe6zbNkyXX/99VqxYoXL4TovvfSSHnvssVI/54IFC7Rt2zatXbvW7fWJRS1atEi//fabDMMo9fP4grS0NF155ZXFTi9tGIaef/55BQYG6tlnn3XanpOTo2uvvVY//PBDqZ/3u+++U8eOHfXjjz869R5I1ske+vbtq9WrV5f6nKW1bNkyTZ48Wbm5uW73OX78uAYOHKht27YpODjYo+dzdW3RxRdf7NE5S/L444+Xqmdw8eLFXutR7dy5s2bOnOmw7u+//3Z5/ZK7KeYvvPBCl+t//fVXnX/++Z4XWYKYmBiX6+vXr1+q40+ePKnLL79cO3bsUHJysqKiolS3bl117txZ1113nW655RaFhISU6lyufkaWLVumvLw8BQXxcRjewU8SYKJx48a5DFWBgYFq1KiRwsPDtXfvXmVlZTls//zzzzVp0iSn8fNvvfWWy+epX7++6tSpo+zsbB0/flxnzpxxW5PtP+hTp065nEHK1X/gvnBh/99//61Bgwa5DFWRkZFKSEjQyZMndfToUaftb775ptq0aaP77rvPvi4pKUkfffSR07624V4xMTFKT0/XoUOHlJmZWWxt3nhfvMUWqiIjI3XOOefo2LFjLodprV69Wq+++qoeeeQRh/Vff/21Hn/8cZfnjo+PV61atXTw4EElJyc7bNu1a5cGDBhQ6mFTmzdvtj+Ojo5W06ZNlZyc7PWZvFavXi2LxVLsPk2bNi31bGq2aa4lqU6dOoqPj1diYqLS0tKc9p08ebL69eunLl26OKwfM2aM21DVrFkzRUZGateuXU5B5sSJE7ruuuv0+++/KyIiwmHbsGHD3IaqoKAgNW/eXCEhITp06JDbiQfc+eWXX+yPmzdvLsMwXA712rFjh7766iuProU6ffq00zDA4OBgXXDBBeU+Z2kUDlV169ZVvXr1XP7unDx5slTDX0sjKirKad3WrVtd7tukSROX6xs1auRyvbvzeNv69eud1tWrV0+NGzcu1fHp6elau3at/fukpCQlJSVp165d+uSTT/TEE0/ovffe01VXXVXiuRo0aKBGjRo5DHFNTU3V9u3b1bFjx1LVA5TI5B4zoEopy1DAnTt3GkFBQU77Dh8+3Dhy5Ih9v5SUFGPs2LFO+4WFhTkN/Sk6xCcqKspYt26d03MfOXLE+Pzzz41Ro0YZdevWdfla3A3T8yZvDgUcOHCgy3M9/vjjRmZmpn2/RYsWGVFRUU771a5d20hJSbHvt379eqd9OnToYBw+fNjhefPz841du3YZ7777rjFgwACjb9++TrV5830pLXdDASUZDz74oJGRkWEYhnVo0bx581wOOatXr56RnZ1tP2dOTo5xzjnnOO138cUXOwwtys/PN+bMmWMEBwc77fvFF1841epqeJlkHfo6a9YsIycnx77voUOHyj2MyV17lLS4G47k7vc9ODjY+N///mcUFBQYhmEYWVlZxrhx41zue+ONNzqcc/v27UZAQIDTfgkJCcamTZvs+508edK46aabXJ7z+eefdzinu5+F0NBQY+rUqU7DPrdu3WqMHj3auPfee51es7v3qkmTJsbGjRvt+/3vf/9zOfR1+PDhZXrPinL1Wlq1alXicZ4OBbS9xh9++MFh/61btzr8O+zu37TyLK7qmz59ust9v/nmG5evOz093eX+gwYNKrHNPLVixQqXzz1p0iS3xxQdCliaJSAgwJg/f36paurTp4/T8Z4MPQeKIlgBXlSWYPX444877de1a1e353Z1zUbRD1BFP8C3atXK/uHOnby8PJfr/SlYJSUlufwQd91117ncf/bs2S6f98MPP7Tv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u5zsYfbs2S73/+ijj5zuDSY5X3firj0DAwPVtGlT9e/f3+leYpJ18oDSnEcq+/viqffee8/l+rlz57pcf9lll9kfu/qZ3b59u8O1YsXZsWOH/vzzz1Lt68/K0sZBQUEO97Fyde3Tli1bXN6cNicnRx988IHT+nPPPdchrLm6x8+vv/5a4o3JXf2OmM3VNYK7d+/2+Notf2GxWDRkyBCn9d99953L0PDJJ584rWvXrp3L6/2GDRsmi8XisPTo0cNtLUlJSerTp4/LUDVmzBh9+eWXZQpVb775ptsJcgr76aefHCbVsWnevHmJPYvbt293Wsc9rOBNBCvAJHfddZdTGDh69Kh69+6t7777zunC3PT0dP3000966qmndN5556lXr15OM2zdcMMN6tu3r95++23t3LnTachVdna225vVFp0Br0aNGi73W7RoUaleX2WKjY11OcPZkiVLNH78eIcPiIsXL7b3PBVWq1Yt/etf/3JYFx8fr6FDh+rTTz/V4cOHnY45ffq05syZ47S+aFt6833x1KpVq/TII4/Y28QwDH366af673//67RvvXr1HC7a79Wrl8u/7t5www167733nD6I5+bmatu2bXrllVfUrVs3tW7d2uUNQ6uayZMn66OPPrL/DmdnZ+vxxx932UvUr18/h1nShg0b5rKHcuDAgfrtt9/s358+fVq33nqryxvxDh8+3OH7kSNHuqxz8ODBeu2115yC/19//aWHH35YDz74YDGv0hy1a9d2miAmNzfXoW2quvvuu8/p/4709HTdcccd9mvq8vLyNGHCBPsNwQu7//77Pa5h//79uvzyy7Vy5UqH9QEBAXrllVf0xhtvlLmnfdOmTbrqqqvUuXNnTZs2zelnOysrS6+99pr69evncrbDAQMGFHv+Q4cOOd1gPCoqyu2kMkC5VNK07kC1UJb7WBmGYTz44INu78sRERFhtGjRwmjXrp3RsGFDw2KxOO2TmJjocL6i9wAJCQkxEhISjA4dOhitWrUyIiMjXT5X8+bNnWo7ePCg29qaNWtmdO7c2b4UvolsWbi750vR87tbPv74Y/u5du7c6fb1RUVFGe3btzfq16/v9jVNmzbNqb6i+0RHRxstWrQwOnbsaDRv3tzlDZ4lGXfffXeFvS+lVdwNggu3Sb169dzuM3XqVKfzfvHFF273Dw4ONpo0aWJ06NDBaNasmRESEuK0j6t7lLm6N9KECRPK/drdcdcOpflZu/XWW53O5+733bbUrVvXaN++vREdHe1ye0BAgPHrr786nfeee+5xe86EhASjbdu2LtvWtt3VfYLc3UDb9r61atXKaN++vVGrVi37+qFDhzqdpyzvlav2cXdPsLIYM2aM03lff/31Yo/x9D5W7v4NN4u7+52Fh4cbbdu2NWrWrOly+8UXX2zk5+e7PGdp28gwDOOqq65yef7o6OhS/T4tWrSoVM9fq1Yto23btkbTpk2LvY9VnTp13N5Pz+bzzz93Oq5///5lbnugOFxjBZho6tSpSkxM1MKFC522ZWRk6O+///bo/Dk5OUpMTCxxv6eeesppXcOGDXXZZZe5vEB47969DvfVKigo8KjOks7vzrFjx+yPW7ZsqU8++UQDBgxwmno4LS2t2OuARo0apf/3//5fic+Xmppa7EQCknUqd1c9YoV58r546vrrr9fixYtLbJPu3btr7NixTuv79++vF198UY899pjTttzcXO3fv9/thfS+qLTTxZfm3luStZevcePG2rhxo44fP67jx4+73ffJJ590GAZo89Zbb+mff/5xOQ18cT83tWrVcnufoLlz5+rYsWNavXq107bc3Fzt2LHD7Xl9zS233OJ0LeoPP/ygBx54wKSKKt9zzz2nP//8U0uXLnVYn5mZqT/++MPlMQkJCZo3b55Xrtl0N717ampqqX6fSjvE+dSpUyVeQxcTE6NFixa5HWVh42qY4S233FKqOoDSYiggYKKgoCB9+eWXmjJlSpnuxRIaGqqbbrrJ6T+Ssg4bCwsL08svv6y77rrL5fZp06a5nXHPF/Xr108///yz2rZtW6r9Y2NjNWPGDE2fPt3l9uDg4DI9f/369bV48WK1adPGYb233xdPvP766xozZkyx+1x99dVavHix25sUjxs3TkuWLHE5mYU7FotFXbt2LfPNdv1NWFiYvv3222KvTbFYLHriiSf07LPPutweGhqqZcuW6bHHHiv1z06vXr20ZcsWp589m/DwcC1fvlwTJkyokMkEKtPll1/uNBzw22+/9fjmw/4kLCxMX331lR544IFSTWvfp08frVmzxuVkPr7ioosuKvMMfT169NCGDRtKnIwjLy9Pn332mcO6uLg49e/fv8x1AsWhxwowWUBAgB577DGNGjVKH3/8sVauXKnNmzfrxIkTSk1NVVhYmGrWrKlzzz1X559/vnr06KGePXu6DDxLly7Vhg0btHbtWm3evFm7du3S/v37lZycrNzcXEVERKhu3bo677zzdOWVV+q2225T/fr13dbWsWNHbd26Va+99pp++OEHJSYmKj093eX4dl/RuXNn/f7771q6dKm+/vprrVu3TocOHVJycrLCw8NVu3ZtXXDBBerdu7fuuOOOYu87dObMGa1Zs0br1q3Tli1btHv3bh06dEhpaWkyDEORkZFq1KiR2rVrpz59+mjQoEEup/r19vviiYCAAL3xxhsaMGCA3n77ba1du1bHjh1TTEyMOnXqpGHDhmnw4MElnufaa6/V7t27tXDhQi1dulS//vqrDh8+rOTkZAUGBio2NlbNmjVT27Ztdfnll+uqq67ymXsBVbRatWppxYoV+vDDD/XBBx9o27ZtOnPmjOrWrasePXpo9OjRJX4QDA4O1pQpU/TQQw/p/fff16pVq/THH3/o9OnTys3NVVxcnJo1a6auXbtq8ODBLnu+igoKCtLEiRM1duxYffjhh1q9erW2bNmikydPKi0tTTVr1lS9evXUtm1bXXXVVerTp4+3msSrLBaLHnjgAYceqpycHH322We69957TayscoWEhOj111/X/fffrw8//FDLli3T3r17dfr0aUVFRal+/frq3r27Bg4cWGzQ9xX333+/7r33Xq1Zs0arVq3S5s2b9ffff+vYsWNKS0tTSEiI4uLi1KJFC1188cUaNGiQOnfuXKpzL1u2zKmXbMSIEQoLC6uIl4JqzGL48ickAEC5rFq1ymHiCZvExESf/qu1P5k4caLTrJBNmzYt1TBWeCYjI0PNmjVzmEW1a9eu+umnn0ysCr5qyJAhmjdvnv370NBQ/fPPP9Xmjz2oPAwFBAAAfiUiIsLpGsS1a9e6vCYU1VtiYqLTMMBRo0YRqlAhCFYAAMDvjBo1yulaq+eee86kauCrpkyZ4nCLixo1alTIxECARLACAAB+KCQkRG+88YbDuqVLl2rz5s0mVQRfc/jwYacbcz/77LOqXbu2OQWhymPyCgAA4Jf69u3r05PpwFwNGjRwunE5UJHosQIAAAAADzErIAAAAAB4iKGARRQUFOjw4cOKjo6WxWIxuxwAAAAAJjEMQ6mpqWrQoIECAoof7EewKuLw4cNq3Lix2WUAAAAA8BEH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eUTffvutLBaLnn32WS1evNjlvqGhoYqJiXFY/ArBCgAAADBdlQxWNl26dNHll18uSZo1a5bJ1VQQplsHAAAATFelg5UkNWzYUJL0zz//mFxJBWG6dQAAAMB0VT5Y7dmzR5IUHR1tciUVhKGAAAAAgOn8Nljl5+fLMIxi9/nhhx+0fv16SVKPHj0qoSoT1Khh/Xr6tFRCewAAAACoGJUerHbv3q1ff/1Vx44d8+g8Bw4c0AUXXKCZM2dqz549DiHrwIEDeuGFF3TDDTfIMAzVrFlTDz30kKel+6a6da1fs7Mlf7sHFwAAAFBFeO0GwcePH9eCBQskSbfddptibUPU/s8///yjQYMGacuWLZIki8WiG264Qe+8845q2Hpdymjr1q267777JEkhISGKiYlRZmam0tPT7fskJCTo888/V3x8fLmew+dFREjR0VJqqnTs2NmhgQAAAAAqjdeC1RdffKHRo0erRYsW+n//7/85bMvOzlbfvn0depYMw9BXX32lEydO6Mcffyzz8zVo0ECfffaZVq1apV9//VWHDx/WyZMnFRgYqCZNmqhDhw664YYbdOuttyo8PNwrr9Fn1at3Nli1bGl2NQAAAEC147VgtWzZMlksFvXv399p29y5c7V7925ZLBb961//Uq9evbR8+XItWrRIa9eu1aeffqpBgwaV6flCQkI0YMAADRgwwFsvwX/Vqyf984909KjZlQAAAADVkteusdq5c6ck6ZJLLnHa9vHHH0uSrrzySn311VcaM2aMvv76a/Xu3VuGYWjevHneKqN6sg1z9PC6NQAAAADl47VgdeLECUlSo0aNHNZnZmZq3bp1slgsuvfeex22DR8+XJK0efNmb5VRPdWrZ/1KsAIAAABM4bVglZSUZD1hgOMp161bp9zcXFksFvXu3dthW0JCgiTrxBfwAMEKAAAAMJXXglVUVJQk6WiR63xWrVolSWrTpo3T7H/BwcGSpKAgr13qVT3ZghXXWAEAAACm8FqwatWqlSTp22+/dVj/+eefy2KxqHv37k7H2EJYPVswQPlwjRUAAABgKq91FV133XVat26dZs2apdatW6tbt26aO3eu/vzzT1ksFt10001Ox9iurWrYsKG3yqieGAoIAAAAmMprwWr06NGaPn26jhw5otGjRztsu/TSS9WzZ0+nYxYtWiSLxaKLLrrIW2VUT4WDlWFIFou59QAAAADVjNeGAsbGxmr58uXq1KmTDMOwL926ddP8+fOd9t+6das2bNggSbrqqqu8VUb1ZAtWWVlSSoq5tQAAAADVkFdnjWjdurU2btyoxMREHT16VPXr11ezZs3c7j9nzhxJ1vtbwQMREVJ0tJSaau21io01uyIAAACgWqmQ6fgSEhLsU6m706FDB3Xo0KEinr56qlfvbLBq2dLsagAAAIBqxWtDAWEyJrAAAAAATFOpN5BatGiR5s+fr5MnTyohIUH33HOPOnXqVJklVF0EKwAAAMA0XuuxWrlyperWrasmTZooKSnJafu///1v3Xjjjfr444+1bNkyzZw5U5dccok++OADb5VQvdnuZcVNggEAAIBK57Vg9c033+jkyZO66KKLFBcX57Bt27Ztmjx5sn2mwLi4OBmGoby8PI0cOVJ79+71VhnVFz1WAAAAgGm8Fqx++uknWSwW9e7d22nbjBkzZBiGatSooU2bNunUqVNav369atasqezsbL399tveKqP6IlgBAAAApvFasDpy5IgkqW3btk7bFi9eLIvFotGjR+uCCy6QJF144YUaPXq0DMPQ8uXLvVVG9UWwAgAAAEzjtWB14sQJSXIaBrh7924dOnRIktS/f3+Hbd26dbPvAw9xjRUAAABgGq8FK8MwJEnJyckO69esWSNJio2NVceOHR221apVS5KUkZHhrTKqr8I9Vv/3XgAAAACoHF4LVvH/12Py119/Oaz/7rvvJEldu3Z1OiY9PV2SVKNGDW+VUX3ZglVWlvVGwQAAAAAqjdeC1SWXXCLDMDRjxgx7D9SePXv09ddfy2Kx6KqrrnI6ZteuXZLOhjJ4ICJCioqyPuY6KwAAAKBSeS1Y3XPPPZKsU6u3a9dOAwYM0CWXXKKsrCyFh4fr1ltvdTrmxx9/lCS1bNnSW2VUb7aASrACAAAAKpXXgtWVV16pBx98UIZhaO/evfryyy918uRJSdJLL72k2rVrO+yflZVl78264oorvFVG9WYbDsgEFgAAAEClCvLmyV599VX16tVLn332mY4ePar69evrzjvv1JVXXum078KFCxUTE6PY2Fj169fPm2VUX0y5DgAAAJjCq8FKkq6//npdf/31Je43cOBADRw40NtPX70RrAAAAABTeG0oIHwAwQoAAAAwhdd7rIrKy8vTmTNnJFmnVQ8KqvCn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",
      "text/plain": [
       "<Figure size 1000x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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prauDRERERFRhVOus0oGBwdj4sSJuHXrFj744IPyvDSVpaNH5cemTQF3d9vWhYiIiIioAir35QDa/ncP1ObNm8v70lRWjhyRH1u0sG09iIiIiIgqqHIP3Nzc3AAAycnJ5X1pKiu6wK15c9vWg4iIiIiogir3wG3/f7MPqlSq8r40lQUhCoZKsseNiIiIiKhMlGvgdvDgQcycOROSJKFly5bleWkqKxcvAmlp8r1tjRvbujZERERERBWSouUAZs6cWWwarVaLO3fu4MiRI/jzzz+h1WohSRImTpyo5NJkLwpPTPLfMFgiIiIiIrIuRYHb9OnTi12AuzAhBFxcXPDBBx/gscceU3JpshecmISIiIiIqMwpCtwAORgriiRJ8PHxQUREBDp06IDnnnsOUVFRSi9L9oKBGxERERFRmVMUuGm1WmvVgxyRVgscOybvc0ZJIiIiIqIyU+6zSlIF8u+/QHo64OEBsBeViIiIiKjMMHCj0tNNTPLAA4Crq23rQkRERERUgTFwo9Lj/W1EREREROVCUeB26tQp1KlTB5GRkUhKSio2fVJSEurVq4e6deviwoULSi5N9oCBGxERERFRuVAUuK1atQoJCQmoV68ewsLCik0fFhaG+vXrIyEhAatWrVJyabI1TkxCRERERFRuFAVuv/76KyRJwpNPPmlxnp49e0IIgV27dim5NNnahQtAZibg6Qk0amTr2hARERERVWiKAjfdcMemTZtanKdJkyYAgPPnzyu5NNmabphkTAzgong5QCIiIiIiKoKiwC0zMxMA4O3tbXEeXdr09HQllyZb080oyWGSRERERERlTlHg5u/vDwC4fv26xXl0aX18fJRcmmyNE5MQEREREZUbRYFbZGQkAGDr1q0W59myZQsAoG7dukouTbak0QDHj8v7DNyIiIiIiMqcosDt8ccfhxACixcvxrlz54pNf+bMGXz55ZeQJAldunRRcmmypfPngawswMsLaNDA1rUhIiIiIqrwFAVuY8eOhZeXF3Jzc/Hoo4/i559/Npt248aNiIuLQ05ODjw9PTFu3DgllyZbKjwxibOzbetCRERERFQJKJoOMCgoCIsWLcLTTz+NlJQU9OzZE3Xq1EHbtm0REhICALh27Rr27duH+Ph4CCEgSRIWLlyI6tWrW+UJkA3ohklyYhIiIiIionKheB73IUOGQKvVYuzY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",
      "text/plain": [
       "<Figure size 1000x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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R454xwEAAACoNIIbqs/x49U7DgAAAIAkghuqU3x89Y4DAAAAIInghurUp4/UsqVkGGVvNwypVSvvOAAAAACVRnBD9QkNlV5+uextRWHupZd4EDcAAADgJ4Ibqtedd0q//nXp9S1bSosWebcDAAAA8EuY1Q2gDjp71vvrvfdKAwd6r2nr04czbQAAAEAVEdxQvQoLpTVrvMtjxkg33GBtPwAAAEAdwFRJVK/du6UffpAcDunaa63uBgAAAKgTCG6oXkVn2268UYqIsLYXAAAAoI4guKF6FQW3vn2t7QMAAACoQwhuqD65udKGDd5lghsAAABQbQhuqD6ffy55PNLFF0uJiVZ3AwAAANQZQR/cMjIyNGXKFCUmJioqKkpOp1M9evTQjBkzlJubG1DtRYsWadCgQWrevLkiIiLUqFEjXX755Ro7dqy+/PLL6nkDdcnq1d5f+/b97wO3AQAAAATMME3TtLqJqjp06JCSkpKUlpYmSXI4HCooKFBOTo4kqWvXrlq7dq2aNGniV92cnBz94he/0NKlS33roqKilJub6wuDISEhmj59uh577DG/arvdbjmdTrlcLsXExPi1r+316uU96/b229L991vdDQAAAGBr/mSDoD3jlp+fr0GDBiktLU3x8fFavXq1srKy5PF4tGDBAkVHR2vnzp0aMWKE37WnTp3qC22//vWvdfToUWVkZOj8+fPatm2brr/+ehUWFmrChAnavn17db+14ORySVu3epdTUqztBQAAAKhjgja4zZ07V7t27ZIkffjhh+r7n5thhISE6O6779brr78uSVq+fLnWrl3rV+158+ZJkm688Ua9+uqratGiha929+7dtWzZMkVFRck0TS1atKi63lJwW7/e+/DtDh2k1q2t7gYAAACoU4I6uElScnKyevXqVWr70KFDlZCQIOm/Qayyjh8/Lkm6+uqry9zudDrVoUMHSVJmZqZftessHgMAAAAA1JigDG4ej0ebNm2SJA0cOLDMMYZhaMCAAZKkjz/+2K/67dq1k6Ryp0G6XC7t379fUvnhrt4pCm4332xtHwAAAEAdFJTBbd++fSosLJQkdenSpdxxRdtOnDihM2fOVLr+ww8/LElav369HnnkEaWnp0uSTNPUjh07dNtttykzM1O9evWq0jV0dc7Ro9I330ghIVJSktXdAAAAAHVOUAa3Y8eO+ZaL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J06cUKdOnTRv3jx1795dubm5euuttzR+/Hjl5ubq4Ycf1syZM2vrLQMAAACop4Ly5iSSFBYWpiVLlig5OVlpaWnq27evHA6HCgsLlZ2dLUnq2rWr5s+f73dtp9OpZcuWqX///tq7d6+uvvpqRUdHKzs7W3l5eZK8UyRffPHFan1PAAAAAFCWoJ0qKUlt27bV119/raeeekpdunSRYRgKDw9X9+7dNX36dH3++edq0qRJlWp3795de/bs0WOPPab27dsrLy9PjRo10vXXX6833nhDK1asCLrTqwAAAACCU9BOlQQAAACA+iKoz7gBAAAAQH1AcKuHMjIyNGXKFCUmJioqKkpOp1M9evTQjBkzlJuba3V78NPf//53GYZxwdeaNWusbhX/4fF4tGLFCv3lL3/RnXfeqTZt2vg+pylTplSqxsmTJzVhwgRdfvnlatiwoWJjY9WnTx+9+eabYiKFNQL5XKdMmVKpn+Pvv/++dt4MJEmnT5/WnDlzNGLECHXq1EmNGjVSgwYN1LJlSw0ePFgfffTRBWvwnWs/gXyufOfa044dO/T000/r5z//ua644go1bdpU4eHhatq0qXr37q1nnnlGZ86cqbBGMHyvBu3NSVA1hw4dUlJSku8xBw6HQzk5Odq2bZu2bdum+fPna+3atVW+NhDWCQkJ0UUXXVTudq7JtI+tW7fqlltuqfL+27dvV//+/XX69GlJUlRUlDIyMvTpp5/q008/1aJFi7RkyRJFRERUV8uohEA/V0kKDw9XbGxsudvDwvjark1xcXHKz8/3/T4yMlLh4eFKT09Xenq6/vnPf2rgwIFatGiRHA5Hqf35zrWnQD9Xie9cu3n77bf16quv+n4fGRmphg0b6syZM/rss8/02Wef6aWXXtKSJUvUq1evUvsHy/cqZ9zqkfz8fA0aNEhpaWmKj4/X6tWrlZWVJY/HowULFig6Olo7d+7UiBEjrG4VVdCqVSudOHGi3FefPn2sbhHFNGnSRCkpKZo0aZLee+89xcXFVWo/l8ul2267TadPn9YVV1yhL774QhkZGcrKytIrr7yi8PBwrVq1SuPHj6/ZN4AyVfVzLXLddddV+HP808fXoGbl5+erZ8+emjlzpg4cOKDz588rMzNTqamp+tWvfiVJWrFihR588MEy9+U7154C+VyL8J1rLz179tS0adO0efNmnT17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",
      "text/plain": [
       "<Figure size 1000x700 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "r_ifca = {}\n",
    "\n",
    "r_ifca['test_loss'] = []\n",
    "r_ifca['test_acc'] = []\n",
    "r_ifca['cl_acc'] = []\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",
    "\n",
    "os.makedirs('graphs', exist_ok=True)\n",
    "\n",
    "avg_test_loss = np.mean([loss[-1] for loss in r_ifca['test_loss']])\n",
    "avg_test_acc = np.mean([acc[-1] for acc in r_ifca['test_acc']])\n",
    "avg_cl_acc = np.mean([cl_acc[-1] for cl_acc in r_ifca['cl_acc']])\n",
    "std_test_acc = np.std([acc[-1] for acc in r_ifca['test_acc']])\n",
    "\n",
    "\n",
    "print(f\"Average Test Loss (Last Epoch): {avg_test_loss:.4f}\")\n",
    "print(f\"Average Test Accuracy (Last Epoch): {avg_test_acc:.4f}\")\n",
    "print(f\"Average Cluster Accuracy (Last Epoch): {avg_cl_acc:.4f}\")\n",
    "print(f\"Average Standard Deviation (Last Epoch): {std_test_acc:.4f}\")\n",
    "\n",
    "for l in range(len(learning_rates)):\n",
    "\n",
    "    plt.figure(figsize=(10,5))\n",
    "    plt.plot(r_ifca['test_loss'][l], label='ifca', color='red')\n",
    "    plt.xlabel('epoch', fontsize=20)\n",
    "    plt.ylabel('loss', fontsize=20)\n",
    "    plt.title(f'Test Loss per Epoch (lr={learning_rates[l]})', fontsize=22, fontweight='bold')\n",
    "    plt.tick_params(axis='both', which='major', labelsize=18)\n",
    "    plt.legend(fontsize=20)\n",
    "    plt.savefig(os.path.join('graphs', 'train_loss.png'))\n",
    "\n",
    "    plt.figure(figsize=(10,5))\n",
    "    plt.plot(r_ifca['test_acc'][l], label='ifca', 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='red', marker='o')\n",
    "    plt.xlabel('epoch', fontsize=20)\n",
    "    plt.ylabel('cluster acc', fontsize=20)\n",
    "    plt.legend(fontsize=20)\n",
    "    plt.tick_params(axis='both', which='major', labelsize=18)\n",
    "    plt.savefig(os.path.join('graphs', 'cluster_acc.png'))"
   ]
  }
 ],
 "metadata": {
  "accelerator": "GPU",
  "colab": {
   "gpuType": "T4",
   "provenance": []
  },
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.11.11"
  },
  "widgets": {
   "application/vnd.jupyter.widget-state+json": {
    "state": {
     "0a3c30b3d8404bf1bb9f5dc6cdabbe87": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {
       "_model_module": "@jupyter-widgets/base",
       "_model_module_version": "2.0.0",
       "_model_name": "LayoutModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "2.0.0",
       "_view_name": "LayoutView",
       "align_content": null,
       "align_items": null,
       "align_self": null,
       "border_bottom": null,
       "border_left": null,
       "border_right": null,
       "border_top": null,
       "bottom": null,
       "display": null,
       "flex": null,
       "flex_flow": null,
       "grid_area": null,
       "grid_auto_columns": null,
       "grid_auto_flow": null,
       "grid_auto_rows": null,
       "grid_column": null,
       "grid_gap": null,
       "grid_row": null,
       "grid_template_areas": null,
       "grid_template_columns": null,
       "grid_template_rows": null,
       "height": null,
       "justify_content": null,
       "justify_items": null,
       "left": null,
       "margin": null,
       "max_height": null,
       "max_width": null,
       "min_height": null,
       "min_width": null,
       "object_fit": null,
       "object_position": null,
       "order": null,
       "overflow": null,
       "padding": null,
       "right": null,
       "top": null,
       "visibility": null,
       "width": null
      }
     },
     "1a0b07184cfe426f99c99c0017acb51e": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLStyleModel",
      "state": {
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "2.0.0",
       "_model_name": "HTMLStyleModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "2.0.0",
       "_view_name": "StyleView",
       "background": null,
       "description_width": "",
       "font_size": null,
       "text_color": null
      }
     },
     "1f42fe2d8ae74beda955fbb202075795": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {
       "_model_module": "@jupyter-widgets/base",
       "_model_module_version": "2.0.0",
       "_model_name": "LayoutModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "2.0.0",
       "_view_name": "LayoutView",
       "align_content": null,
       "align_items": null,
       "align_self": null,
       "border_bottom": null,
       "border_left": null,
       "border_right": null,
       "border_top": null,
       "bottom": null,
       "display": null,
       "flex": null,
       "flex_flow": null,
       "grid_area": null,
       "grid_auto_columns": null,
       "grid_auto_flow": null,
       "grid_auto_rows": null,
       "grid_column": null,
       "grid_gap": null,
       "grid_row": null,
       "grid_template_areas": null,
       "grid_template_columns": null,
       "grid_template_rows": null,
       "height": null,
       "justify_content": null,
       "justify_items": null,
       "left": null,
       "margin": null,
       "max_height": null,
       "max_width": null,
       "min_height": null,
       "min_width": null,
       "object_fit": null,
       "object_position": null,
       "order": null,
       "overflow": null,
       "padding": null,
       "right": null,
       "top": null,
       "visibility": null,
       "width": null
      }
     },
     "2399aea95518487eb735b60b0e73b663": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLModel",
      "state": {
       "_dom_classes": [],
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "2.0.0",
       "_model_name": "HTMLModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/controls",
       "_view_module_version": "2.0.0",
       "_view_name": "HTMLView",
       "description": "",
       "description_allow_html": false,
       "layout": "IPY_MODEL_4256ef12093e4a24bf1c79a48dfbb9e6",
       "placeholder": "​",
       "style": "IPY_MODEL_1a0b07184cfe426f99c99c0017acb51e",
       "tabbable": null,
       "tooltip": null,
       "value": " 3/3 [4:42:41&lt;00:00, 2065.89s/tasks]"
      }
     },
     "2c0f94a47f3b436fb5c7396ebca0c715": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "FloatProgressModel",
      "state": {
       "_dom_classes": [],
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "2.0.0",
       "_model_name": "FloatProgressModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/controls",
       "_view_module_version": "2.0.0",
       "_view_name": "ProgressView",
       "bar_style": "success",
       "description": "",
       "description_allow_html": false,
       "layout": "IPY_MODEL_1f42fe2d8ae74beda955fbb202075795",
       "max": 3,
       "min": 0,
       "orientation": "horizontal",
       "style": "IPY_MODEL_fcac53cc894248edacd37bb9e727a6f3",
       "tabbable": null,
       "tooltip": null,
       "value": 3
      }
     },
     "337e384cd1e04f21b2bdaf2671114662": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {
       "_model_module": "@jupyter-widgets/base",
       "_model_module_version": "2.0.0",
       "_model_name": "LayoutModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "2.0.0",
       "_view_name": "LayoutView",
       "align_content": null,
       "align_items": null,
       "align_self": null,
       "border_bottom": null,
       "border_left": null,
       "border_right": null,
       "border_top": null,
       "bottom": null,
       "display": null,
       "flex": null,
       "flex_flow": null,
       "grid_area": null,
       "grid_auto_columns": null,
       "grid_auto_flow": null,
       "grid_auto_rows": null,
       "grid_column": null,
       "grid_gap": null,
       "grid_row": null,
       "grid_template_areas": null,
       "grid_template_columns": null,
       "grid_template_rows": null,
       "height": null,
       "justify_content": null,
       "justify_items": null,
       "left": null,
       "margin": null,
       "max_height": null,
       "max_width": null,
       "min_height": null,
       "min_width": null,
       "object_fit": null,
       "object_position": null,
       "order": null,
       "overflow": null,
       "padding": null,
       "right": null,
       "top": null,
       "visibility": null,
       "width": null
      }
     },
     "4256ef12093e4a24bf1c79a48dfbb9e6": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {
       "_model_module": "@jupyter-widgets/base",
       "_model_module_version": "2.0.0",
       "_model_name": "LayoutModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "2.0.0",
       "_view_name": "LayoutView",
       "align_content": null,
       "align_items": null,
       "align_self": null,
       "border_bottom": null,
       "border_left": null,
       "border_right": null,
       "border_top": null,
       "bottom": null,
       "display": null,
       "flex": null,
       "flex_flow": null,
       "grid_area": null,
       "grid_auto_columns": null,
       "grid_auto_flow": null,
       "grid_auto_rows": null,
       "grid_column": null,
       "grid_gap": null,
       "grid_row": null,
       "grid_template_areas": null,
       "grid_template_columns": null,
       "grid_template_rows": null,
       "height": null,
       "justify_content": null,
       "justify_items": null,
       "left": null,
       "margin": null,
       "max_height": null,
       "max_width": null,
       "min_height": null,
       "min_width": null,
       "object_fit": null,
       "object_position": null,
       "order": null,
       "overflow": null,
       "padding": null,
       "right": null,
       "top": null,
       "visibility": null,
       "width": null
      }
     },
     "449d46dc356a40d6ad3bd0c8fd03e4ef": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HBoxModel",
      "state": {
       "_dom_classes": [],
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "2.0.0",
       "_model_name": "HBoxModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/controls",
       "_view_module_version": "2.0.0",
       "_view_name": "HBoxView",
       "box_style": "",
       "children": [
        "IPY_MODEL_f95aa764f6004f378bed561ca11e4d55",
        "IPY_MODEL_7c403a12612f4870a5fea409cc10061a",
        "IPY_MODEL_d414853e3519414e998086cb00a4bee3"
       ],
       "layout": "IPY_MODEL_6a531147c8b34e6ab1e2aaf7f0650be5",
       "tabbable": null,
       "tooltip": null
      }
     },
     "51e5577e0adb4caebccfb7a5d15ed679": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLStyleModel",
      "state": {
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "2.0.0",
       "_model_name": "HTMLStyleModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "2.0.0",
       "_view_name": "StyleView",
       "background": null,
       "description_width": "",
       "font_size": null,
       "text_color": null
      }
     },
     "6a531147c8b34e6ab1e2aaf7f0650be5": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {
       "_model_module": "@jupyter-widgets/base",
       "_model_module_version": "2.0.0",
       "_model_name": "LayoutModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "2.0.0",
       "_view_name": "LayoutView",
       "align_content": null,
       "align_items": null,
       "align_self": null,
       "border_bottom": null,
       "border_left": null,
       "border_right": null,
       "border_top": null,
       "bottom": null,
       "display": null,
       "flex": null,
       "flex_flow": null,
       "grid_area": null,
       "grid_auto_columns": null,
       "grid_auto_flow": null,
       "grid_auto_rows": null,
       "grid_column": null,
       "grid_gap": null,
       "grid_row": null,
       "grid_template_areas": null,
       "grid_template_columns": null,
       "grid_template_rows": null,
       "height": null,
       "justify_content": null,
       "justify_items": null,
       "left": null,
       "margin": null,
       "max_height": null,
       "max_width": null,
       "min_height": null,
       "min_width": null,
       "object_fit": null,
       "object_position": null,
       "order": null,
       "overflow": null,
       "padding": null,
       "right": null,
       "top": null,
       "visibility": null,
       "width": null
      }
     },
     "7c403a12612f4870a5fea409cc10061a": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "FloatProgressModel",
      "state": {
       "_dom_classes": [],
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "2.0.0",
       "_model_name": "FloatProgressModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/controls",
       "_view_module_version": "2.0.0",
       "_view_name": "ProgressView",
       "bar_style": "success",
       "description": "",
       "description_allow_html": false,
       "layout": "IPY_MODEL_7ef1404e2d4e4840b8612724952752fb",
       "max": 3,
       "min": 0,
       "orientation": "horizontal",
       "style": "IPY_MODEL_cf97ab3bed9b4c7f8c85e75977fdfb2d",
       "tabbable": null,
       "tooltip": null,
       "value": 3
      }
     },
     "7ef1404e2d4e4840b8612724952752fb": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {
       "_model_module": "@jupyter-widgets/base",
       "_model_module_version": "2.0.0",
       "_model_name": "LayoutModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "2.0.0",
       "_view_name": "LayoutView",
       "align_content": null,
       "align_items": null,
       "align_self": null,
       "border_bottom": null,
       "border_left": null,
       "border_right": null,
       "border_top": null,
       "bottom": null,
       "display": null,
       "flex": null,
       "flex_flow": null,
       "grid_area": null,
       "grid_auto_columns": null,
       "grid_auto_flow": null,
       "grid_auto_rows": null,
       "grid_column": null,
       "grid_gap": null,
       "grid_row": null,
       "grid_template_areas": null,
       "grid_template_columns": null,
       "grid_template_rows": null,
       "height": null,
       "justify_content": null,
       "justify_items": null,
       "left": null,
       "margin": null,
       "max_height": null,
       "max_width": null,
       "min_height": null,
       "min_width": null,
       "object_fit": null,
       "object_position": null,
       "order": null,
       "overflow": null,
       "padding": null,
       "right": null,
       "top": null,
       "visibility": null,
       "width": null
      }
     },
     "81911ddd6bf3483aa58b720cf8ac5608": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HBoxModel",
      "state": {
       "_dom_classes": [],
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "2.0.0",
       "_model_name": "HBoxModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/controls",
       "_view_module_version": "2.0.0",
       "_view_name": "HBoxView",
       "box_style": "",
       "children": [
        "IPY_MODEL_f0fe7929373b42f9bb4bdb6fe8559604",
        "IPY_MODEL_2c0f94a47f3b436fb5c7396ebca0c715",
        "IPY_MODEL_2399aea95518487eb735b60b0e73b663"
       ],
       "layout": "IPY_MODEL_cd90a682b5ca4cbabbd99dedf018cca9",
       "tabbable": null,
       "tooltip": null
      }
     },
     "cd90a682b5ca4cbabbd99dedf018cca9": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {
       "_model_module": "@jupyter-widgets/base",
       "_model_module_version": "2.0.0",
       "_model_name": "LayoutModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "2.0.0",
       "_view_name": "LayoutView",
       "align_content": null,
       "align_items": null,
       "align_self": null,
       "border_bottom": null,
       "border_left": null,
       "border_right": null,
       "border_top": null,
       "bottom": null,
       "display": null,
       "flex": null,
       "flex_flow": null,
       "grid_area": null,
       "grid_auto_columns": null,
       "grid_auto_flow": null,
       "grid_auto_rows": null,
       "grid_column": null,
       "grid_gap": null,
       "grid_row": null,
       "grid_template_areas": null,
       "grid_template_columns": null,
       "grid_template_rows": null,
       "height": null,
       "justify_content": null,
       "justify_items": null,
       "left": null,
       "margin": null,
       "max_height": null,
       "max_width": null,
       "min_height": null,
       "min_width": null,
       "object_fit": null,
       "object_position": null,
       "order": null,
       "overflow": null,
       "padding": null,
       "right": null,
       "top": null,
       "visibility": null,
       "width": null
      }
     },
     "cf97ab3bed9b4c7f8c85e75977fdfb2d": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "ProgressStyleModel",
      "state": {
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "2.0.0",
       "_model_name": "ProgressStyleModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "2.0.0",
       "_view_name": "StyleView",
       "bar_color": null,
       "description_width": ""
      }
     },
     "d414853e3519414e998086cb00a4bee3": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLModel",
      "state": {
       "_dom_classes": [],
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "2.0.0",
       "_model_name": "HTMLModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/controls",
       "_view_module_version": "2.0.0",
       "_view_name": "HTMLView",
       "description": "",
       "description_allow_html": false,
       "layout": "IPY_MODEL_337e384cd1e04f21b2bdaf2671114662",
       "placeholder": "​",
       "style": "IPY_MODEL_51e5577e0adb4caebccfb7a5d15ed679",
       "tabbable": null,
       "tooltip": null,
       "value": " 3/3 [00:05&lt;00:00,  5.48s/engine]"
      }
     },
     "f09390fd4e844b878333ab7232c8ad25": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {
       "_model_module": "@jupyter-widgets/base",
       "_model_module_version": "2.0.0",
       "_model_name": "LayoutModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "2.0.0",
       "_view_name": "LayoutView",
       "align_content": null,
       "align_items": null,
       "align_self": null,
       "border_bottom": null,
       "border_left": null,
       "border_right": null,
       "border_top": null,
       "bottom": null,
       "display": null,
       "flex": null,
       "flex_flow": null,
       "grid_area": null,
       "grid_auto_columns": null,
       "grid_auto_flow": null,
       "grid_auto_rows": null,
       "grid_column": null,
       "grid_gap": null,
       "grid_row": null,
       "grid_template_areas": null,
       "grid_template_columns": null,
       "grid_template_rows": null,
       "height": null,
       "justify_content": null,
       "justify_items": null,
       "left": null,
       "margin": null,
       "max_height": null,
       "max_width": null,
       "min_height": null,
       "min_width": null,
       "object_fit": null,
       "object_position": null,
       "order": null,
       "overflow": null,
       "padding": null,
       "right": null,
       "top": null,
       "visibility": null,
       "width": null
      }
     },
     "f0fe7929373b42f9bb4bdb6fe8559604": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLModel",
      "state": {
       "_dom_classes": [],
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "2.0.0",
       "_model_name": "HTMLModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/controls",
       "_view_module_version": "2.0.0",
       "_view_name": "HTMLView",
       "description": "",
       "description_allow_html": false,
       "layout": "IPY_MODEL_0a3c30b3d8404bf1bb9f5dc6cdabbe87",
       "placeholder": "​",
       "style": "IPY_MODEL_fa03744c1bc045a981f6d06895cd71ff",
       "tabbable": null,
       "tooltip": null,
       "value": "unknown: 100%"
      }
     },
     "f39d3a65294343b784594b2883a36c8f": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLStyleModel",
      "state": {
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "2.0.0",
       "_model_name": "HTMLStyleModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "2.0.0",
       "_view_name": "StyleView",
       "background": null,
       "description_width": "",
       "font_size": null,
       "text_color": null
      }
     },
     "f95aa764f6004f378bed561ca11e4d55": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLModel",
      "state": {
       "_dom_classes": [],
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "2.0.0",
       "_model_name": "HTMLModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/controls",
       "_view_module_version": "2.0.0",
       "_view_name": "HTMLView",
       "description": "",
       "description_allow_html": false,
       "layout": "IPY_MODEL_f09390fd4e844b878333ab7232c8ad25",
       "placeholder": "​",
       "style": "IPY_MODEL_f39d3a65294343b784594b2883a36c8f",
       "tabbable": null,
       "tooltip": null,
       "value": "100%"
      }
     },
     "fa03744c1bc045a981f6d06895cd71ff": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLStyleModel",
      "state": {
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "2.0.0",
       "_model_name": "HTMLStyleModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "2.0.0",
       "_view_name": "StyleView",
       "background": null,
       "description_width": "",
       "font_size": null,
       "text_color": null
      }
     },
     "fcac53cc894248edacd37bb9e727a6f3": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "ProgressStyleModel",
      "state": {
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "2.0.0",
       "_model_name": "ProgressStyleModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "2.0.0",
       "_view_name": "StyleView",
       "bar_color": null,
       "description_width": ""
      }
     }
    },
    "version_major": 2,
    "version_minor": 0
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
